Exemple #1
0
        public void ShouldFormatWithException()
        {
            DateTime              dateTime;
            UnicastLogger         logger;
            MockedUnicastReceiver receiver;

            receiver = new MockedUnicastReceiver(3023);

            logger = new UnicastLogger(IPAddress.Parse("127.0.0.1"), 3023);

            dateTime = DateTime.Now;
            logger.Log(1, "Component", "Method", new Exception("Message1"));
            receiver.ReceivedEvent.WaitOne();
            Assert.AreEqual(1, receiver.Logs.Count);
            Assert.AreEqual("Message1", receiver.Logs[0].Message);

            dateTime = DateTime.Now;
            logger.Log(1, "Component", "Method", new Exception("Message2"));
            receiver.ReceivedEvent.WaitOne();
            Assert.AreEqual(2, receiver.Logs.Count);
            Assert.AreEqual("Message2", receiver.Logs[1].Message);


            logger.Dispose();
            receiver.Dispose();
        }
Exemple #2
0
        public void ShouldFormatWithNullInput()
        {
            DateTime              dateTime;
            UnicastLogger         logger;
            MockedUnicastReceiver receiver;

            receiver = new MockedUnicastReceiver(3022);

            logger = new UnicastLogger(IPAddress.Parse("127.0.0.1"), 3022);

            dateTime = DateTime.Now;
            logger.Log(1, null, null, LogLevels.Debug, null);
            receiver.ReceivedEvent.WaitOne();
            Assert.AreEqual(1, receiver.Logs.Count);
            Assert.AreEqual(null, receiver.Logs[0].Message);

            dateTime = DateTime.Now;
            logger.Log(1, null, null, LogLevels.Debug, null);
            receiver.ReceivedEvent.WaitOne();
            Assert.AreEqual(2, receiver.Logs.Count);
            Assert.AreEqual(null, receiver.Logs[1].Message);

            logger.Dispose();
            receiver.Dispose();
        }
Exemple #3
0
        public void ShouldFormatWithValidInput()
        {
            DateTime              dateTime;
            UnicastLogger         logger;
            MockedUnicastReceiver receiver;

            receiver = new MockedUnicastReceiver(3021);

            logger = new UnicastLogger(IPAddress.Parse("127.0.0.1"), 3021);

            dateTime = DateTime.Now;
            logger.Log(1, "Component", "Method", LogLevels.Debug, "Message0");
            receiver.ReceivedEvent.WaitOne();
            Assert.AreEqual(1, receiver.Logs.Count);
            Assert.AreEqual("Message0", receiver.Logs[0].Message);

            dateTime = DateTime.Now;
            logger.Log(1, "Component", "Method", LogLevels.Debug, "Message1");
            receiver.ReceivedEvent.WaitOne();
            Assert.AreEqual(2, receiver.Logs.Count);
            Assert.AreEqual("Message1", receiver.Logs[1].Message);

            dateTime = DateTime.Now;
            logger.Log(new Log(dateTime, 1, "Component", "Method", LogLevels.Debug, "Message2"));
            receiver.ReceivedEvent.WaitOne();
            Assert.AreEqual(3, receiver.Logs.Count);
            Assert.AreEqual("Message2", receiver.Logs[2].Message);

            logger.Dispose();
            receiver.Dispose();
        }
Exemple #4
0
        static void Main(string[] args)
        {
            List <GeneratorModule> modules;
            GeneratorModule        module;
            ILogger logger;

            modules = new List <GeneratorModule>();
            for (int clientId = 0; clientId < Properties.Settings.Default.ClientCount; clientId++)
            {
                //logger=new MulticastLogger(IPAddress.Parse(Properties.Settings.Default.MulticastIPaddress), Properties.Settings.Default.MulticastPort);
                logger = new UnicastLogger(IPAddress.Parse("127.0.0.1"), Properties.Settings.Default.UnicastPort);
                for (int componentID = 0; componentID < Properties.Settings.Default.ComponentCount; componentID++)
                {
                    for (int methodID = 0; methodID < Properties.Settings.Default.MethodCount; methodID++)
                    {
                        module = new GeneratorModule(logger, Properties.Settings.Default.TriggerDelay, clientId, componentID, methodID);
                        module.Start();
                        modules.Add(module);
                    }
                }
            }



            Console.ReadLine();

            foreach (GeneratorModule m in modules)
            {
                m.Stop();
            }
        }
Exemple #5
0
        public void ShouldFormatWithValidInputWhenNoReceiverIsRunning()
        {
            DateTime      dateTime;
            UnicastLogger logger;

            logger = new UnicastLogger(IPAddress.Parse("127.0.0.1"), 3020);

            dateTime = DateTime.Now;
            logger.Log(1, "Component", "Method", LogLevels.Debug, "Message");

            logger.Dispose();
        }
