From 1a6df752204fb19779ffe9baec811b73e2b03fd0 Mon Sep 17 00:00:00 2001 From: Patrick Austin Date: Thu, 21 Nov 2024 16:06:55 +0000 Subject: [PATCH] Use timeout, actual ICAT ids and Long.equals in UserResourceTest #35 --- .../org/icatproject/topcat/IcatClient.java | 28 +++++++++++++++++++ .../icatproject/topcat/UserResourceTest.java | 19 ++++++++----- src/test/resources/run.properties | 1 + 3 files changed, 41 insertions(+), 7 deletions(-) diff --git a/src/main/java/org/icatproject/topcat/IcatClient.java b/src/main/java/org/icatproject/topcat/IcatClient.java index 841b6783..e94e5907 100644 --- a/src/main/java/org/icatproject/topcat/IcatClient.java +++ b/src/main/java/org/icatproject/topcat/IcatClient.java @@ -9,6 +9,7 @@ import org.icatproject.topcat.httpclient.*; import org.icatproject.topcat.exceptions.*; +import org.apache.commons.lang3.StringUtils; import org.icatproject.topcat.domain.*; import jakarta.json.*; @@ -93,6 +94,33 @@ public String getFullName() throws TopcatException { } } + /** + * Gets a single Entity of the specified type, without any other conditions. + * + * @param entityType Type of ICAT Entity to get + * @return A single ICAT Entity of the specified type as a JsonObject + * @throws TopcatException + */ + public JsonObject getEntity(String entityType) throws TopcatException { + try { + String entityCapital = StringUtils.capitalize(entityType.toLowerCase()); + String query = URLEncoder.encode("SELECT o FROM " + entityCapital + " o LIMIT 0, 1", "UTF8"); + String url = "entityManager?sessionId=" + URLEncoder.encode(sessionId, "UTF8") + "&query=" + query; + Response response = httpClient.get(url, new HashMap()); + if(response.getCode() == 404){ + throw new NotFoundException("Could not run getEntity got a 404 response"); + } else if(response.getCode() >= 400){ + throw new BadRequestException(Utils.parseJsonObject(response.toString()).getString("message")); + } + JsonObject entity = Utils.parseJsonArray(response.toString()).getJsonObject(0); + return entity.getJsonObject(entityCapital); + } catch (TopcatException e){ + throw e; + } catch (Exception e) { + throw new BadRequestException(e.getMessage()); + } + } + public List getEntities(String entityType, List entityIds) throws TopcatException { List out = new ArrayList(); try { diff --git a/src/test/java/org/icatproject/topcat/UserResourceTest.java b/src/test/java/org/icatproject/topcat/UserResourceTest.java index 2ee7f646..850fd602 100644 --- a/src/test/java/org/icatproject/topcat/UserResourceTest.java +++ b/src/test/java/org/icatproject/topcat/UserResourceTest.java @@ -88,10 +88,9 @@ public void setup() throws Exception { public void testGetSize() throws Exception { String facilityName = "LILS"; String entityType = "investigation"; - Long entityId = (long) 1; IcatClient icatClient = new IcatClient("https://localhost:8181", sessionId); - - List emptyIds = new ArrayList(); + JsonObject investigation = icatClient.getEntity(entityType); + long entityId = investigation.getInt("id"); Response response = userResource.getSize(facilityName, sessionId, entityType, entityId); @@ -105,6 +104,9 @@ public void testGetSize() throws Exception { @Test public void testCart() throws Exception { String facilityName = "LILS"; + IcatClient icatClient = new IcatClient("https://localhost:8181", sessionId); + JsonObject dataset = icatClient.getEntity("dataset"); + long entityId = dataset.getInt("id"); Response response; @@ -127,7 +129,7 @@ public void testCart() throws Exception { // We assume that there is a dataset with id = 1, and that simple/root can see // it. - response = userResource.addCartItems(facilityName, sessionId, "dataset 1", false); + response = userResource.addCartItems(facilityName, sessionId, "dataset " + entityId, false); assertEquals(200, response.getStatus()); response = userResource.getCart(facilityName, sessionId); @@ -138,7 +140,7 @@ public void testCart() throws Exception { // Again, this ought to be done directly, rather than using the methods we // should be testing independently! - response = userResource.deleteCartItems(facilityName, sessionId, "dataset 1"); + response = userResource.deleteCartItems(facilityName, sessionId, "dataset " + entityId); assertEquals(200, response.getStatus()); assertEquals(0, getCartSize(response)); } @@ -149,6 +151,9 @@ public void testSubmitCart() throws Exception { Response response; JsonObject json; List downloads; + IcatClient icatClient = new IcatClient("https://localhost:8181", sessionId); + JsonObject dataset = icatClient.getEntity("dataset"); + long entityId = dataset.getInt("id"); // Get the initial state of the downloads - may not be empty // It appears queryOffset cannot be empty! @@ -163,7 +168,7 @@ public void testSubmitCart() throws Exception { System.out.println("DEBUG testSubmitCart: initial downloads size: " + initialDownloadsSize); // Put something into the Cart, so we have something to submit - response = userResource.addCartItems(facilityName, sessionId, "dataset 1", false); + response = userResource.addCartItems(facilityName, sessionId, "dataset " + entityId, false); assertEquals(200, response.getStatus()); // Now submit it @@ -318,7 +323,7 @@ private int getCartSize(Response response) throws Exception { private Download findDownload(List downloads, Long downloadId) { for (Download download : downloads) { - if (download.getId() == downloadId) + if (download.getId().equals(downloadId)) return download; } return null; diff --git a/src/test/resources/run.properties b/src/test/resources/run.properties index 8d595686..4cbeefe5 100644 --- a/src/test/resources/run.properties +++ b/src/test/resources/run.properties @@ -4,6 +4,7 @@ facility.LILS.icatUrl = https://localhost:8181 facility.LILS.idsUrl = https://localhost:8181 adminUserNames=simple/root anonUserName=anon/anon +ids.timeout=10s # Disable scheduled Download status checks (DO THIS FOR TESTS ONLY!) test.disableDownloadStatusChecks = true