From e20cfa3021ddd2d1cfc7e99e734d8d434fe41a0f Mon Sep 17 00:00:00 2001 From: Sanoj Punchihewa Date: Mon, 16 Dec 2024 11:11:03 +0530 Subject: [PATCH] Normalize the JSON for Comparison --- .../test/v2/ScatterGatherTestCase.java | 42 +++++++++++++++++-- 1 file changed, 39 insertions(+), 3 deletions(-) diff --git a/integration/mediation-tests/tests-mediator-1/src/test/java/org/wso2/carbon/esb/mediator/test/v2/ScatterGatherTestCase.java b/integration/mediation-tests/tests-mediator-1/src/test/java/org/wso2/carbon/esb/mediator/test/v2/ScatterGatherTestCase.java index e9cc18d579..b4e92a7a67 100644 --- a/integration/mediation-tests/tests-mediator-1/src/test/java/org/wso2/carbon/esb/mediator/test/v2/ScatterGatherTestCase.java +++ b/integration/mediation-tests/tests-mediator-1/src/test/java/org/wso2/carbon/esb/mediator/test/v2/ScatterGatherTestCase.java @@ -19,6 +19,7 @@ package org.wso2.carbon.esb.mediator.test.v2; import com.google.gson.JsonElement; +import com.google.gson.JsonObject; import com.google.gson.JsonParser; import org.apache.http.HttpResponse; import org.testng.Assert; @@ -37,6 +38,7 @@ import javax.xml.parsers.ParserConfigurationException; import static org.testng.Assert.assertEquals; +import static org.testng.Assert.assertTrue; public class ScatterGatherTestCase extends ESBIntegrationTest { @@ -79,7 +81,7 @@ public void testScatterGatherJSONBodyReplace() throws IOException { JsonElement responseJSON = JsonParser.parseString(responsePayload); JsonElement expectedJSON = JsonParser.parseString(expectedResponse); - assertEquals(responseJSON, expectedJSON, "Response payload mismatched"); + assertTrue(areJsonElementsEquivalent(expectedJSON, responseJSON), "Response payload mismatched"); } @Test(groups = {"wso2.esb"}, description = "Testing Scatter-Gather mediator with JSON and variable output") @@ -105,6 +107,7 @@ public void testScatterGatherJSONVariableOutput() throws IOException, Interrupte "{\"name\":\"pet2\",\"type\":\"cat\",\"requestId\":1114567},{\"name\":\"pet3\",\"type\":\"mock-backend\"," + "\"requestId\":1114567}]", DEFAULT_TIMEOUT); Assert.assertTrue(logFound, "Scatter Gather result not set to variable"); + carbonLogReader.stop(); } @Test(groups = {"wso2.esb"}, description = "Testing Scatter-Gather mediator with XML body replace") @@ -155,6 +158,7 @@ public void testScatterGatherXMLVariableOutput() throws IOException, Interrupted "78658pet2dog78658" + "", DEFAULT_TIMEOUT); Assert.assertTrue(logFound, "Scatter Gather result not set to variable"); + carbonLogReader.stop(); } @Test(groups = {"wso2.esb"}, description = "Testing Scatter-Gather mediator with Aggregation condition") @@ -183,7 +187,7 @@ public void testScatterGatherJSONCondition() throws IOException { JsonElement responseJSON = JsonParser.parseString(responsePayload); JsonElement expectedJSON = JsonParser.parseString(expectedResponse); - assertEquals(responseJSON, expectedJSON, "Response payload mismatched"); + assertTrue(areJsonElementsEquivalent(expectedJSON, responseJSON), "Response payload mismatched"); } @Test(groups = {"wso2.esb"}, description = "Testing Scatter-Gather mediator when a path fails") @@ -212,7 +216,39 @@ public void testScatterGatherJSON404EPClone() throws IOException { JsonElement responseJSON = JsonParser.parseString(responsePayload); JsonElement expectedJSON = JsonParser.parseString(expectedResponse); - assertEquals(responseJSON, expectedJSON, "Response payload mismatched"); + assertTrue(areJsonElementsEquivalent(expectedJSON, responseJSON), "Response payload mismatched"); + } + + private static boolean areJsonElementsEquivalent(JsonElement e1, JsonElement e2) { + + if (e1.isJsonObject() && e2.isJsonObject()) { + JsonObject obj1 = e1.getAsJsonObject(); + JsonObject obj2 = e2.getAsJsonObject(); + + if (obj1.size() != obj2.size()) { + return false; + } + + for (String key : obj1.keySet()) { + if (!obj2.has(key) || !areJsonElementsEquivalent(obj1.get(key), obj2.get(key))) { + return false; + } + } + return true; + } else if (e1.isJsonArray() && e2.isJsonArray()) { + if (e1.getAsJsonArray().size() != e2.getAsJsonArray().size()) { + return false; + } + + for (int i = 0; i < e1.getAsJsonArray().size(); i++) { + if (!areJsonElementsEquivalent(e1.getAsJsonArray().get(i), e2.getAsJsonArray().get(i))) { + return false; + } + } + return true; + } else { + return e1.equals(e2); + } } private static Document parseXML(String xml) throws IOException, ParserConfigurationException, SAXException {