Exemple #6
0
        static void Main(string[] args)
        {
            ILogger logger;
            VersionControlModule versionControlModule;
            //ServiceHostModule serviceHostModule;
            //IBotsService service;
            RESTServer    server;
            IRouteManager routeManager;

            IDatabase          database;
            IConnectionFactory connectionFactory;
            ICommandBuilder    commandBuilder;
            IDatabaseCreator   databaseCreator;

            IBotModule          botModule;
            IOrderModule        orderModule;
            IOrderManagerModule orderManagerModule;
            IProduceOrderModule produceOrderModule;
            IHarvestOrderModule harvestOrderModule;
            IBuildOrderModule   buildOrderModule;

            IBotSchedulerModule botSchedulerModule;

            PIOServiceClient client;


            quitEvent = new AutoResetEvent(false);
            Console.CancelKeyPress += new ConsoleCancelEventHandler(Console_CancelKeyPress);

            //logger = new ConsoleLogger(new DefaultLogFormatter());
            logger = new UnicastLogger(IPAddress.Loopback, Properties.Settings.Default.UnicastPort);
            //logger = new FileLogger(new DefaultLogFormatter(), "PIO.Bots.ServerHost.Log");

            databaseCreator   = new SqlDatabaseCreator(Properties.Settings.Default.Server, Properties.Settings.Default.DatabaseName);
            connectionFactory = new SqlConnectionFactory(Properties.Settings.Default.Server, Properties.Settings.Default.DatabaseName);
            commandBuilder    = new SqlCommandBuilder();
            database          = new Database(connectionFactory, commandBuilder);

            versionControlModule = new VersionControlModule(logger, databaseCreator, new BotsVersionControl(database));
            if (!versionControlModule.InitializeDatabase(Properties.Settings.Default.DropDatabase))
            {
                Console.ReadLine();
                return;
            }

            client = new PIOServiceClient(new BasicHttpBinding(), new EndpointAddress($@"http://127.0.0.1:8733/PIO/Service/"));
            client.Open();


            botModule          = new BotModule(logger, database);
            orderModule        = new OrderModule(logger, database);
            produceOrderModule = new ProduceOrderModule(logger, database);
            harvestOrderModule = new HarvestOrderModule(logger, database);
            buildOrderModule   = new BuildOrderModule(logger, database);

            orderManagerModule = new OrderManagerModule(logger, client, orderModule, produceOrderModule, harvestOrderModule, buildOrderModule, 10);

            botSchedulerModule = new BotSchedulerModule(logger, client, botModule, orderManagerModule, 5);
            botSchedulerModule.Start();

            routeManager = new RouteManager(new RouteParser(), new ResponseSerializer());
            routeManager.AddRouteHandler(new BotRouteHandler(botModule));
            routeManager.AddRouteHandler(new ProduceOrderRouteHandler(produceOrderModule));
            routeManager.AddRouteHandler(new HarvestOrderRouteHandler(harvestOrderModule));
            routeManager.AddRouteHandler(new BuildOrderRouteHandler(buildOrderModule));

            server = new RESTServer(logger, routeManager, "http://127.0.0.1:8734/");

            server.Start();

            WaitHandle.WaitAny(new WaitHandle[] { quitEvent }, -1);

            server.Stop();
            //serviceHostModule.Stop();
            botSchedulerModule.Stop();

            client.Close();
            logger.Dispose();

            Console.CancelKeyPress -= new ConsoleCancelEventHandler(Console_CancelKeyPress);
        }
