4648
This commit is contained in:
@@ -9,10 +9,6 @@ namespace raven_integration
|
||||
public class WorkOrderCrud
|
||||
{
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
/// <summary>
|
||||
/// 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>();
|
||||
((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<long>();
|
||||
|
||||
//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<long>();
|
||||
|
||||
/*
|
||||
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<long>();
|
||||
@@ -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<long>();
|
||||
|
||||
#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<long>();
|
||||
|
||||
@@ -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<long>();
|
||||
|
||||
@@ -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<long>();
|
||||
|
||||
@@ -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<long>();
|
||||
@@ -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<long>();
|
||||
@@ -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<long>();
|
||||
@@ -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<long>();
|
||||
|
||||
@@ -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<long>();
|
||||
|
||||
@@ -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<long>();
|
||||
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"];
|
||||
|
||||
Reference in New Issue
Block a user