From 5d90cc9cc63fa44d76cfde2dde096a28d1f96f21 Mon Sep 17 00:00:00 2001 From: John Cardinal Date: Thu, 26 Feb 2026 12:52:58 -0800 Subject: [PATCH] 4648 --- WorkOrder/WorkOrderCrud.cs | 377 +++++++++++++++++++------------------ util.cs | 5 + 2 files changed, 201 insertions(+), 181 deletions(-) diff --git a/WorkOrder/WorkOrderCrud.cs b/WorkOrder/WorkOrderCrud.cs index e3f3ba9..f3fb206 100644 --- a/WorkOrder/WorkOrderCrud.cs +++ b/WorkOrder/WorkOrderCrud.cs @@ -9,10 +9,6 @@ namespace raven_integration public class WorkOrderCrud { - - - - /// /// Test all CRUD routes for a WorkOrder /// Build up graph, update graph, remove graph bit by bit @@ -20,50 +16,75 @@ namespace raven_integration [Fact] public async Task CRUD() { - ///////////////////////////////////////////////////////////////////////// - // CREATE - // - dynamic d = new JObject(); - d.active = true; - d.notes = "WOHEADER The quick brown fox jumped over the six lazy dogs!"; - d.wiki = "no wiki"; - //Tags - dynamic dTagsArray = new JArray(); - dTagsArray.Add("wo-Red"); - dTagsArray.Add("wo-green"); - dTagsArray.Add("wo-blue"); - d.tags = dTagsArray; - ApiResponse a = await Util.PostAsync("workorder", await Util.GetTokenAsync("superuser", "l3tm3in"), d.ToString()); + + //CREATE WO HEADER + + //Tags + var TagNameStart = Util.Uniquify("crud-tag-test");//ensure this run gets it's own unique tags + var tagsJson = Util.TagJsonFromStrings(TagNameStart, "wo-red", "wo-green", "wo-blue"); + + var isoNow = DateTime.Now.ToString("o"); + var isoOneHourFromNow = DateTime.Now.AddHours(1).ToString("o"); + var payload = $$""" + {"id":0,"concurrency":0,"serial":0,"notes":"WOHEADER The quick brown fox jumped over the six lazy dogs!","wiki":null,"customFields":"{}","tags":[{{tagsJson}}],"customerId":1,"projectId":null,"contractId":null,"internalReferenceNumber":null,"customerReferenceNumber":null,"customerContactName":null,"fromQuoteId":null,"fromPMId":null,"serviceDate":"{{isoNow}}","completeByDate":null,"durationToCompleted":"00:00:00","invoiceNumber":null,"onsite":true,"customerSignature":null,"customerSignatureName":null,"customerSignatureCaptured":null,"techSignature":null,"techSignatureName":null,"techSignatureCaptured":null,"postAddress":null,"postCity":null,"postRegion":null,"postCountry":null,"postCode":null,"address":null,"city":null,"region":null,"country":null,"addressPostal":null,"latitude":null,"longitude":null,"isDirty":true,"isLockedAtServer":false} + """; + + ApiResponse a = await Util.PostAsync("workorder", await Util.GetTokenAsync("BizAdmin"), payload); Util.ValidateDataReturnResponseOk(a); dynamic WorkorderToUpdate = a.ObjectResponse["data"]; long WorkOrderId = a.ObjectResponse["data"]["id"].Value(); ((long)a.ObjectResponse["data"]["serial"]).Should().NotBe(0); - #region CREATE first woitem - - //CREATE WOITEM 1 - d = new JObject(); - d.active = true; - d.notes = "woitem The quick brown fox jumped over the six lazy dogs!"; - d.wiki = "# woitem test wiki"; - d.workOrderId = WorkOrderId; - - //Tags - dTagsArray = new JArray(); - dTagsArray.Add("woitem-Red"); - dTagsArray.Add("woitem-green"); - dTagsArray.Add("woitem-blue"); - d.tags = dTagsArray; - - a = await Util.PostAsync("workorder/items", await Util.GetTokenAsync("superuser", "l3tm3in"), d.ToString()); - Util.ValidateDataReturnResponseOk(a); - dynamic WorkOrderItemToUpdate = a.ObjectResponse["data"]; - + //CREATE WO ITEM 1 + payload = $$""" + {"id":0,"concurrency":0,"notes":"test item summary","wiki":null,"customFields":"{}","tags":[],"workOrderId":{{WorkOrderId}},"fromCSRId":null,"techNotes":null,"workOrderItemStatusId":null,"workOrderItemPriorityId":null,"requestDate":null,"warrantyService":false,"sequence":1,"isDirty":true,"uid":1772137159653} + """; + a = await Util.PostAsync("workorder/items", await Util.GetTokenAsync("BizAdmin"), payload); + Util.ValidateDataReturnResponseOk(a); long WorkOrderItem1Id = a.ObjectResponse["data"]["id"].Value(); + //CREATE WO ITEM 1 PART + payload = $$""" + {"id":0,"concurrency":0,"userId":null,"description":null,"serials":null,"partId":9,"partWarehouseId":1,"quantity":0,"suggestedQuantity":1,"taxPartSaleId":2,"price":0,"priceOverride":null,"cost":0,"listPrice":0,"workOrderItemId":{{WorkOrderItem1Id}}} + """; + a = await Util.PostAsync("workorder/parts", await Util.GetTokenAsync("BizAdmin"), payload); + Util.ValidateDataReturnResponseOk(a); + long WorkOrderItem1Id = a.ObjectResponse["data"]["id"].Value(); + /* + UNIT: + {"id":0,"concurrency":0,"wiki":null,"customFields":"{}","tags":[],"notes":"test unit notes","unitId":10,"workOrderItemId":747} + + Scheduled users: + {"id":0,"concurrency":0,"userId":null,"estimatedQuantity":1.5,"startDate":"2026-02-26T20:00:00.000Z","stopDate":"2026-02-26T21:30:00.000Z","serviceRateId":null,"workOrderItemId":747} + + tasks: + {"id":0,"concurrency":0,"sequence":1,"task":"test task","status":1,"completedByUserId":null,"completedDate":null,"workOrderItemId":747} + + parts: + {"id":0,"concurrency":0,"userId":null,"description":null,"serials":null,"partId":9,"partWarehouseId":1,"quantity":0,"suggestedQuantity":1,"taxPartSaleId":2,"price":0,"priceOverride":null,"cost":0,"listPrice":0,"workOrderItemId":747} + + labors: + {"id":0,"concurrency":0,"userId":null,"serviceStartDate":"2026-02-26T21:00:00.000Z","serviceStopDate":"2026-02-26T22:00:00.000Z","serviceRateId":null,"serviceDetails":"Test labour service details","serviceRateQuantity":1,"noChargeQuantity":0,"taxCodeSaleId":null,"price":0,"priceOverride":null,"workOrderItemId":747} + + travels: + {"id":0,"concurrency":0,"userId":null,"travelStartDate":"2026-02-26T21:00:00.000Z","travelStopDate":"2026-02-26T21:15:00.000Z","travelRateId":null,"travelDetails":"Test travel details","travelRateQuantity":0.25,"noChargeQuantity":0,"distance":0,"taxCodeSaleId":1,"price":0,"priceOverride":null,"workOrderItemId":747} + + expenses: + {"id":0,"concurrency":0,"description":"test expense description","name":"Test expense summary","totalCost":5.55,"chargeAmount":10,"taxPaid":0,"chargeTaxCodeId":null,"reimburseUser":false,"userId":null,"chargeToCustomer":true,"workOrderItemId":747} + + loans: + {"id":0,"concurrency":0,"notes":null,"outDate":null,"dueDate":null,"returnDate":null,"taxCodeId":2,"loanUnitId":3,"quantity":1,"rate":1,"cost":0,"priceOverride":null,"workOrderItemId":747} + + outside services: + {"id":0,"concurrency":0,"unitId":234,"notes":null,"vendorSentToId":null,"vendorSentViaId":null,"rmaNumber":null,"trackingNumber":null,"repairCost":0,"repairPrice":0,"shippingCost":0,"shippingPrice":0,"sentDate":"2026-02-26T20:25:07.321Z","etaDate":null,"returnDate":null,"taxCodeId":null,"workOrderItemId":747} + + + + + */ //CREATE WOITEMPART d = new JObject(); @@ -73,13 +94,13 @@ namespace raven_integration d.workOrderItemId = WorkOrderItem1Id; //Tags - dTagsArray = new JArray(); - dTagsArray.Add("woitempart-Red"); - dTagsArray.Add("woitempart-green"); - dTagsArray.Add("woitempart-blue"); - d.tags = dTagsArray; + // dTagsArray = new JArray(); + // dTagsArray.Add("woitempart-Red"); + // dTagsArray.Add("woitempart-green"); + // dTagsArray.Add("woitempart-blue"); + //d.tags = dTagsArray; - a = await Util.PostAsync("workorder/items/parts", await Util.GetTokenAsync("superuser", "l3tm3in"), d.ToString()); + a = await Util.PostAsync("workorder/items/parts", await Util.GetTokenAsync("BizAdmin"), d.ToString()); Util.ValidateDataReturnResponseOk(a); dynamic dPartToUpdate = a.ObjectResponse["data"]; long PartId = (long)a.ObjectResponse["data"]["id"]; @@ -94,13 +115,13 @@ namespace raven_integration d.workOrderItemId = WorkOrderItem1Id; //Tags - dTagsArray = new JArray(); - dTagsArray.Add("woitemlabor-Red"); - dTagsArray.Add("woitemlabor-green"); - dTagsArray.Add("woitemlabor-blue"); - d.tags = dTagsArray; + // dTagsArray = new JArray(); + // dTagsArray.Add("woitemlabor-Red"); + // dTagsArray.Add("woitemlabor-green"); + // dTagsArray.Add("woitemlabor-blue"); + // d.tags = dTagsArray; - a = await Util.PostAsync("workorder/items/labors", await Util.GetTokenAsync("superuser", "l3tm3in"), d.ToString()); + a = await Util.PostAsync("workorder/items/labors", await Util.GetTokenAsync("BizAdmin"), d.ToString()); Util.ValidateDataReturnResponseOk(a); dynamic dLaborOne = a.ObjectResponse["data"]; long Labor1Id = a.ObjectResponse["data"]["id"].Value(); @@ -112,20 +133,18 @@ namespace raven_integration d.wiki = "# woitemlabor2 test wiki"; d.workOrderItemId = WorkOrderItem1Id; - //Tags - dTagsArray = new JArray(); - dTagsArray.Add("woitemlabor-Red"); - dTagsArray.Add("woitemlabor-green"); - dTagsArray.Add("woitemlabor-blue"); - d.tags = dTagsArray; + // //Tags + // dTagsArray = new JArray(); + // dTagsArray.Add("woitemlabor-Red"); + // dTagsArray.Add("woitemlabor-green"); + // dTagsArray.Add("woitemlabor-blue"); + // d.tags = dTagsArray; - a = await Util.PostAsync("workorder/items/labors", await Util.GetTokenAsync("superuser", "l3tm3in"), d.ToString()); + a = await Util.PostAsync("workorder/items/labors", await Util.GetTokenAsync("BizAdmin"), d.ToString()); Util.ValidateDataReturnResponseOk(a); long WorkOrderItemLaborId2 = a.ObjectResponse["data"]["id"].Value(); - #endregion create first woitem - #region CREATE Second woitem ///////////////////////////////////////// // Second woitem // @@ -138,13 +157,13 @@ namespace raven_integration d.workOrderId = WorkOrderId; //Tags - dTagsArray = new JArray(); - dTagsArray.Add("woitem-Red"); - dTagsArray.Add("woitem-green"); - dTagsArray.Add("woitem-blue"); - d.tags = dTagsArray; + // dTagsArray = new JArray(); + // dTagsArray.Add("woitem-Red"); + // dTagsArray.Add("woitem-green"); + // dTagsArray.Add("woitem-blue"); + // d.tags = dTagsArray; - a = await Util.PostAsync("workorder/items", await Util.GetTokenAsync("superuser", "l3tm3in"), d.ToString()); + a = await Util.PostAsync("workorder/items", await Util.GetTokenAsync("BizAdmin"), d.ToString()); Util.ValidateDataReturnResponseOk(a); long WorkOrderItem2Id = a.ObjectResponse["data"]["id"].Value(); @@ -157,14 +176,14 @@ namespace raven_integration d.wiki = "# woitempart test wiki"; d.workOrderItemId = WorkOrderItem2Id; - //Tags - dTagsArray = new JArray(); - dTagsArray.Add("woitempart-Red"); - dTagsArray.Add("woitempart-green"); - dTagsArray.Add("woitempart-blue"); - d.tags = dTagsArray; + // //Tags + // dTagsArray = new JArray(); + // dTagsArray.Add("woitempart-Red"); + // dTagsArray.Add("woitempart-green"); + // dTagsArray.Add("woitempart-blue"); + // d.tags = dTagsArray; - a = await Util.PostAsync("workorder/items/parts", await Util.GetTokenAsync("superuser", "l3tm3in"), d.ToString()); + a = await Util.PostAsync("workorder/items/parts", await Util.GetTokenAsync("BizAdmin"), d.ToString()); Util.ValidateDataReturnResponseOk(a); @@ -177,14 +196,14 @@ namespace raven_integration d.wiki = "# woitemlabor test wiki"; d.workOrderItemId = WorkOrderItem2Id; - //Tags - dTagsArray = new JArray(); - dTagsArray.Add("woitemlabor-Red"); - dTagsArray.Add("woitemlabor-green"); - dTagsArray.Add("woitemlabor-blue"); - d.tags = dTagsArray; + // //Tags + // dTagsArray = new JArray(); + // dTagsArray.Add("woitemlabor-Red"); + // dTagsArray.Add("woitemlabor-green"); + // dTagsArray.Add("woitemlabor-blue"); + // d.tags = dTagsArray; - a = await Util.PostAsync("workorder/items/labors", await Util.GetTokenAsync("superuser", "l3tm3in"), d.ToString()); + a = await Util.PostAsync("workorder/items/labors", await Util.GetTokenAsync("BizAdmin"), d.ToString()); Util.ValidateDataReturnResponseOk(a); //TWO-2 @@ -194,14 +213,14 @@ namespace raven_integration d.wiki = "# woitemlabor2 test wiki"; d.workOrderItemId = WorkOrderItem2Id; - //Tags - dTagsArray = new JArray(); - dTagsArray.Add("woitemlabor-Red"); - dTagsArray.Add("woitemlabor-green"); - dTagsArray.Add("woitemlabor-blue"); - d.tags = dTagsArray; + // //Tags + // dTagsArray = new JArray(); + // dTagsArray.Add("woitemlabor-Red"); + // dTagsArray.Add("woitemlabor-green"); + // dTagsArray.Add("woitemlabor-blue"); + // d.tags = dTagsArray; - a = await Util.PostAsync("workorder/items/labors", await Util.GetTokenAsync("superuser", "l3tm3in"), d.ToString()); + a = await Util.PostAsync("workorder/items/labors", await Util.GetTokenAsync("BizAdmin"), d.ToString()); Util.ValidateDataReturnResponseOk(a); @@ -213,13 +232,13 @@ namespace raven_integration d.workOrderItemId = WorkOrderItem2Id; //Tags - dTagsArray = new JArray(); - dTagsArray.Add("expense-Red"); - dTagsArray.Add("expense-green"); - dTagsArray.Add("expense-blue"); - d.tags = dTagsArray; + // dTagsArray = new JArray(); + // dTagsArray.Add("expense-Red"); + // dTagsArray.Add("expense-green"); + // dTagsArray.Add("expense-blue"); + // d.tags = dTagsArray; - a = await Util.PostAsync("workorder/items/expenses", await Util.GetTokenAsync("superuser", "l3tm3in"), d.ToString()); + a = await Util.PostAsync("workorder/items/expenses", await Util.GetTokenAsync("BizAdmin"), d.ToString()); Util.ValidateDataReturnResponseOk(a); long TestExpenseId = (long)a.ObjectResponse["data"]["id"]; @@ -231,14 +250,14 @@ namespace raven_integration d.wiki = "# loan test wiki"; d.workOrderItemId = WorkOrderItem2Id; - //Tags - dTagsArray = new JArray(); - dTagsArray.Add("loan-Red"); - dTagsArray.Add("loan-green"); - dTagsArray.Add("loan-blue"); - d.tags = dTagsArray; + // //Tags + // dTagsArray = new JArray(); + // dTagsArray.Add("loan-Red"); + // dTagsArray.Add("loan-green"); + // dTagsArray.Add("loan-blue"); + // d.tags = dTagsArray; - a = await Util.PostAsync("workorder/items/loans", await Util.GetTokenAsync("superuser", "l3tm3in"), d.ToString()); + a = await Util.PostAsync("workorder/items/loans", await Util.GetTokenAsync("BizAdmin"), d.ToString()); Util.ValidateDataReturnResponseOk(a); @@ -249,14 +268,14 @@ namespace raven_integration d.wiki = "# partrequest test wiki"; d.workOrderItemId = WorkOrderItem2Id; - //Tags - dTagsArray = new JArray(); - dTagsArray.Add("partrequest-Red"); - dTagsArray.Add("partrequest-green"); - dTagsArray.Add("partrequest-blue"); - d.tags = dTagsArray; + // //Tags + // dTagsArray = new JArray(); + // dTagsArray.Add("partrequest-Red"); + // dTagsArray.Add("partrequest-green"); + // dTagsArray.Add("partrequest-blue"); + // d.tags = dTagsArray; - a = await Util.PostAsync("workorder/items/partrequests", await Util.GetTokenAsync("superuser", "l3tm3in"), d.ToString()); + a = await Util.PostAsync("workorder/items/partrequests", await Util.GetTokenAsync("BizAdmin"), d.ToString()); Util.ValidateDataReturnResponseOk(a); //scheduleduser @@ -266,14 +285,14 @@ namespace raven_integration d.wiki = "# scheduleduser test wiki"; d.workOrderItemId = WorkOrderItem2Id; - //Tags - dTagsArray = new JArray(); - dTagsArray.Add("scheduleduser-Red"); - dTagsArray.Add("scheduleduser-green"); - dTagsArray.Add("scheduleduser-blue"); - d.tags = dTagsArray; + // //Tags + // dTagsArray = new JArray(); + // dTagsArray.Add("scheduleduser-Red"); + // dTagsArray.Add("scheduleduser-green"); + // dTagsArray.Add("scheduleduser-blue"); + // d.tags = dTagsArray; - a = await Util.PostAsync("workorder/items/scheduledusers", await Util.GetTokenAsync("superuser", "l3tm3in"), d.ToString()); + a = await Util.PostAsync("workorder/items/scheduledusers", await Util.GetTokenAsync("BizAdmin"), d.ToString()); Util.ValidateDataReturnResponseOk(a); @@ -284,14 +303,14 @@ namespace raven_integration d.wiki = "# task test wiki"; d.workOrderItemId = WorkOrderItem2Id; - //Tags - dTagsArray = new JArray(); - dTagsArray.Add("task-Red"); - dTagsArray.Add("task-green"); - dTagsArray.Add("task-blue"); - d.tags = dTagsArray; + // //Tags + // dTagsArray = new JArray(); + // dTagsArray.Add("task-Red"); + // dTagsArray.Add("task-green"); + // dTagsArray.Add("task-blue"); + // d.tags = dTagsArray; - a = await Util.PostAsync("workorder/items/tasks", await Util.GetTokenAsync("superuser", "l3tm3in"), d.ToString()); + a = await Util.PostAsync("workorder/items/tasks", await Util.GetTokenAsync("BizAdmin"), d.ToString()); Util.ValidateDataReturnResponseOk(a); @@ -302,14 +321,14 @@ namespace raven_integration d.wiki = "# travel test wiki"; d.workOrderItemId = WorkOrderItem2Id; - //Tags - dTagsArray = new JArray(); - dTagsArray.Add("travel-Red"); - dTagsArray.Add("travel-green"); - dTagsArray.Add("travel-blue"); - d.tags = dTagsArray; + // //Tags + // dTagsArray = new JArray(); + // dTagsArray.Add("travel-Red"); + // dTagsArray.Add("travel-green"); + // dTagsArray.Add("travel-blue"); + // d.tags = dTagsArray; - a = await Util.PostAsync("workorder/items/travels", await Util.GetTokenAsync("superuser", "l3tm3in"), d.ToString()); + a = await Util.PostAsync("workorder/items/travels", await Util.GetTokenAsync("BizAdmin"), d.ToString()); Util.ValidateDataReturnResponseOk(a); @@ -320,45 +339,41 @@ namespace raven_integration d.wiki = "# unit test wiki"; d.workOrderItemId = WorkOrderItem2Id; - //Tags - dTagsArray = new JArray(); - dTagsArray.Add("unit-Red"); - dTagsArray.Add("unit-green"); - dTagsArray.Add("unit-blue"); - d.tags = dTagsArray; + // //Tags + // dTagsArray = new JArray(); + // dTagsArray.Add("unit-Red"); + // dTagsArray.Add("unit-green"); + // dTagsArray.Add("unit-blue"); + // d.tags = dTagsArray; - a = await Util.PostAsync("workorder/items/units", await Util.GetTokenAsync("superuser", "l3tm3in"), d.ToString()); + a = await Util.PostAsync("workorder/items/units", await Util.GetTokenAsync("BizAdmin"), d.ToString()); Util.ValidateDataReturnResponseOk(a); - #endregion create second woitem - #region UPDATE ///////////////////////////////////////////////////////////////////////// //UPDATES // dLaborOne.notes = "UpdatedLaborNotes"; - a = await Util.PutAsync("workorder/items/labors", await Util.GetTokenAsync("superuser", "l3tm3in"), dLaborOne.ToString()); + a = await Util.PutAsync("workorder/items/labors", await Util.GetTokenAsync("BizAdmin"), dLaborOne.ToString()); Util.ValidateDataReturnResponseOk(a); dPartToUpdate.notes = "UpdatedPartNotes"; - a = await Util.PutAsync("workorder/items/parts", await Util.GetTokenAsync("superuser", "l3tm3in"), dPartToUpdate.ToString()); + a = await Util.PutAsync("workorder/items/parts", await Util.GetTokenAsync("BizAdmin"), dPartToUpdate.ToString()); Util.ValidateDataReturnResponseOk(a); WorkOrderItemToUpdate.notes = "UpdatedWoItemNotes"; - a = await Util.PutAsync("workorder/items", await Util.GetTokenAsync("superuser", "l3tm3in"), WorkOrderItemToUpdate.ToString()); + a = await Util.PutAsync("workorder/items", await Util.GetTokenAsync("BizAdmin"), WorkOrderItemToUpdate.ToString()); Util.ValidateDataReturnResponseOk(a); WorkorderToUpdate.notes = "UpdatedWoNotes"; - a = await Util.PutAsync("workorder", await Util.GetTokenAsync("superuser", "l3tm3in"), WorkorderToUpdate.ToString()); + a = await Util.PutAsync("workorder", await Util.GetTokenAsync("BizAdmin"), WorkorderToUpdate.ToString()); Util.ValidateDataReturnResponseOk(a); - #endregion update - #region Validate all create and update //RETRIEVE WORKORDER AND VALIDATE ENTIRE - a = await Util.GetAsync("workorder/" + WorkOrderId.ToString(), await Util.GetTokenAsync("superuser", "l3tm3in")); + a = await Util.GetAsync("workorder/" + WorkOrderId.ToString(), await Util.GetTokenAsync("BizAdmin")); Util.ValidateDataReturnResponseOk(a); var w = a.ObjectResponse["data"]; @@ -390,32 +405,32 @@ namespace raven_integration woitem2["units"].Count().Should().Be(1); - #endregion validate entire + //Test get ancestor route var AyaTypeWorkOrderItemExpense = 36; - a = await Util.GetAsync($"search/ancestor/{AyaTypeWorkOrderItemExpense}/{TestExpenseId}", await Util.GetTokenAsync("superuser", "l3tm3in")); + a = await Util.GetAsync($"search/ancestor/{AyaTypeWorkOrderItemExpense}/{TestExpenseId}", await Util.GetTokenAsync("BizAdmin")); Util.ValidateDataReturnResponseOk(a); - #region DELETE - a = await Util.DeleteAsync("workorder/items/labors/" + Labor1Id.ToString(), await Util.GetTokenAsync("superuser", "l3tm3in")); + + a = await Util.DeleteAsync("workorder/items/labors/" + Labor1Id.ToString(), await Util.GetTokenAsync("BizAdmin")); Util.ValidateHTTPStatusCode(a, 204); - a = await Util.GetAsync("workorder/items/labors/" + Labor1Id.ToString(), await Util.GetTokenAsync("superuser", "l3tm3in")); + a = await Util.GetAsync("workorder/items/labors/" + Labor1Id.ToString(), await Util.GetTokenAsync("BizAdmin")); Util.ValidateHTTPStatusCode(a, 404); - a = await Util.DeleteAsync("workorder/items/" + WorkOrderItem2Id.ToString(), await Util.GetTokenAsync("superuser", "l3tm3in")); + a = await Util.DeleteAsync("workorder/items/" + WorkOrderItem2Id.ToString(), await Util.GetTokenAsync("BizAdmin")); Util.ValidateHTTPStatusCode(a, 204); - a = await Util.GetAsync("workorder/items/" + WorkOrderItem2Id.ToString(), await Util.GetTokenAsync("superuser", "l3tm3in")); + a = await Util.GetAsync("workorder/items/" + WorkOrderItem2Id.ToString(), await Util.GetTokenAsync("BizAdmin")); Util.ValidateHTTPStatusCode(a, 404); - a = await Util.DeleteAsync("workorder/" + WorkOrderId.ToString(), await Util.GetTokenAsync("superuser", "l3tm3in")); + a = await Util.DeleteAsync("workorder/" + WorkOrderId.ToString(), await Util.GetTokenAsync("BizAdmin")); Util.ValidateHTTPStatusCode(a, 204); - a = await Util.GetAsync("workorder/" + WorkOrderId.ToString(), await Util.GetTokenAsync("superuser", "l3tm3in")); + a = await Util.GetAsync("workorder/" + WorkOrderId.ToString(), await Util.GetTokenAsync("BizAdmin")); Util.ValidateHTTPStatusCode(a, 404); - #endregion delete + } @@ -424,7 +439,7 @@ namespace raven_integration [Fact] public async Task ConfirmDeleteTransactionWorksAtServer() { - ApiResponse a = await Util.GetAsync("build-mode", await Util.GetTokenAsync("superuser", "l3tm3in")); + ApiResponse a = await Util.GetAsync("build-mode", await Util.GetTokenAsync("BizAdmin")); Util.ValidateDataReturnResponseOk(a); var BuildMode = (string)a.ObjectResponse["data"]["buildMode"]; @@ -436,7 +451,7 @@ namespace raven_integration d.notes = "WOHEADER"; d.wiki = "INTEGRATION_DELETE_TEST_FAIL_BEFORE_COMMIT";//<-- key phrase triggers server exception in Workorder immediately before it would normally commit the whole thing - a = await Util.PostAsync("workorder", await Util.GetTokenAsync("superuser", "l3tm3in"), d.ToString()); + a = await Util.PostAsync("workorder", await Util.GetTokenAsync("BizAdmin"), d.ToString()); Util.ValidateDataReturnResponseOk(a); long WorkOrderId = a.ObjectResponse["data"]["id"].Value(); @@ -444,7 +459,7 @@ namespace raven_integration d = new JObject(); d.active = true; d.workOrderId = WorkOrderId; - a = await Util.PostAsync("workorder/items", await Util.GetTokenAsync("superuser", "l3tm3in"), d.ToString()); + a = await Util.PostAsync("workorder/items", await Util.GetTokenAsync("BizAdmin"), d.ToString()); Util.ValidateDataReturnResponseOk(a); long WorkOrderItem1Id = a.ObjectResponse["data"]["id"].Value(); @@ -452,7 +467,7 @@ namespace raven_integration d = new JObject(); d.active = true; d.workOrderItemId = WorkOrderItem1Id; - a = await Util.PostAsync("workorder/items/parts", await Util.GetTokenAsync("superuser", "l3tm3in"), d.ToString()); + a = await Util.PostAsync("workorder/items/parts", await Util.GetTokenAsync("BizAdmin"), d.ToString()); Util.ValidateDataReturnResponseOk(a); //CREATE TWO WOITEMLABORS @@ -460,21 +475,21 @@ namespace raven_integration d = new JObject(); d.active = true; d.workOrderItemId = WorkOrderItem1Id; - a = await Util.PostAsync("workorder/items/labors", await Util.GetTokenAsync("superuser", "l3tm3in"), d.ToString()); + a = await Util.PostAsync("workorder/items/labors", await Util.GetTokenAsync("BizAdmin"), d.ToString()); Util.ValidateDataReturnResponseOk(a); //TWO d = new JObject(); d.active = true; d.workOrderItemId = WorkOrderItem1Id; - a = await Util.PostAsync("workorder/items/labors", await Util.GetTokenAsync("superuser", "l3tm3in"), d.ToString()); + a = await Util.PostAsync("workorder/items/labors", await Util.GetTokenAsync("BizAdmin"), d.ToString()); Util.ValidateDataReturnResponseOk(a); //CREATE WOITEM-2 d = new JObject(); d.active = true; d.workOrderId = WorkOrderId; - a = await Util.PostAsync("workorder/items", await Util.GetTokenAsync("superuser", "l3tm3in"), d.ToString()); + a = await Util.PostAsync("workorder/items", await Util.GetTokenAsync("BizAdmin"), d.ToString()); Util.ValidateDataReturnResponseOk(a); long WorkOrderItem2Id = (long)a.ObjectResponse["data"]["id"]; @@ -482,7 +497,7 @@ namespace raven_integration d = new JObject(); d.active = true; d.workOrderItemId = WorkOrderItem2Id; - a = await Util.PostAsync("workorder/items/parts", await Util.GetTokenAsync("superuser", "l3tm3in"), d.ToString()); + a = await Util.PostAsync("workorder/items/parts", await Util.GetTokenAsync("BizAdmin"), d.ToString()); Util.ValidateDataReturnResponseOk(a); //CREATE WOITEMLABOR(S)-2 @@ -490,22 +505,22 @@ namespace raven_integration d = new JObject(); d.active = true; d.workOrderItemId = WorkOrderItem2Id; - a = await Util.PostAsync("workorder/items/labors", await Util.GetTokenAsync("superuser", "l3tm3in"), d.ToString()); + a = await Util.PostAsync("workorder/items/labors", await Util.GetTokenAsync("BizAdmin"), d.ToString()); Util.ValidateDataReturnResponseOk(a); //TWO-2 d = new JObject(); d.active = true; d.workOrderItemId = WorkOrderItem2Id; - a = await Util.PostAsync("workorder/items/labors", await Util.GetTokenAsync("superuser", "l3tm3in"), d.ToString()); + a = await Util.PostAsync("workorder/items/labors", await Util.GetTokenAsync("BizAdmin"), d.ToString()); Util.ValidateDataReturnResponseOk(a); - a = await Util.DeleteAsync("workorder/" + WorkOrderId.ToString(), await Util.GetTokenAsync("superuser", "l3tm3in")); - Util.ValidateErrorCodeResponse(a, 2200, 400); + a = await Util.DeleteAsync("workorder/" + WorkOrderId.ToString(), await Util.GetTokenAsync("BizAdmin")); + Util.ValidateErrorCodeResponse(a, 2200, 400); //now confirm the workorder is still there and with it's children intact //RETRIEVE WORKORDER AND VALIDATE ENTIRE - a = await Util.GetAsync("workorder/" + WorkOrderId.ToString(), await Util.GetTokenAsync("superuser", "l3tm3in")); + a = await Util.GetAsync("workorder/" + WorkOrderId.ToString(), await Util.GetTokenAsync("BizAdmin")); Util.ValidateDataReturnResponseOk(a); var w = a.ObjectResponse["data"]; @@ -541,7 +556,7 @@ namespace raven_integration d.notes = "WOHEADER DuplicateWorks"; d.wiki = "DuplicateWorks integration test"; - ApiResponse a = await Util.PostAsync("workorder", await Util.GetTokenAsync("superuser", "l3tm3in"), d.ToString()); + ApiResponse a = await Util.PostAsync("workorder", await Util.GetTokenAsync("BizAdmin"), d.ToString()); Util.ValidateDataReturnResponseOk(a); dynamic WorkorderToUpdate = a.ObjectResponse["data"]; long WorkOrderId = a.ObjectResponse["data"]["id"].Value(); @@ -555,7 +570,7 @@ namespace raven_integration d.wiki = "# woitem test wiki"; d.workOrderId = WorkOrderId; - a = await Util.PostAsync("workorder/items", await Util.GetTokenAsync("superuser", "l3tm3in"), d.ToString()); + a = await Util.PostAsync("workorder/items", await Util.GetTokenAsync("BizAdmin"), d.ToString()); Util.ValidateDataReturnResponseOk(a); dynamic WorkOrderItemToUpdate = a.ObjectResponse["data"]; long WorkOrderItem1Id = a.ObjectResponse["data"]["id"].Value(); @@ -564,10 +579,10 @@ namespace raven_integration d = new JObject(); d.active = true; d.notes = "woitempart DuplicateWorks"; - // d.wiki = "# woitempart test wiki"; + // d.wiki = "# woitempart test wiki"; d.workOrderItemId = WorkOrderItem1Id; - a = await Util.PostAsync("workorder/items/parts", await Util.GetTokenAsync("superuser", "l3tm3in"), d.ToString()); + a = await Util.PostAsync("workorder/items/parts", await Util.GetTokenAsync("BizAdmin"), d.ToString()); Util.ValidateDataReturnResponseOk(a); dynamic dPartToUpdate = a.ObjectResponse["data"]; long PartId = (long)a.ObjectResponse["data"]["id"]; @@ -577,11 +592,11 @@ namespace raven_integration d = new JObject(); d.active = true; d.notes = "woitemlabor DuplicateWorks"; - // d.wiki = "# woitemlabor test wiki"; + // d.wiki = "# woitemlabor test wiki"; d.workOrderItemId = WorkOrderItem1Id; - a = await Util.PostAsync("workorder/items/labors", await Util.GetTokenAsync("superuser", "l3tm3in"), d.ToString()); + a = await Util.PostAsync("workorder/items/labors", await Util.GetTokenAsync("BizAdmin"), d.ToString()); Util.ValidateDataReturnResponseOk(a); dynamic dLaborOne = a.ObjectResponse["data"]; long Labor1Id = a.ObjectResponse["data"]["id"].Value(); @@ -590,11 +605,11 @@ namespace raven_integration d = new JObject(); d.active = true; d.notes = "woitemlabor2 DuplicateWorks"; - // d.wiki = "# woitemlabor2 test wiki"; + // d.wiki = "# woitemlabor2 test wiki"; d.workOrderItemId = WorkOrderItem1Id; - a = await Util.PostAsync("workorder/items/labors", await Util.GetTokenAsync("superuser", "l3tm3in"), d.ToString()); + a = await Util.PostAsync("workorder/items/labors", await Util.GetTokenAsync("BizAdmin"), d.ToString()); Util.ValidateDataReturnResponseOk(a); long WorkOrderItemLaborId2 = a.ObjectResponse["data"]["id"].Value(); @@ -611,7 +626,7 @@ namespace raven_integration d.wiki = "# woitem test wiki"; d.workOrderId = WorkOrderId; - a = await Util.PostAsync("workorder/items", await Util.GetTokenAsync("superuser", "l3tm3in"), d.ToString()); + a = await Util.PostAsync("workorder/items", await Util.GetTokenAsync("BizAdmin"), d.ToString()); Util.ValidateDataReturnResponseOk(a); long WorkOrderItem2Id = a.ObjectResponse["data"]["id"].Value(); @@ -619,10 +634,10 @@ namespace raven_integration d = new JObject(); d.active = true; d.notes = "woitem-2-partDuplicateWorks"; - // d.wiki = "# woitempart test wiki"; + // d.wiki = "# woitempart test wiki"; d.workOrderItemId = WorkOrderItem2Id; - a = await Util.PostAsync("workorder/items/parts", await Util.GetTokenAsync("superuser", "l3tm3in"), d.ToString()); + a = await Util.PostAsync("workorder/items/parts", await Util.GetTokenAsync("BizAdmin"), d.ToString()); Util.ValidateDataReturnResponseOk(a); //CREATE WOITEMLABOR(S)-2 @@ -632,7 +647,7 @@ namespace raven_integration d.notes = "woitem-2-laborDuplicateWorks"; //d.wiki = "# woitemlabor test wiki"; d.workOrderItemId = WorkOrderItem2Id; - a = await Util.PostAsync("workorder/items/labors", await Util.GetTokenAsync("superuser", "l3tm3in"), d.ToString()); + a = await Util.PostAsync("workorder/items/labors", await Util.GetTokenAsync("BizAdmin"), d.ToString()); Util.ValidateDataReturnResponseOk(a); //TWO-2 @@ -641,7 +656,7 @@ namespace raven_integration d.notes = "woitem-2-labor2DuplicateWorks"; //d.wiki = "# woitemlabor2 test wiki"; d.workOrderItemId = WorkOrderItem2Id; - a = await Util.PostAsync("workorder/items/labors", await Util.GetTokenAsync("superuser", "l3tm3in"), d.ToString()); + a = await Util.PostAsync("workorder/items/labors", await Util.GetTokenAsync("BizAdmin"), d.ToString()); Util.ValidateDataReturnResponseOk(a); #endregion create second woitem @@ -651,14 +666,14 @@ namespace raven_integration #region Duplicate and Validate //DUPLICATE - should make a copy of above, save and return entire object graph just like a get operation - a = await Util.PostAsync("workorder/duplicate/" + WorkOrderId.ToString(), await Util.GetTokenAsync("superuser", "l3tm3in"), d.ToString()); + a = await Util.PostAsync("workorder/duplicate/" + WorkOrderId.ToString(), await Util.GetTokenAsync("BizAdmin"), d.ToString()); Util.ValidateDataReturnResponseOk(a); long DuplicateWorkOrderId = a.ObjectResponse["data"]["id"].Value(); DuplicateWorkOrderId.Should().NotBe(WorkOrderId); ((long)a.ObjectResponse["data"]["serial"]).Should().NotBe(0); // //RETRIEVE WORKORDER AND VALIDATE ENTIRE - // a = await Util.GetAsync("workorder/" + WorkOrderId.ToString(), await Util.GetTokenAsync("superuser", "l3tm3in")); + // a = await Util.GetAsync("workorder/" + WorkOrderId.ToString(), await Util.GetTokenAsync("BizAdmin")); // Util.ValidateDataReturnResponseOk(a); var w = a.ObjectResponse["data"]; diff --git a/util.cs b/util.cs index c0c5d08..36f7f87 100644 --- a/util.cs +++ b/util.cs @@ -647,6 +647,11 @@ namespace raven_integration } + public static string TagJsonFromStrings(string tagNameStart, params string[] tags) + { + return string.Join(", ", tags.Select(t => $"\"{tagNameStart}-{t}\"")); + } +