Exemple #7
0
        static void Main(string[] args)
        {
            ILogger logger;
            VersionControlModule versionControlModule;
            ServiceHostModule    pioServiceHostModule;
            ServiceHostModule    taskCallbackServiceHostModule;
            SchedulerModule      schedulerModule;

            IPIOService          pioService;
            ITaskCallbackService taskCallbackService;
            IDatabase            database;
            IConnectionFactory   connectionFactory;
            ICommandBuilder      commandBuilder;
            IDatabaseCreator     databaseCreator;

            IPlanetGeneratorModule planetGeneratorModule;

            IPhraseModule       phraseModule;
            IPlanetModule       planetModule;
            ICellModule         cellModule;
            IBuildingModule     buildingModule;
            IWorkerModule       workerModule;
            IBuilderModule      factoryBuilderModule;
            IStackModule        stackModule;
            IResourceTypeModule resourceTypeModule;
            IBuildingTypeModule buildingTypeModule;
            ITaskTypeModule     taskTypeModule;
            IMaterialModule     materialModule;
            IIngredientModule   ingredientModule;
            IProductModule      productModule;
            ITaskModule         taskModule;

            IIdlerModule           idlerModule;
            IResourceCheckerModule resourceCheckerModule;
            ILocationCheckerModule locationCheckerModule;
            IProducerModule        producerModule;
            IHarvesterModule       harvesterModule;
            IMoverModule           moverModule;
            ITakerModule           takerModule;
            IStorerModule          storerModule;

            quitEvent = new AutoResetEvent(false);
            Console.CancelKeyPress += new ConsoleCancelEventHandler(Console_CancelKeyPress);

            //logger = new ConsoleLogger(new DefaultLogFormatter());
            logger = new UnicastLogger(IPAddress.Loopback, Properties.Settings.Default.UnicastPort);
            //logger = new FileLogger(new DefaultLogFormatter(), "PIO.ServerHost.Log");

            databaseCreator   = new SqlDatabaseCreator(Properties.Settings.Default.Server, Properties.Settings.Default.DatabaseName);
            connectionFactory = new SqlConnectionFactory(Properties.Settings.Default.Server, Properties.Settings.Default.DatabaseName);
            commandBuilder    = new SqlCommandBuilder();
            database          = new Database(connectionFactory, commandBuilder);

            versionControlModule = new VersionControlModule(logger, databaseCreator, new PIOVersionControl(database));
            if (!versionControlModule.InitializeDatabase(Properties.Settings.Default.DropDatabase))
            {
                return;
            }


            phraseModule       = new PhraseModule(logger, database);
            planetModule       = new PlanetModule(logger, database);
            cellModule         = new CellModule(logger, database);
            buildingModule     = new BuildingModule(logger, database);
            workerModule       = new WorkerModule(logger, database);
            stackModule        = new StackModule(logger, database);
            resourceTypeModule = new ResourceTypeModule(logger, database);
            buildingTypeModule = new BuildingTypeModule(logger, database);
            taskTypeModule     = new TaskTypeModule(logger, database);
            materialModule     = new MaterialModule(logger, database);
            ingredientModule   = new IngredientModule(logger, database);
            productModule      = new ProductModule(logger, database);
            taskModule         = new TaskModule(logger, database);


            factoryBuilderModule  = new BuilderModule(logger, taskModule, workerModule, buildingModule, buildingTypeModule, stackModule, materialModule);;
            idlerModule           = new IdlerModule(logger, taskModule, workerModule);
            resourceCheckerModule = new ResourceCheckerModule(logger, buildingModule, stackModule, ingredientModule, materialModule);
            locationCheckerModule = new LocationCheckerModule(logger, workerModule, buildingModule);
            producerModule        = new ProducerModule(logger, taskModule, workerModule, buildingModule, buildingTypeModule, stackModule, ingredientModule, productModule);
            harvesterModule       = new HarvesterModule(logger, taskModule, workerModule, buildingModule, buildingTypeModule, stackModule, productModule);
            moverModule           = new MoverModule(logger, taskModule, workerModule, buildingModule);
            takerModule           = new TakerModule(logger, taskModule, workerModule, buildingModule, stackModule);
            storerModule          = new StorerModule(logger, taskModule, workerModule, buildingModule, stackModule);

            planetGeneratorModule = new PlanetGeneratorModule(logger, phraseModule, resourceTypeModule, buildingTypeModule, taskTypeModule, materialModule, ingredientModule, productModule, planetModule, cellModule, buildingModule, workerModule);
            if (!planetGeneratorModule.Generate())
            {
                return;
            }

            schedulerModule = new SchedulerModule(logger, taskModule, idlerModule, producerModule, harvesterModule, moverModule, takerModule, storerModule, factoryBuilderModule);
            schedulerModule.Start();


            pioService = new PIOService(
                logger, phraseModule, planetModule, cellModule, buildingModule, workerModule,
                stackModule, resourceTypeModule,
                buildingTypeModule, taskTypeModule, materialModule, ingredientModule, productModule, taskModule,
                schedulerModule,
                resourceCheckerModule, locationCheckerModule, idlerModule, producerModule, harvesterModule, moverModule, takerModule, storerModule,
                factoryBuilderModule);

            pioServiceHostModule = new ServiceHostModule(logger, pioService);
            pioServiceHostModule.Start();

            taskCallbackService           = new TaskCallbackService(logger, schedulerModule);
            taskCallbackServiceHostModule = new ServiceHostModule(logger, taskCallbackService);
            taskCallbackServiceHostModule.Start();

            WaitHandle.WaitAny(new WaitHandle[] { quitEvent }, -1);

            taskCallbackServiceHostModule.Stop();
            pioServiceHostModule.Stop();
            schedulerModule.Stop();

            Console.CancelKeyPress -= new ConsoleCancelEventHandler(Console_CancelKeyPress);
        }