Exemplo n.º 1
0
        /// <summary>
        /// Called by InvokeAction(string[] args) and assumes that ArgumentParser has been created.
        /// </summary>
        private void InvokeAction()
        {
            // save the arguments.
            if (null == _commandlineParsers)
            {
                // the arguments must be created @see InvokeAction(string[] args)
                throw new ArgumentNullException(nameof(_commandlineParsers));
            }

            // are we installing?
            if (_commandlineParsers.IsSet("install"))
            {
                InvokeActionInstall();
                return;
            }

            // uninstalling?
            if (_commandlineParsers.IsSet("uninstall"))
            {
                InvokeActionUnInstall();
                return;
            }

            // running as a console
            if (_commandlineParsers.IsSet("console"))
            {
                RunAsConsole();
                return;
            }

            // then we must be running as a service.
            RunAsService();
        }
        public void TestArgumentsCanBeNull()
        {
            // the arguments
            var parser = new CommandlineParser(null);

            // and we can get values.
            Assert.IsFalse(parser.IsSet("a"));
            Assert.IsFalse(parser.IsSet("b"));
        }
        public void TestArgumentsCanBeEmpty()
        {
            // the arguments
            var args   = new string[] { };
            var parser = new CommandlineParser(args);

            // and we can get values.
            Assert.IsFalse(parser.IsSet("a"));
            Assert.IsFalse(parser.IsSet("b"));
        }
        public void TestFlagsWithValuesAndNoValuesNonDefaultLeadingPattern()
        {
            // the arguments
            var args   = new[] { "-a", "-b", "world" };
            var parser = new CommandlineParser(args, null, "-");

            Assert.IsTrue(parser.IsSet("a"));
            Assert.IsTrue(parser.IsSet("b"));
            Assert.AreEqual("world", parser.Get("b", "nope"));
        }
        public void IsSetWhenAliasIsSetButParamIsNot()
        {
            var args   = new[] { "--a", "b", };
            var parser = new CommandlineParser(args, new CommandlineArgumentRules
            {
                new OptionalCommandlineArgumentRule("a"),
                new HelpCommandlineArgumentRule(new [] { "help", "h" })
            });

            // the param is not set for either values
            Assert.IsFalse(parser.IsSet("h"));
            Assert.IsFalse(parser.IsSet("help"));
        }
        public void IsSetWhenAliasIsSet()
        {
            var args   = new[] { "--a", "b", "--help" };
            var parser = new CommandlineParser(args, new CommandlineArgumentRules
            {
                new OptionalCommandlineArgumentRule("a"),
                new HelpCommandlineArgumentRule(new [] { "help", "h" })
            });

            // although the actual value in the argument is "help" we look for "h"
            Assert.IsTrue(parser.IsSet("h"));
            Assert.IsTrue(parser.IsSet("help"));
        }
        public void TestNullArgumentsButhHasRules()
        {
            // the arguments
            var parser = new CommandlineParser(null, new CommandlineArgumentRules
            {
                new OptionalCommandlineArgumentRule("a", "Hello"),
                new OptionalCommandlineArgumentRule("b", "World")
            });

            Assert.IsFalse(parser.IsSet("a"));
            Assert.IsFalse(parser.IsSet("b"));
            Assert.AreEqual("Hello", parser.Get("a"));
            Assert.AreEqual("World", parser.Get("b"));
        }
        public void TestEmptyArgumentsButhHasRules()
        {
            var args = new string[] { };
            // the arguments
            var parser = new CommandlineParser(args, new CommandlineArgumentRules
            {
                new OptionalCommandlineArgumentRule("a", "Hello"),
                new OptionalCommandlineArgumentRule("b", "World")
            });

            Assert.IsFalse(parser.IsSet("a"));
            Assert.IsFalse(parser.IsSet("b"));
            Assert.AreEqual("Hello", parser.Get("a"));
            Assert.AreEqual("World", parser.Get("b"));
        }
        public void TestNonRequiredValueWithDefaultArgumentsInRulesButValueDoesExist()
        {
            // the arguments
            var args   = new[] { "--a", "--b", "Hello" };
            var parser = new CommandlineParser(args, new CommandlineArgumentRules
            {
                new RequiredCommandlineArgumentRule("a"),
                new OptionalCommandlineArgumentRule("b", "World")
            });

            Assert.IsTrue(parser.IsSet("a"));
            Assert.IsTrue(parser.IsSet("b"));
            Assert.AreEqual("Hello", parser.Get("b"));
            Assert.AreEqual("Hello", parser.Get("b", "World"));
        }
        public void TestNonRequiredValueWithDefaultArgumentsInRules()
        {
            // the arguments
            var args   = new[] { "--a" };
            var parser = new CommandlineParser(args, new CommandlineArgumentRules
            {
                new RequiredCommandlineArgumentRule("a"),
                new OptionalCommandlineArgumentRule("b", "World")
            });

            Assert.IsTrue(parser.IsSet("a"));
            Assert.IsFalse(parser.IsSet("b"));
            Assert.AreEqual("World", parser.Get("b"));
            Assert.AreEqual("Hello", parser.Get("b", "Hello")); // if we are explicitely given another default, we will use it.
        }
        public void TestFlagsWithNoValueAloneNonDefaultLeadingPattern()
        {
            // the arguments
            var args   = new[] { "-a" };
            var parser = new CommandlineParser(args, null, "-");

            // "a" exist
            Assert.IsTrue(parser.IsSet("a"));
        }
        public void TestFlagsWithNoValueAlone()
        {
            // the arguments
            var args   = new[] { "--a" };
            var parser = new CommandlineParser(args);

            // "a" exist
            Assert.IsTrue(parser.IsSet("a"));

            // not "b"
            Assert.IsFalse(parser.IsSet("b"));

            // but a and b are empty
            Assert.AreEqual(null, parser.Get("a"));
            Assert.AreEqual(null, parser.Get("b"));

            // even with a default
            Assert.AreEqual(null, parser.Get("a", "nope"));
            Assert.AreEqual("nope", parser.Get("b", "nope"));
        }
        public void TestFlagsWithNoValues()
        {
            // the arguments
            var args   = new[] { "--a", "--b", "--c", "hello" };
            var parser = new CommandlineParser(args);

            //  "c" has a value
            Assert.AreEqual("hello", parser.Get("c"));

            // the exist
            Assert.IsTrue(parser.IsSet("a"));
            Assert.IsTrue(parser.IsSet("b"));

            // but a and b are empty
            Assert.AreEqual(null, parser.Get("a"));
            Assert.AreEqual(null, parser.Get("b"));

            // even with a default
            Assert.AreEqual(null, parser.Get("a", "nope"));
            Assert.AreEqual(null, parser.Get("b", "nope"));
        }
        public void IsSetWhenValueIsNotSetAndItIsNotARule()
        {
            var args   = new[] { "--a", "b", "--b", "--help" };
            var parser = new CommandlineParser(args, new CommandlineArgumentRules
            {
                new OptionalCommandlineArgumentRule("a"),
                new HelpCommandlineArgumentRule(new [] { "help", "h" })
            });

            // 'c' is not one of our rules, or set in the params
            Assert.IsFalse(parser.IsSet("c"));
        }
        public void IsSetWhenValueIsSetButItIsNotARule()
        {
            var args   = new[] { "--a", "b", "--b", "--help" };
            var parser = new CommandlineParser(args, new CommandlineArgumentRules
            {
                new OptionalCommandlineArgumentRule("a"),
                new HelpCommandlineArgumentRule(new [] { "help", "h" })
            });

            // 'b' is not one of our rules, but it is set.
            Assert.IsTrue(parser.IsSet("b"));
        }
