From 9536e41b3854457f8198ba788e503e08e7e652e4 Mon Sep 17 00:00:00 2001 From: Marc Johnson Date: Wed, 20 Dec 2017 11:51:41 +0000 Subject: [PATCH] Ignore example of sorting fixed due date schedules by name with different cases As this fails on MacOS due to different colation mechanism for UTF-8 --- .../folio/rest/api/FixedDueDateApiTest.java | 136 +++++++++++------- .../folio/rest/api/LoanPoliciesApiTest.java | 2 +- 2 files changed, 89 insertions(+), 49 deletions(-) diff --git a/src/test/java/org/folio/rest/api/FixedDueDateApiTest.java b/src/test/java/org/folio/rest/api/FixedDueDateApiTest.java index f314621ee..3796e06d1 100644 --- a/src/test/java/org/folio/rest/api/FixedDueDateApiTest.java +++ b/src/test/java/org/folio/rest/api/FixedDueDateApiTest.java @@ -1,7 +1,13 @@ package org.folio.rest.api; -import static org.hamcrest.MatcherAssert.assertThat; -import static org.hamcrest.core.Is.is; +import io.vertx.core.json.JsonArray; +import io.vertx.core.json.JsonObject; +import org.folio.rest.support.*; +import org.hamcrest.junit.MatcherAssert; +import org.junit.After; +import org.junit.Before; +import org.junit.Ignore; +import org.junit.Test; import java.io.UnsupportedEncodingException; import java.net.HttpURLConnection; @@ -15,20 +21,9 @@ import java.util.concurrent.TimeUnit; import java.util.concurrent.TimeoutException; -import org.folio.rest.support.HttpClient; -import org.folio.rest.support.IndividualResource; -import org.folio.rest.support.JsonArrayHelper; -import org.folio.rest.support.JsonResponse; -import org.folio.rest.support.Response; -import org.folio.rest.support.ResponseHandler; -import org.folio.rest.support.TextResponse; -import org.hamcrest.junit.MatcherAssert; -import org.junit.After; -import org.junit.Before; -import org.junit.Test; - -import io.vertx.core.json.JsonArray; -import io.vertx.core.json.JsonObject; +import static org.folio.rest.api.LoanPoliciesApiTest.loanPolicyStorageUrl; +import static org.hamcrest.MatcherAssert.assertThat; +import static org.hamcrest.core.Is.is; /** * @author shale @@ -37,7 +32,7 @@ public class FixedDueDateApiTest { private static final String TABLE_NAME = "fixed_due_date_schedule"; - protected static final String SCHEDULE_SECTION = "schedules"; + static final String SCHEDULE_SECTION = "schedules"; private static HttpClient client = new HttpClient(StorageTestSuite.getVertx()); @Before @@ -46,7 +41,8 @@ public void beforeEach() ExecutionException, TimeoutException, MalformedURLException { - System.out.println("attempting full delete FixedDueDateApiTest....."); + + StorageTestSuite.deleteAll(loanPolicyStorageUrl()); StorageTestSuite.deleteAll(dueDateURL()); } @@ -239,9 +235,6 @@ public void canCreateSchedule() getCompleted4Response.getStatusCode(), is(HttpURLConnection.HTTP_OK)); assertThat(getCompleted4Response.getJson().getString("name"), is("semester2")); - canSortByNameAscending(); - canSortByNameDescending(); - //// delete by id /////////////////////// CompletableFuture delCompleted = new CompletableFuture<>(); client.delete(dueDateURL("/"+newId2), StorageTestSuite.TENANT_ID, @@ -289,13 +282,13 @@ public void canCreateSchedule() get2CompletedResponse.getStatusCode(), is(HttpURLConnection.HTTP_OK)); assertThat(get2CompletedResponse.getJson().getJsonArray("fixedDueDateSchedules").size(), is(2)); - ///// delete all items //////////////////////////////// + //// try to delete all fdds (uses cascade so will succeed) /////////////////////// CompletableFuture delAllCompleted = new CompletableFuture<>(); client.delete(dueDateURL(), StorageTestSuite.TENANT_ID, ResponseHandler.empty(delAllCompleted)); Response delAllCompleted4Response = delAllCompleted.get(5, TimeUnit.SECONDS); assertThat(String.format("Failed to delete due date: %s", dueDateURL()), - delAllCompleted4Response.getStatusCode(), is(500)); + delAllCompleted4Response.getStatusCode(), is(204)); //////////////////////////////////////////////////////// //// get , should have 0 records /////////////////////// @@ -305,21 +298,21 @@ public void canCreateSchedule() JsonResponse get3CompletedResponse = get3Completed.get(5, TimeUnit.SECONDS); assertThat(String.format("Failed to get due date: %s", get3CompletedResponse.getJson().encodePrettily()), get3CompletedResponse.getStatusCode(), is(HttpURLConnection.HTTP_OK)); - assertThat(get3CompletedResponse.getJson().getJsonArray("fixedDueDateSchedules").size(), is(2)); + assertThat(get3CompletedResponse.getJson().getJsonArray("fixedDueDateSchedules").size(), is(0)); } - //Fails on Mac OS due to differences in UTF-8 collation libraries - - public void canSortByNameAscending() + @Ignore("Fails on Mac OS due to differences in UTF-8 collation libraries") + @Test + public void canSortDifferentCaseNamesAscending() throws InterruptedException, MalformedURLException, TimeoutException, ExecutionException, UnsupportedEncodingException { - //createFixedDueDateSchedule(createFixedDueDate("quarterly")); - //createFixedDueDateSchedule(createFixedDueDate("Semester")); - //createFixedDueDateSchedule(createFixedDueDate("semester2")); + createFixedDueDateSchedule(createFixedDueDate("quarterly")); + createFixedDueDateSchedule(createFixedDueDate("Semester")); + createFixedDueDateSchedule(createFixedDueDate("semester2")); URL sortUrl = dueDateURL("?query=name=*" + URLEncoder.encode(" sortBy name/sort.ascending", "UTF-8")); @@ -346,20 +339,20 @@ public void canSortByNameAscending() assertThat(results.get(0).getString("name"), is("quarterly")); } - - public void canSortByNameDescending() + @Test + public void canSortByNameAscending() throws InterruptedException, MalformedURLException, TimeoutException, ExecutionException, UnsupportedEncodingException { - //createFixedDueDateSchedule(createFixedDueDate("quarterly")); - //createFixedDueDateSchedule(createFixedDueDate("Semester")); - //createFixedDueDateSchedule(createFixedDueDate("semester2")); + createFixedDueDateSchedule(createFixedDueDate("quarterly")); + createFixedDueDateSchedule(createFixedDueDate("semester")); + createFixedDueDateSchedule(createFixedDueDate("semester2")); URL sortUrl = dueDateURL("?query=name=*" - + URLEncoder.encode(" sortBy name/sort.descending", "UTF-8")); + + URLEncoder.encode(" sortBy name/sort.ascending", "UTF-8")); CompletableFuture getCompleted = new CompletableFuture<>(); @@ -375,14 +368,47 @@ public void canSortByNameDescending() List results = JsonArrayHelper.toList(getResponse.getJson() .getJsonArray("fixedDueDateSchedules")); - System.out.println("Ascending Results"); - results.stream() .map(result -> result.getString("name")) .forEachOrdered(System.out::println); + assertThat(results.size(), is(3)); + assertThat(results.get(0).getString("name"), is("quarterly")); + assertThat(results.get(2).getString("name"), is("semester2")); + } + + @Test + public void canSortByNameDescending() + throws InterruptedException, + MalformedURLException, + TimeoutException, + ExecutionException, + UnsupportedEncodingException { + + createFixedDueDateSchedule(createFixedDueDate("quarterly")); + createFixedDueDateSchedule(createFixedDueDate("semester")); + createFixedDueDateSchedule(createFixedDueDate("semester2")); + + URL sortUrl = dueDateURL("?query=name=*" + + URLEncoder.encode(" sortBy name/sort.descending", "UTF-8")); + + CompletableFuture getCompleted = new CompletableFuture<>(); + + client.get(sortUrl, StorageTestSuite.TENANT_ID, + ResponseHandler.json(getCompleted)); + + JsonResponse getResponse = getCompleted.get(5, TimeUnit.SECONDS); + + assertThat(String.format("Failed to get fixed due date schedules: %s", + getResponse.getJson().encodePrettily()), + getResponse.getStatusCode(), is(HttpURLConnection.HTTP_OK)); + + List results = JsonArrayHelper.toList(getResponse.getJson() + .getJsonArray("fixedDueDateSchedules")); + assertThat(results.size(), is(3)); assertThat(results.get(0).getString("name"), is("semester2")); + assertThat(results.get(2).getString("name"), is("quarterly")); } protected static URL dueDateURL() throws MalformedURLException { @@ -392,34 +418,48 @@ protected static URL dueDateURL() throws MalformedURLException { protected static URL dueDateURL(String subPath) throws MalformedURLException { - return StorageTestSuite.storageUrl("/fixed-due-date-schedule-storage/fixed-due-date-schedules" + subPath); + return StorageTestSuite.storageUrl( + "/fixed-due-date-schedule-storage/fixed-due-date-schedules" + subPath); } - protected static JsonObject createSchedule(String from, String to, String due){ + protected static JsonObject createSchedule( + String from, + String to, + String due) { + JsonObject jo = new JsonObject(); - if(from != null){ + + if(from != null) { jo.put("from", from); } - if(to != null){ + if(to != null) { jo.put("to", to); } - if(from != null){ + if(from != null) { jo.put("due", due); } return jo; } - protected static JsonObject createFixedDueDate(String id, String name, String desc){ + protected static JsonObject createFixedDueDate( + String id, + String name, + String desc) { + JsonObject jo = new JsonObject(); - if(id != null){ + + if(id != null) { jo.put("id", id); } - if(name != null){ + + if(name != null) { jo.put("name", name); } - if(desc != null){ + + if(desc != null) { jo.put("description", desc); } + return jo; } @@ -433,7 +473,7 @@ private IndividualResource createFixedDueDateSchedule(JsonObject request) ExecutionException, TimeoutException { - CompletableFuture createCompleted = new CompletableFuture(); + CompletableFuture createCompleted = new CompletableFuture<>(); client.post(dueDateURL(), request, StorageTestSuite.TENANT_ID, ResponseHandler.json(createCompleted)); diff --git a/src/test/java/org/folio/rest/api/LoanPoliciesApiTest.java b/src/test/java/org/folio/rest/api/LoanPoliciesApiTest.java index 714586977..5bbf83408 100644 --- a/src/test/java/org/folio/rest/api/LoanPoliciesApiTest.java +++ b/src/test/java/org/folio/rest/api/LoanPoliciesApiTest.java @@ -585,7 +585,7 @@ public void canDeleteALoanPolicy() getResponse.getStatusCode(), is(HttpURLConnection.HTTP_NOT_FOUND)); } - private static URL loanPolicyStorageUrl() throws MalformedURLException { + static URL loanPolicyStorageUrl() throws MalformedURLException { return loanPolicyStorageUrl(""); }