From 2f0681353a5049a272bb5b71bbe9cdce4561abc1 Mon Sep 17 00:00:00 2001 From: John Cardinal Date: Wed, 25 Feb 2026 09:33:05 -0800 Subject: [PATCH] 4648 --- Search/SearchOps.cs | 228 ++++++++++++++++++-------------------------- 1 file changed, 94 insertions(+), 134 deletions(-) diff --git a/Search/SearchOps.cs b/Search/SearchOps.cs index 80f41c1..28145bf 100644 --- a/Search/SearchOps.cs +++ b/Search/SearchOps.cs @@ -1,9 +1,6 @@ -using System; using Xunit; using Newtonsoft.Json.Linq; -using System.Linq; using FluentAssertions; -using System.Collections.Generic; namespace raven_integration { @@ -11,98 +8,69 @@ namespace raven_integration public class SearchOps { - //NOTE: this test failed one time for no apparent reason but then was ok afterwards + [Fact] public async Task PhraseOnlySearchShouldReturnCorrectResultsInOrder() { - const string TEST_SEARCH_PHRASE = "simple dogs"; + + //CREATE A PROJECT phrase in notes + var projectName = Util.Uniquify("search notes test project should match"); + var dateStarted = DateTime.Now.ToString("o"); + var payload = $$""" + {"id":0,"concurrency":0,"name":"{{projectName}}","active":true,"notes":"This record will match in notes: The quick brown and simple fox jumped over the six lazy dogs!","wiki":null,"customFields":"{}","tags":["blue","zebra"],"dateStarted":"{{dateStarted}}","dateCompleted":null,"projectOverseerId":null,"accountNumber":"TestAccountNumber"} + """; - //CREATE A WIDGET - dynamic D = new JObject(); - D.name = Util.Uniquify("search NOTES Test WIDGET"); - D.customFields = Util.WidgetRequiredCustomFieldsJsonString(); - D.dollarAmount = 1.11m; - D.active = true; - D.usertype = 1; - D.notes = "This record will match in notes: The quick brown and simple fox jumped over the six lazy dogs!"; - - ApiResponse a = await Util.PostAsync("widget", await Util.GetTokenAsync("superuser", "l3tm3in"), D.ToString()); + ApiResponse a = await Util.PostAsync("project", await Util.GetTokenAsync("superuser", "l3tm3in"), payload); Util.ValidateDataReturnResponseOk(a); - long MatchWidgetInNotesId = a.ObjectResponse["data"]["id"].Value(); + long MatchProjectInNotesId = a.ObjectResponse["data"]["id"].Value(); - //CREATE FIRST TEST USER WITH PHRASE IN NAME - D = new JObject(); - D.name = Util.Uniquify("search NAME DOGS simple Test User"); - D.customFields = Util.WidgetRequiredCustomFieldsJsonString(); - D.notes = "This user has the match in it's name"; - - D.active = true; - D.login = Util.Uniquify("LOGIN"); - D.password = Util.Uniquify("PASSWORD"); - D.usertype = 1; - - D.userType = 2;// not service type user - - a = await Util.PostAsync("User", await Util.GetTokenAsync("superuser", "l3tm3in"), D.ToString()); + //CREATE FIRST TEST USER WITH PHRASE IN NAME + var userName = Util.Uniquify("search NAME DOGS simple Test User"); + payload = $$""" + {"id":0,"concurrency":0,"active":true,"allowLogin":true,"name":"{{userName}}","roles":8,"userType":2,"employeeNumber":null,"notes":null,"customerId":null,"headOfficeId":null,"vendorId":null,"wiki":null,"customFields":"{}","tags":[],"lastLogin":null,"password":"{{userName}}","login":"{{userName}}"} + """; + a = await Util.PostAsync("User", await Util.GetTokenAsync("superuser", "l3tm3in"), payload); Util.ValidateDataReturnResponseOk(a); long MatchUserInNameId = a.ObjectResponse["data"]["id"].Value(); //CREATE A SECOND TEST USER WITH PHRASE IN NOTES - D = new JObject(); - D.name = Util.Uniquify("search NOTES Test User"); - D.customFields = Util.WidgetRequiredCustomFieldsJsonString(); - D.notes = "This user has the match simple dogs in its notes"; - - D.active = true; - D.login = Util.Uniquify("LOGIN"); - D.password = Util.Uniquify("PASSWORD"); - D.usertype = 1; - - D.userType = 2;// not service type user - - a = await Util.PostAsync("User", await Util.GetTokenAsync("superuser", "l3tm3in"), D.ToString()); + userName = Util.Uniquify("search NOTES Test User"); + payload = $$""" + {"id":0,"concurrency":0,"active":true,"allowLogin":true,"name":"{{userName}}","roles":8,"userType":2,"employeeNumber":null,"notes":"This user has the match simple dogs in its notes","customerId":null,"headOfficeId":null,"vendorId":null,"wiki":null,"customFields":"{}","tags":[],"lastLogin":null,"password":"{{userName}}","login":"{{userName}}"} + """; + a = await Util.PostAsync("User", await Util.GetTokenAsync("superuser", "l3tm3in"), payload); Util.ValidateDataReturnResponseOk(a); long MatchUserInNotesId = a.ObjectResponse["data"]["id"].Value(); - //CREATE A SECOND WIDGET - D = new JObject(); - D.name = Util.Uniquify("search NAME simple as in dogs Test WIDGET"); - D.customFields = Util.WidgetRequiredCustomFieldsJsonString(); - D.dollarAmount = 1.11m; - D.active = true; - D.usertype = 1; - D.notes = "This Widget matches in name"; - - a = await Util.PostAsync("widget", await Util.GetTokenAsync("superuser", "l3tm3in"), D.ToString()); + //CREATE A SECOND PROJECT + projectName = Util.Uniquify("search NAME simple as in dogs Test PROJECT"); + payload = $$""" + {"id":0,"concurrency":0,"name":"{{projectName}}","active":true,"notes":"This Project matches in name","wiki":null,"customFields":"{}","tags":["blue","zebra"],"dateStarted":"{{dateStarted}}","dateCompleted":null,"projectOverseerId":null,"accountNumber":"TestAccountNumber"} + """; + a = await Util.PostAsync("project", await Util.GetTokenAsync("superuser", "l3tm3in"), payload); Util.ValidateDataReturnResponseOk(a); - long MatchWidgetInNameId = a.ObjectResponse["data"]["id"].Value(); + long MatchProjectInNameId = a.ObjectResponse["data"]["id"].Value(); - //CREATE A THIRD WIDGET - D = new JObject(); - D.name = Util.Uniquify("search NO-MATCH THIRD Test WIDGET"); - D.customFields = Util.WidgetRequiredCustomFieldsJsonString(); - D.dollarAmount = 1.11m; - D.active = true; - D.usertype = 1; - D.notes = "This Widget should not be returned in the search as it only contains a single keyword in the name not both"; - - a = await Util.PostAsync("widget", await Util.GetTokenAsync("superuser", "l3tm3in"), D.ToString()); + //CREATE A THIRD PROJECT + projectName = Util.Uniquify("XXX NO MATCH search simple THIRD Test PROJECT"); + payload = $$""" + {"id":0,"concurrency":0,"name":"{{projectName}}","active":true,"notes":"This Project should not be returned in the search as it only contains a single keyword in the name not both","wiki":null,"customFields":"{}","tags":["blue","zebra"],"dateStarted":"{{dateStarted}}","dateCompleted":null,"projectOverseerId":null,"accountNumber":"TestAccountNumber"} + """; + a = await Util.PostAsync("project", await Util.GetTokenAsync("superuser", "l3tm3in"), payload); Util.ValidateDataReturnResponseOk(a); - long MatchNothingWidgetId = a.ObjectResponse["data"]["id"].Value(); + long MatchNothingProjectId = a.ObjectResponse["data"]["id"].Value(); //Now see if can find those objects with a phrase search dynamic SearchParameters = new JObject(); - - SearchParameters.phrase = TEST_SEARCH_PHRASE; - + SearchParameters.phrase = "simple dogs"; SearchParameters.typeOnly = 0;//no type SearchParameters.maxResults = 0; a = await Util.PostAsync("search", await Util.GetTokenAsync("superuser", "l3tm3in"), SearchParameters.ToString()); Util.ValidateDataReturnResponseOk(a); //Now validate the return list - ((JArray)a.ObjectResponse["data"]["searchResults"]).Count.Should().BeGreaterOrEqualTo(3); + ((JArray)a.ObjectResponse["data"]["searchResults"]).Count.Should().BeGreaterOrEqualTo(4); //Turn the list into an array of id's var v = ((JArray)a.ObjectResponse["data"]["searchResults"]); @@ -113,24 +81,16 @@ namespace raven_integration } //Ensure the expected items are returned - MatchingIdList.Should().Contain(MatchWidgetInNotesId, "ShouldContainMatchWidgetInNotesId"); - MatchingIdList.Should().Contain(MatchWidgetInNameId, "ShouldContainMatchWidgetInNameId"); + MatchingIdList.Should().Contain(MatchProjectInNotesId, "ShouldContainMatchProjectInNotesId"); + MatchingIdList.Should().Contain(MatchProjectInNameId, "ShouldContainMatchProjectInNameId"); MatchingIdList.Should().Contain(MatchUserInNotesId, "ShouldContainMatchUserInNotesId"); MatchingIdList.Should().Contain(MatchUserInNameId, "ShouldContainMatchUserInNameId"); - MatchingIdList.Should().NotContain(MatchNothingWidgetId, "ShouldNotContainMatchNothingWidgetId"); - - //Assert the order (roughly, this is kind of a waste of time, either the code is sorting or not, it's not going to change) - //first item must be a widget - a.ObjectResponse["data"]["searchResults"][0]["type"].Value().Should().Be(2); - - //final item must be a user - a.ObjectResponse["data"]["searchResults"][MatchingIdList.Count - 1]["type"].Value().Should().Be(3); - + MatchingIdList.Should().NotContain(MatchNothingProjectId, "ShouldNotContainMatchNothingProjectId"); //FULL BODY SEARCH RIGHTS //First up test a full record search returns no results due to insufficient rights //even though the record exists - //Just re-run the above search exactly but with a no rights to full User or Widget role instead + //Just re-run the above search exactly but with a no rights to full User or Project role instead //Only BizAdmin* roles can read a full user record //This search should return zero items @@ -150,19 +110,19 @@ namespace raven_integration { const string TEST_SEARCH_PHRASE = "hap* goose"; - //CREATE A WIDGET + //CREATE A PROJECT dynamic D = new JObject(); - D.name = Util.Uniquify("Wildcard startswith search test WIDGET"); - D.customFields = Util.WidgetRequiredCustomFieldsJsonString(); + D.name = Util.Uniquify("Wildcard startswith search test PROJECT"); + D.dollarAmount = 1.11m; D.active = true; D.usertype = 1; D.notes = "This record will match in notes: The quick brown and hapless goose"; - ApiResponse a = await Util.PostAsync("widget", await Util.GetTokenAsync("superuser", "l3tm3in"), D.ToString()); + ApiResponse a = await Util.PostAsync("project", await Util.GetTokenAsync("superuser", "l3tm3in"), D.ToString()); Util.ValidateDataReturnResponseOk(a); - long MatchWidgetInNotesId = a.ObjectResponse["data"]["id"].Value(); + long MatchProjectInNotesId = a.ObjectResponse["data"]["id"].Value(); //CREATE FIRST TEST USER WITH PHRASE IN NAME D = new JObject(); @@ -204,7 +164,7 @@ namespace raven_integration } //Ensure the expected items are returned - MatchingIdList.Should().Contain(MatchWidgetInNotesId, "ShouldContainMatchWidgetInNotesId"); + MatchingIdList.Should().Contain(MatchProjectInNotesId, "ShouldContainMatchProjectInNotesId"); MatchingIdList.Should().Contain(MatchUserInNameId, "ShouldContainMatchUserInNameId"); }//eot @@ -215,18 +175,18 @@ namespace raven_integration { const string TEST_SEARCH_PHRASE = "goose *act"; - //CREATE A WIDGET + //CREATE A PROJECT dynamic D = new JObject(); - D.name = Util.Uniquify("Wildcard endswith search test WIDGET"); - D.customFields = Util.WidgetRequiredCustomFieldsJsonString(); + D.name = Util.Uniquify("Wildcard endswith search test PROJECT"); + D.dollarAmount = 1.11m; D.active = true; D.usertype = 1; D.notes = "This record will match in notes: react to the goose"; - ApiResponse a = await Util.PostAsync("widget", await Util.GetTokenAsync("superuser", "l3tm3in"), D.ToString()); + ApiResponse a = await Util.PostAsync("project", await Util.GetTokenAsync("superuser", "l3tm3in"), D.ToString()); Util.ValidateDataReturnResponseOk(a); - long MatchWidgetInNotesId = a.ObjectResponse["data"]["id"].Value(); + long MatchProjectInNotesId = a.ObjectResponse["data"]["id"].Value(); //CREATE FIRST TEST USER WITH PHRASE IN NAME D = new JObject(); @@ -268,7 +228,7 @@ namespace raven_integration } //Ensure the expected items are returned - MatchingIdList.Should().Contain(MatchWidgetInNotesId, "ShouldContainMatchWidgetInNotesId"); + MatchingIdList.Should().Contain(MatchProjectInNotesId, "ShouldContainMatchProjectInNotesId"); MatchingIdList.Should().Contain(MatchUserInNameId, "ShouldContainMatchUserInNameId"); }//eot @@ -281,18 +241,18 @@ namespace raven_integration { const string TEST_SEARCH_PHRASE = "cast goose"; - //CREATE A WIDGET + //CREATE A PROJECT dynamic D = new JObject(); - D.name = Util.Uniquify("Wildcard contains search test WIDGET"); - D.customFields = Util.WidgetRequiredCustomFieldsJsonString(); + D.name = Util.Uniquify("Wildcard contains search test PROJECT"); + D.dollarAmount = 1.11m; D.active = true; D.usertype = 1; D.notes = "This record will match in notes: broadcasting to the goose"; - ApiResponse a = await Util.PostAsync("widget", await Util.GetTokenAsync("superuser", "l3tm3in"), D.ToString()); + ApiResponse a = await Util.PostAsync("project", await Util.GetTokenAsync("superuser", "l3tm3in"), D.ToString()); Util.ValidateDataReturnResponseOk(a); - long MatchWidgetInNotesId = a.ObjectResponse["data"]["id"].Value(); + long MatchProjectInNotesId = a.ObjectResponse["data"]["id"].Value(); //CREATE FIRST TEST USER WITH PHRASE IN NAME D = new JObject(); @@ -334,13 +294,13 @@ namespace raven_integration } //Ensure the expected items are returned - MatchingIdList.Should().Contain(MatchWidgetInNotesId, "ShouldContainMatchWidgetInNotesId"); + MatchingIdList.Should().Contain(MatchProjectInNotesId, "ShouldContainMatchProjectInNotesId"); MatchingIdList.Should().Contain(MatchUserInNameId, "ShouldContainMatchUserInNameId"); //Ensure excerpt works and contains the search phrase // /Search/Info/2/1?phrase=we&max=200 - a = await Util.GetAsync($"search/Info/2/{MatchWidgetInNotesId}?phrase={TEST_SEARCH_PHRASE}&max=200", await Util.GetTokenAsync("superuser", "l3tm3in")); + a = await Util.GetAsync($"search/Info/2/{MatchProjectInNotesId}?phrase={TEST_SEARCH_PHRASE}&max=200", await Util.GetTokenAsync("superuser", "l3tm3in")); Util.ValidateDataReturnResponseOk(a); a.ObjectResponse["data"].Value().Should().Contain(TEST_SEARCH_PHRASE.Split(" ")[0]); a.ObjectResponse["data"].Value().Should().Contain(TEST_SEARCH_PHRASE.Split(" ")[1]); @@ -368,36 +328,36 @@ namespace raven_integration //w.tags = InclusiveTagsArray; - //CREATE A WIDGET + //CREATE A PROJECT dynamic D = new JObject(); - D.name = Util.Uniquify("TAG search test WIDGET TAG AND PHRASE"); - D.customFields = Util.WidgetRequiredCustomFieldsJsonString(); + D.name = Util.Uniquify("TAG search test PROJECT TAG AND PHRASE"); + D.dollarAmount = 1.11m; D.active = true; D.usertype = 1; D.notes = "This record will match in notes and tag: elementary my dear aardvark"; D.tags = TagsArray; - ApiResponse a = await Util.PostAsync("widget", await Util.GetTokenAsync("superuser", "l3tm3in"), D.ToString()); + ApiResponse a = await Util.PostAsync("project", await Util.GetTokenAsync("superuser", "l3tm3in"), D.ToString()); Util.ValidateDataReturnResponseOk(a); - long MatchWidgetInNotesId = a.ObjectResponse["data"]["id"].Value(); + long MatchProjectInNotesId = a.ObjectResponse["data"]["id"].Value(); - //CREATE A WIDGET WITH TAG BUT NOT SEARCH PHRASE + //CREATE A PROJECT WITH TAG BUT NOT SEARCH PHRASE D = new JObject(); - D.name = Util.Uniquify("TAG search test WIDGET TAG ONLY"); - D.customFields = Util.WidgetRequiredCustomFieldsJsonString(); + D.name = Util.Uniquify("TAG search test PROJECT TAG ONLY"); + D.dollarAmount = 1.11m; D.active = true; D.usertype = 1; D.notes = "This record will match in tag but no search phrase"; D.tags = TagsArray; - a = await Util.PostAsync("widget", await Util.GetTokenAsync("superuser", "l3tm3in"), D.ToString()); + a = await Util.PostAsync("project", await Util.GetTokenAsync("superuser", "l3tm3in"), D.ToString()); Util.ValidateDataReturnResponseOk(a); - long NoPhraseMatchWidgetInTagId = a.ObjectResponse["data"]["id"].Value(); + long NoPhraseMatchProjectInTagId = a.ObjectResponse["data"]["id"].Value(); @@ -441,9 +401,9 @@ namespace raven_integration } //Ensure the expected items are returned - MatchingIdList.Should().Contain(MatchWidgetInNotesId, "ShouldContainMatchWidgetInNotesId"); + MatchingIdList.Should().Contain(MatchProjectInNotesId, "ShouldContainMatchProjectInNotesId"); MatchingIdList.Should().NotContain(MatchUserInNameId, "ShouldNotContainMatchUserInNameId"); - MatchingIdList.Should().NotContain(NoPhraseMatchWidgetInTagId, "ShouldNotContainNoPhraseMatchWidgetInTagId"); + MatchingIdList.Should().NotContain(NoPhraseMatchProjectInTagId, "ShouldNotContainNoPhraseMatchProjectInTagId"); }//eot @@ -530,22 +490,22 @@ namespace raven_integration [Fact] public async Task SearchForSerialFieldShouldWork() { - //CREATE A WIDGET + //CREATE A PROJECT dynamic D = new JObject(); - D.name = Util.Uniquify("Serial search test WIDGET"); - D.customFields = Util.WidgetRequiredCustomFieldsJsonString(); + D.name = Util.Uniquify("Serial search test PROJECT"); + D.dollarAmount = 1.11m; D.active = true; D.usertype = 1; D.notes = "Test for serial number search"; - ApiResponse a = await Util.PostAsync("widget", await Util.GetTokenAsync("superuser", "l3tm3in"), D.ToString()); + ApiResponse a = await Util.PostAsync("project", await Util.GetTokenAsync("superuser", "l3tm3in"), D.ToString()); Util.ValidateDataReturnResponseOk(a); - long MatchWidgetInSerialId = a.ObjectResponse["data"]["id"].Value(); - var MatchWidgetSerial = a.ObjectResponse["data"]["serial"].Value(); + long MatchProjectInSerialId = a.ObjectResponse["data"]["id"].Value(); + var MatchProjectSerial = a.ObjectResponse["data"]["serial"].Value(); //TODO: get this from the return object - string SerialSearch = MatchWidgetSerial.ToString(); ; + string SerialSearch = MatchProjectSerial.ToString(); ; //Now see if can find those objects with a phrase search @@ -569,7 +529,7 @@ namespace raven_integration } //Ensure the expected items are returned - MatchingIdList.Should().Contain(MatchWidgetInSerialId, "ShouldContainMatchWidgetInSerialId"); + MatchingIdList.Should().Contain(MatchProjectInSerialId, "ShouldContainMatchProjectInSerialId"); @@ -588,7 +548,7 @@ namespace raven_integration [xUnit.net 00:00:21.49] raven_integration.SearchOps.CustomFieldSearchShouldWork [FAIL] X raven_integration.SearchOps.CustomFieldSearchShouldWork [1s 84ms] Error Message: - Expected MatchingIdList {109274L, 109095L, 108919L, 108740L, 108558L, 108382L, 108201L, 108021L, 107842L, 107663L, 107487L, 107305L, 107126L, 106947L, 106768L, 106589L, 106413L, 106233L, 106052L, 105873L, 105692L, 105510L, 105341L, 105157L, 104978L, 104799L, 104620L, 104441L, 104262L, 104084L, 103906L, 103725L, .468 more.} to contain 195378L because ShouldContainMatchingCustomFieldWidgetId. + Expected MatchingIdList {109274L, 109095L, 108919L, 108740L, 108558L, 108382L, 108201L, 108021L, 107842L, 107663L, 107487L, 107305L, 107126L, 106947L, 106768L, 106589L, 106413L, 106233L, 106052L, 105873L, 105692L, 105510L, 105341L, 105157L, 104978L, 104799L, 104620L, 104441L, 104262L, 104084L, 103906L, 103725L, .468 more.} to contain 195378L because ShouldContainMatchingCustomFieldProjectId. Stack Trace: at FluentAssertions.Execution.XUnit2TestFramework.Throw(String message) at FluentAssertions.Execution.TestFrameworkProvider.Throw(String message) @@ -610,18 +570,18 @@ Likely fix is to force order to most recent or simply to delete after test so th dCustomField.c4 = "true"; dCustomField.c5 = "23.45"; - //CREATE A WIDGET + //CREATE A PROJECT dynamic D = new JObject(); - D.name = Util.Uniquify("CUSTOMFIELD search test WIDGET"); + D.name = Util.Uniquify("CUSTOMFIELD search test PROJECT"); D.customFields = dCustomField.ToString(); D.dollarAmount = 1.11m; D.active = true; D.usertype = 1; D.notes = "This record will match in custom field"; - ApiResponse a = await Util.PostAsync("widget", await Util.GetTokenAsync("superuser", "l3tm3in"), D.ToString()); + ApiResponse a = await Util.PostAsync("project", await Util.GetTokenAsync("superuser", "l3tm3in"), D.ToString()); Util.ValidateDataReturnResponseOk(a); - long MatchingWidgetId = a.ObjectResponse["data"]["id"].Value(); + long MatchingProjectId = a.ObjectResponse["data"]["id"].Value(); //Now see if can find this object with a phrase search @@ -646,11 +606,11 @@ Likely fix is to force order to most recent or simply to delete after test so th } //Ensure the expected items are returned - MatchingIdList.Should().Contain(MatchingWidgetId, "ShouldContainMatchingCustomFieldWidgetId"); + MatchingIdList.Should().Contain(MatchingProjectId, "ShouldContainMatchingCustomFieldProjectId"); //Now delete the newly created one so the list doesn't build up and prevent this test from working in big runs... //DELETE - ApiResponse DELETETestResponse = await Util.DeleteAsync("widget/" + MatchingWidgetId.ToString(), await Util.GetTokenAsync("superuser", "l3tm3in")); + ApiResponse DELETETestResponse = await Util.DeleteAsync("project/" + MatchingProjectId.ToString(), await Util.GetTokenAsync("superuser", "l3tm3in")); Util.ValidateHTTPStatusCode(DELETETestResponse, 204); @@ -664,18 +624,18 @@ Likely fix is to force order to most recent or simply to delete after test so th { string TEST_SEARCH_PHRASE = Util.Uniquify("qqwweerrttyy"); - //CREATE A WIDGET + //CREATE A PROJECT dynamic d = new JObject(); - d.name = Util.Uniquify("Wildcard endswith search test WIDGET"); - d.customFields = Util.WidgetRequiredCustomFieldsJsonString(); + d.name = Util.Uniquify("Wildcard endswith search test PROJECT"); + d.dollarAmount = 1.11m; d.active = true; d.usertype = 1; d.notes = $"This record will match in notes: {TEST_SEARCH_PHRASE} there"; - ApiResponse a = await Util.PostAsync("widget", await Util.GetTokenAsync("superuser", "l3tm3in"), d.ToString()); + ApiResponse a = await Util.PostAsync("project", await Util.GetTokenAsync("superuser", "l3tm3in"), d.ToString()); Util.ValidateDataReturnResponseOk(a); - long WidgetId = (long)a.ObjectResponse["data"]["id"]; + long ProjectId = (long)a.ObjectResponse["data"]["id"]; //Now see if can find with a phrase search dynamic SearchParameters = new JObject(); @@ -687,8 +647,8 @@ Likely fix is to force order to most recent or simply to delete after test so th //Now validate the return list (should be only one as it's super unique) ((JArray)a.ObjectResponse["data"]["searchResults"]).Count.Should().Be(1); - //Now delete the widget and re-run the search - a = await Util.DeleteAsync("widget/" + WidgetId.ToString(), await Util.GetTokenAsync("superuser", "l3tm3in")); + //Now delete the project and re-run the search + a = await Util.DeleteAsync("project/" + ProjectId.ToString(), await Util.GetTokenAsync("superuser", "l3tm3in")); Util.ValidateHTTPStatusCode(a, 204); a = await Util.PostAsync("search", await Util.GetTokenAsync("superuser", "l3tm3in"), SearchParameters.ToString());