public void SingleQueueControllerTest() { var manager = new QueueMessageManagerSql(); // sample - create 3 message for (int i = 0; i < 3; i++) { var item = new QueueMessageItem() { QueueName = "Queue1", Message = "Print Image", Action = "PRINTIMAGE", TextInput = "4334333" // image Id }; // sets appropriate settings for submit on item manager.SubmitRequest(item); // item has to be saved Assert.IsTrue(manager.Save(), manager.ErrorMessage); Console.WriteLine("added " + manager.Item.Id); } Console.WriteLine("Starting... Async Manager Processing"); // create a new Controller to process in the background // on separate threads var controller = new QueueController() { ConnectionString = "QueueMessageManager", ThreadCount = 2, WaitInterval = 200, QueueName = "Queue1" }; Console.WriteLine("Wait: " + controller.WaitInterval); // ExecuteStart Event is where your processing logic goes controller.ExecuteStart += controller_ExecuteStart; // ExecuteFailed and ExecuteComplete let you take actions on completion controller.ExecuteComplete += controller_ExecuteComplete; controller.ExecuteFailed += controller_ExecuteFailed; // actually start the queue controller.StartProcessingAsync(); // For test we have to keep the threads alive // to allow the 3 requests to process Thread.Sleep(2000); // shut down controller.StopProcessing(); Thread.Sleep(200); Console.WriteLine("Stopping... Async Manager Processing"); Assert.IsTrue(true); }
public void CompleteMessageTest() { this.SubmitRequestWithPropertiesTest(); var manager = new QueueMessageManagerSql(); var item = new QueueMessageItem() { TextInput = "My input", Message = "Getting started." }; manager.CreateItem(item); manager.Properties["Time"] = DateTime.Now; Assert.IsTrue(manager.Save(), manager.ErrorMessage); string reqId = item.Id; manager = new QueueMessageManagerSql(); item = manager.GetNextQueueMessage(); DateTime?time = manager.GetProperty("Time") as DateTime?; Assert.IsNotNull(time); manager.CompleteRequest(item, "Message completed @" + DateTime.Now.ToString("t")); Assert.IsTrue(manager.Save(), manager.ErrorMessage); }
public void SubmitRequestsToQueueTest() { var manager = new QueueMessageManagerSql(); int queueCount = 30; bool res = true; for (int i = 0; i < queueCount; i++) { var msg = new QueueMessageItem() { QueueName = "MPWF", Message = "Xml Message #" + i + " @ " + DateTime.Now.ToString("t"), Action = "NEWXMLORDER" }; if (!manager.SubmitRequest(msg)) { Console.WriteLine(manager.ErrorMessage); } res = manager.Save(msg); if (!res) { break; } } }
public void LoadRequestTest() { var manager = new QueueMessageManagerSql(); var db = manager.Db; var item = db.Find <QueueMessageItem>("select TOP 1 * from queueMessageItems where IsComplete = 0"); // no pending items - nothing to do if (item == null) { Console.WriteLine("No pending items... nothing to do."); return; } string reqId = item.Id; // clear out item item = null; // load through manager item = manager.Load(reqId); Assert.IsNotNull(item, manager.ErrorMessage); item.Message = "Updated @ " + DateTime.Now.ToString("t"); item.PercentComplete = 10; Assert.IsTrue(manager.Save(), manager.ErrorMessage); }
public void SubmitRequestTest() { var manager = new QueueMessageManagerSql(); string imageId = "10"; // Create a message object // item contains many properties for pushing // values back and forth as well as a few message fields var item = manager.CreateItem(); item.Action = "PRINTIMAGE"; item.TextInput = imageId; item.Message = "Print Image operation started at " + DateTime.Now.ToString(); item.PercentComplete = 10; // *** you can also serialize objects directly into the Xml property // manager.Serialization.SerializeToXml(SomeObjectToSerialize); // add an arbitrary custom properties - serialized to Xml manager.Properties.Add("Time", DateTime.Now); manager.Properties.Add("User", "ricks"); // Set the message status and timestamps as submitted manager.SubmitRequest(item); // actually save the queue message to disk Assert.IsTrue(manager.Save(), manager.ErrorMessage); }
public void SubmitRequestWithPropertiesTest() { var manager = new QueueMessageManagerSql(); manager.SubmitRequest(messageText: "New Entry with Properties"); // add a custom property manager.Properties.Add("Time", DateTime.Now); Assert.IsTrue(manager.Save(), manager.ErrorMessage); }
public void SubmitRequestWithPresetObjectTest() { string xml = "<doc><value>Hello</value></doc>"; var manager = new QueueMessageManagerSql(); var msg = new QueueMessageItem() { QueueName="MPWF", Message = "Xml Message @ " + DateTime.Now.ToString("t"), Action = "NEWXMLORDER", Xml = xml }; manager.SubmitRequest(msg); Assert.IsTrue(manager.Save(), manager.ErrorMessage); }
public void SubmitRequestWithPresetObjectTest() { string xml = "<doc><value>Hello</value></doc>"; var manager = new QueueMessageManagerSql(); var msg = new QueueMessageItem() { QueueName = "MPWF", Message = "Xml Message @ " + DateTime.Now.ToString("t"), Action = "NEWXMLORDER", Xml = xml }; manager.SubmitRequest(msg); Assert.IsTrue(manager.Save(), manager.ErrorMessage); }
public void LoadRequestWithPropertiesTest() { var manager = new QueueMessageManagerSql(); var db = manager.Db; var item = db.Find <QueueMessageItem>("select TOP 1 * from queueMessageItems where IsComplete = 0 and XmlProperties is not null"); // no pending items - nothing to do if (item == null) { Console.WriteLine("No pending items... nothing to do."); return; } string reqId = item.Id; // clear out item item = null; // load through manager item = manager.Load(reqId); Assert.IsNotNull(item, manager.ErrorMessage); item.Message = "Updated @ " + DateTime.Now.ToString("t"); item.PercentComplete = 10; // Update Properties object t = manager.GetProperty("Time"); DateTime?time3 = t as DateTime?; Assert.IsNotNull(t, "Time Property is null and shouldn't be."); Assert.IsTrue(manager.Save(), manager.ErrorMessage); Console.WriteLine(item.XmlProperties); }
public void GetNextQueueMessageItemWithAddedItemTest() { using (var manager = new QueueMessageManagerSql()) { // delete all pending requests int res = manager.Db.ExecuteNonQuery("delete from queuemessageItems where IsNull(started,'') = '' or started < '01/01/2000'"); Console.WriteLine(res); manager.SubmitRequest(messageText: "Next Complete Test " + DateTime.Now.ToString("t")); Assert.IsTrue(manager.Save(), manager.ErrorMessage); } using (var manager = new QueueMessageManagerSql()) { var item = manager.GetNextQueueMessage(); Assert.IsNotNull(item, manager.ErrorMessage); Console.WriteLine(item.Message); manager.CompleteRequest(item, "Next Complete complete " + DateTime.Now.ToString("t")); Assert.IsTrue(manager.Save(), manager.ErrorMessage); } }
public void SubmitRequestsToQueueTest() { var manager = new QueueMessageManagerSql(); int queueCount = 30; bool res = true; for (int i = 0; i < queueCount; i++) { var msg = new QueueMessageItem() { QueueName = "MPWF", Message = "Xml Message #" + i + " @ " + DateTime.Now.ToString("t"), Action = "NEWXMLORDER" }; if (!manager.SubmitRequest(msg)) Console.WriteLine(manager.ErrorMessage); res = manager.Save(msg); if (!res) break; } }
public void CompleteMessageTest() { this.SubmitRequestWithPropertiesTest(); var manager = new QueueMessageManagerSql(); var item = new QueueMessageItem() { TextInput = "My input", Message = "Getting started." }; manager.CreateItem(item); manager.Properties["Time"] = DateTime.Now; Assert.IsTrue(manager.Save(),manager.ErrorMessage); string reqId = item.Id; manager = new QueueMessageManagerSql(); item = manager.GetNextQueueMessage(); DateTime? time = manager.GetProperty("Time") as DateTime?; Assert.IsNotNull(time); manager.CompleteRequest(item,"Message completed @" + DateTime.Now.ToString("t")); Assert.IsTrue(manager.Save(), manager.ErrorMessage); }
public void LoadRequestWithPropertiesTest() { var manager = new QueueMessageManagerSql(); var db = manager.Db; var item = db.Find<QueueMessageItem>("select TOP 1 * from queueMessageItems where IsComplete = 0 and XmlProperties is not null"); // no pending items - nothing to do if (item == null) { Console.WriteLine("No pending items... nothing to do."); return; } string reqId = item.Id; // clear out item item = null; // load through manager item = manager.Load(reqId); Assert.IsNotNull(item, manager.ErrorMessage); item.Message = "Updated @ " + DateTime.Now.ToString("t"); item.PercentComplete = 10; // Update Properties object t = manager.GetProperty("Time"); DateTime? time3 = t as DateTime?; Assert.IsNotNull(t, "Time Property is null and shouldn't be."); Assert.IsTrue(manager.Save(), manager.ErrorMessage); Console.WriteLine(item.XmlProperties); }
public void LoadRequestTest() { var manager = new QueueMessageManagerSql(); var db = manager.Db; var item = db.Find<QueueMessageItem>("select TOP 1 * from queueMessageItems where IsComplete = 0"); // no pending items - nothing to do if (item == null) { Console.WriteLine("No pending items... nothing to do."); return; } string reqId = item.Id; // clear out item item = null; // load through manager item = manager.Load(reqId); Assert.IsNotNull(item, manager.ErrorMessage); item.Message = "Updated @ " + DateTime.Now.ToString("t"); item.PercentComplete = 10; Assert.IsTrue(manager.Save(), manager.ErrorMessage); }
public void QueueControllerMultipleTest() { var manager = new QueueMessageManagerSql(); // sample - create 3 message in 'default' queue for (int i = 0; i < 3; i++) { var item = new QueueMessageItem() { Message = "Print Image", Action = "PRINTIMAGE", TextInput = "4334333", // image Id QueueName = "Queue1" }; // sets appropriate settings for submit on item manager.SubmitRequest(item); // item has to be saved Assert.IsTrue(manager.Save(), manager.ErrorMessage); Console.WriteLine("added to Queue1:" + manager.Item.Id); } // sample - create 3 message in 'default' queue for (int i = 0; i < 3; i++) { var item = new QueueMessageItem() { Message = "Print Image (2nd)", Action = "PRINTIMAGE", TextInput = "5334333", // image Id QueueName = "Queue2" }; // sets appropriate settings for submit on item manager.SubmitRequest(item); // item has to be saved Assert.IsTrue(manager.Save(), manager.ErrorMessage); Console.WriteLine("added to Queue2: " + manager.Item.Id); } // create a new Controller to process in the background // on separate threads var controller = new QueueControllerMultiple(new List <QueueController>() { new QueueControllerMultiple() { QueueName = "Queue1", WaitInterval = 300, ThreadCount = 5 }, new QueueControllerMultiple() { QueueName = "Queue2", WaitInterval = 500, ThreadCount = 3 } }); // Point all controllers at the same execution handlers // Alternately you can configure each controller with their // own event handlers or implement custom controller subclasses // that use the OnXXX handlers to handle the events controller.ExecuteStart += controller_ExecuteStart; controller.ExecuteComplete += controller_ExecuteComplete; controller.ExecuteFailed += controller_ExecuteFailed; // actually start the queue Console.WriteLine("Starting... Async Manager Processing"); controller.StartProcessingAsync(); // For test we have to keep the threads alive // to allow the 10 requests to process Thread.Sleep(2000); // shut down controller.StopProcessing(); Thread.Sleep(200); Console.WriteLine("Stopping... Async Manager Processing"); Assert.IsTrue(true); Console.WriteLine("Processed: " + controller.MessagesProcessed); }
public void QueueControllerMultipleTest() { var manager = new QueueMessageManagerSql(); // sample - create 3 message in 'default' queue for (int i = 0; i < 3; i++) { var item = new QueueMessageItem() { Message = "Print Image", Action = "PRINTIMAGE", TextInput = "4334333", // image Id QueueName = "Queue1" }; // sets appropriate settings for submit on item manager.SubmitRequest(item); // item has to be saved Assert.IsTrue(manager.Save(), manager.ErrorMessage); Console.WriteLine("added to Queue1:" + manager.Item.Id); } // sample - create 3 message in 'default' queue for (int i = 0; i < 3; i++) { var item = new QueueMessageItem() { Message = "Print Image (2nd)", Action = "PRINTIMAGE", TextInput = "5334333", // image Id QueueName = "Queue2" }; // sets appropriate settings for submit on item manager.SubmitRequest(item); // item has to be saved Assert.IsTrue(manager.Save(), manager.ErrorMessage); Console.WriteLine("added to Queue2: " + manager.Item.Id); } // create a new Controller to process in the background // on separate threads var controller = new QueueControllerMultiple(new List<QueueController>() { new QueueControllerMultiple() { QueueName = "Queue1", WaitInterval = 300, ThreadCount = 5 }, new QueueControllerMultiple() { QueueName = "Queue2", WaitInterval = 500, ThreadCount = 3 } }); // Point all controllers at the same execution handlers // Alternately you can configure each controller with their // own event handlers or implement custom controller subclasses // that use the OnXXX handlers to handle the events controller.ExecuteStart += controller_ExecuteStart; controller.ExecuteComplete += controller_ExecuteComplete; controller.ExecuteFailed += controller_ExecuteFailed; // actually start the queue Console.WriteLine("Starting... Async Manager Processing"); controller.StartProcessingAsync(); // For test we have to keep the threads alive // to allow the 10 requests to process Thread.Sleep(2000); // shut down controller.StopProcessing(); Thread.Sleep(200); Console.WriteLine("Stopping... Async Manager Processing"); Assert.IsTrue(true); Console.WriteLine("Processed: " + controller.MessagesProcessed); }