Exemplo n.º 16
0
        static void Main(string[] args)
        {
            string argumentsHelp = Environment.NewLine +
                                   "EDR.Integrator Uso:" + Environment.NewLine + Environment.NewLine +
                                   "-help           Despliega esta pantalla de ayuda" + Environment.NewLine +
                                   "-site           Nombre del sitio EDR remoto a conectarse para extraer valores de las variables operativas" + Environment.NewLine +
                                   "-maxparallel    Máximo grado de paralelismo. Rango entre 1 y 20 (por defecto 10). Recomendado para este equipo: {0}" + Environment.NewLine +
                                   "-batchsize      Número de filas a procesar por lote (por defecto 2000)" + Environment.NewLine + Environment.NewLine +
                                   "Ejemplo EDR.Integrator.CommandLine -site srv_samaria3 [-maxparallel 12] [-batchsize 4000]";

            int    MAX_PARALLEL_DEGREE = 10;
            int    MAX_BATCH_SIZE      = 2000;
            string SITE_NAME           = string.Empty;

            string[] validArguments = { "site", "maxparalel", "batchsize", "help" };

            try
            {
                var arguments = new CommandlineParser(args, new CommandlineArgumentRules
                {
                    new HelpCommandlineArgumentRule(new [] { "help" }),
                    new OptionalCommandlineArgumentRule("batchsize", "2000"),
                    new OptionalCommandlineArgumentRule("maxparallel", "10"),
                    new OptionalCommandlineArgumentRule("site")
                }, "-"
                                                      );

                //cálculo del número óptimo de procesos en hilo con base a los CPU disponibles del equipo
                int maxCPU = Convert.ToInt32(Math.Ceiling((Environment.ProcessorCount * 0.75) * 2.0));
                //si el valor por defecto de 10 no es posible ejecutarlo en el equipo se establece con base a la capacidad
                if (MAX_PARALLEL_DEGREE > maxCPU)
                {
                    MAX_PARALLEL_DEGREE = maxCPU;
                }

                argumentsHelp = string.Format(argumentsHelp, maxCPU);

                if (arguments.IsHelp())
                {
                    Console.WriteLine(argumentsHelp);
                    return;
                }

                if (!arguments.IsSet("site"))
                {
                    Console.WriteLine(argumentsHelp);
                    return;
                }
                else
                {
                    string site = arguments.Get <string>("site");
                    if (string.IsNullOrEmpty(site))
                    {
                        Console.WriteLine(argumentsHelp);
                        Console.WriteLine("Valor de -site: " + site);
                        return;
                    }
                    else
                    {
                        SITE_NAME = site;
                    }
                }

                if (arguments.IsSet("maxparallel"))
                {
                    int maxparallel = arguments.Get <int>("maxparallel");
                    if (maxparallel > MAX_PARALLEL_DEGREE)
                    {
                        Console.WriteLine("El valor maxparallel es mayor al que el equipo puede ejecutar, se establece por defecto a " + MAX_PARALLEL_DEGREE.ToString());
                    }
                    if (maxparallel < 1 || maxparallel > 20)
                    {
                        Console.WriteLine("El valor maxparallel no está en el rango de 1 a 20 - Recomendado para este equipo: " + MAX_PARALLEL_DEGREE.ToString());
                        return;
                    }
                }

                if (arguments.IsSet("batchsize"))
                {
                    int maxBatchSize = arguments.Get <int>("batchsize");
                    if (maxBatchSize < 100 || maxBatchSize > 10000)
                    {
                        Console.WriteLine("El valor batchsize está fuera de una rango permitido ( >= 100 y <= 10,000)");
                        return;
                    }
                    else
                    {
                        MAX_BATCH_SIZE = maxBatchSize;
                    }
                }

                DateTime initTime   = DateTime.Now;
                DateTime finishTime = DateTime.Now;

                Console.WriteLine("*******ETL Site process INIT - " + SITE_NAME);

                ETLProcess.MaxBatchSize = MAX_BATCH_SIZE;
                ETLProcess.GetConfiguration(SITE_NAME);
                ETLProcess.GetVariablesOnSite();

                Parallel.ForEach(ETLProcess.serverOnSiteVariables,
                                 new ParallelOptions {
                    MaxDegreeOfParallelism = MAX_PARALLEL_DEGREE
                },
                                 v =>
                {
                    DateTime?dt = ETLProcess.GetLastSync(v);
                    if (dt != null)
                    {
                        v.LastSync = dt;
                    }
                    ETLProcess.ExtractAndLoad(v);
                });

                finishTime = DateTime.Now;
                long     elapsedTime = finishTime.Ticks - initTime.Ticks;
                TimeSpan elapsedSpan = new TimeSpan(elapsedTime);

                Console.WriteLine("*******ETL Site process FINISH: Start: " + initTime.ToString() + " | Finish:" + finishTime.ToString() + " | Elapsed time: " + elapsedSpan.TotalSeconds.ToString());
                Console.ReadKey();
            }
            catch (Exception ex)
            {
                Console.WriteLine(ex);
            }

            //1. Buscar la configuración de conexión del sitename y servername establecido en el parámetro
            //2. Leer las variables operativas activas
            //3. Leer la última sincronización (si no existe (NULL) es primera integración
            //4. Por cada variable operativa: Consultar los registros de la variable operativa
            //5. Integrar el dataset en la BD EDRDS guardando (de cada variable):
            //      - Número de registros obtenidos
            //      - TimeStamp del último registro leído en la tabla de control
            //      - Fecha de inicio y término del proceso
        }