diff --git a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCast2Test.java b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCast2Test.java index eb8e510d404..a2db314b027 100644 --- a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCast2Test.java +++ b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCast2Test.java @@ -15,13 +15,11 @@ package org.finos.legend.engine.changetoken.generation; import com.fasterxml.jackson.core.JsonProcessingException; -import org.junit.Assert; import org.junit.BeforeClass; import org.junit.Test; import java.io.IOException; import java.lang.reflect.InvocationTargetException; -import java.util.Map; public class GenerateCast2Test extends GenerateCastTestBase { @@ -63,23 +61,19 @@ public static void setupSuite() throws IOException, ClassNotFoundException @Test public void testUpcast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = "{\n" + - " \"version\": \"ftdm:abcdefg123\",\n" + - " \"@type\": \"meta::pure::changetoken::tests::SomeClassWithAnArray\",\n" + - " \"array\": [\n" + - " {\n" + - " \"@type\": \"meta::pure::changetoken::tests::OuterClass\",\n" + - " \"existingValue\": \"someValue\",\n" + - " \"innerObject\": {\n" + - " \"@type\": \"meta::pure::changetoken::tests::SampleClass\"\n" + - " }\n" + - " }\n" + - " ]\n" + - "}\n"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("upcast", Map.class).invoke(null, jsonNode); - - Map expectedJsonNodeOut = mapper.readValue( + expect(upcast("{\n" + + " \"version\": \"ftdm:abcdefg123\",\n" + + " \"@type\": \"meta::pure::changetoken::tests::SomeClassWithAnArray\",\n" + + " \"array\": [\n" + + " {\n" + + " \"@type\": \"meta::pure::changetoken::tests::OuterClass\",\n" + + " \"existingValue\": \"someValue\",\n" + + " \"innerObject\": {\n" + + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\"\n" + + " }\n" + + " }\n" + + " ]\n" + + "}\n"), "{\n" + " \"version\": \"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SomeClassWithAnArray\",\n" + @@ -93,18 +87,13 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " }\n" + " }\n" + " ]\n" + - "}\n", Map.class); // copied 'someValue' from '../existingValue' - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - - // assert that the input is not mutated - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::OuterClass\",\n" + " \"existingValue\": \"someValue\",\n" + @@ -112,19 +101,12 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"abc\": \"someValue\"\n" + " }\n" + - "}\n"; - Map jsonNode = mapper.readValue(input, Map.class); - - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class).invoke(null, jsonNode, "ftdm:abcdefg123"); - - Map expectedJsonNodeOut = mapper.readValue( + "}\n", "ftdm:abcdefg123"), "{\n" + " \"version\":\"ftdm:abcdefg123\",\n" + " \"@type\": \"meta::pure::changetoken::tests::OuterClass\",\n" + " \"existingValue\": \"someValue\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}\n" + - "}\n", Map.class); // moved 'someValue' to '../existingValue' - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } } diff --git a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCast3Test.java b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCast3Test.java index adf0e20ef7b..bcf81fec6c3 100644 --- a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCast3Test.java +++ b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCast3Test.java @@ -15,13 +15,11 @@ package org.finos.legend.engine.changetoken.generation; import com.fasterxml.jackson.core.JsonProcessingException; -import org.junit.Assert; import org.junit.BeforeClass; import org.junit.Test; import java.io.IOException; import java.lang.reflect.InvocationTargetException; -import java.util.Map; public class GenerateCast3Test extends GenerateCastTestBase { @@ -56,24 +54,20 @@ public static void setupSuite() throws IOException, ClassNotFoundException @Test public void testUpcast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = "{\n" + - " \"version\": \"ftdm:abcdefg123\",\n" + - " \"@type\": \"meta::pure::changetoken::tests::SomeClassWithAnArray\",\n" + - " \"array\": [\n" + - " {\n" + - " \"@type\": \"meta::pure::changetoken::tests::OuterClass\",\n" + - " \"existingValue\": \"someValue\",\n" + - " \"innerObject\": {\n" + - " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + - " \"abc\": 123\n" + - " }\n" + - " }\n" + - " ]\n" + - "}\n"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("upcast", Map.class).invoke(null, jsonNode); - - Map expectedJsonNodeOut = mapper.readValue( + expect(upcast("{\n" + + " \"version\": \"ftdm:abcdefg123\",\n" + + " \"@type\": \"meta::pure::changetoken::tests::SomeClassWithAnArray\",\n" + + " \"array\": [\n" + + " {\n" + + " \"@type\": \"meta::pure::changetoken::tests::OuterClass\",\n" + + " \"existingValue\": \"someValue\",\n" + + " \"innerObject\": {\n" + + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + + " \"abc\": 123\n" + + " }\n" + + " }\n" + + " ]\n" + + "}\n"), "{\n" + " \"version\": \"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SomeClassWithAnArray\",\n" + @@ -87,36 +81,26 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " }\n" + " }\n" + " ]\n" + - "}\n", Map.class); // 123 converted to "123" - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - - // assert that the input is not mutated - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = "{\n" + - " \"version\": \"ftdm:abcdefg456\",\n" + - " \"@type\": \"meta::pure::changetoken::tests::SomeClassWithAnArray\",\n" + - " \"array\": [\n" + - " {\n" + - " \"@type\": \"meta::pure::changetoken::tests::OuterClass\",\n" + - " \"existingValue\": \"someValue\",\n" + - " \"innerObject\": {\n" + - " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + - " \"abc\": \"123\"\n" + - " }\n" + - " }\n" + - " ]\n" + - "}\n"; - Map jsonNode = mapper.readValue(input, Map.class); - - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class).invoke(null, jsonNode, "ftdm:abcdefg123"); -// Map jsonNodeOut = TempGenerated.downcast(jsonNode, "ftdm:abcdefg123"); - - Map expectedJsonNodeOut = mapper.readValue( + expect(downcast("{\n" + + " \"version\": \"ftdm:abcdefg456\",\n" + + " \"@type\": \"meta::pure::changetoken::tests::SomeClassWithAnArray\",\n" + + " \"array\": [\n" + + " {\n" + + " \"@type\": \"meta::pure::changetoken::tests::OuterClass\",\n" + + " \"existingValue\": \"someValue\",\n" + + " \"innerObject\": {\n" + + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + + " \"abc\": \"123\"\n" + + " }\n" + + " }\n" + + " ]\n" + + "}\n", "ftdm:abcdefg123"), "{\n" + " \"version\": \"ftdm:abcdefg123\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SomeClassWithAnArray\",\n" + @@ -130,10 +114,6 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " }\n" + " }\n" + " ]\n" + - "}\n", Map.class); // "123" converted to 123 - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - - // assert that the input is not mutated - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } } diff --git a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCast4Test.java b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCast4Test.java index abefa9ef9d5..44440ecbb1f 100644 --- a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCast4Test.java +++ b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCast4Test.java @@ -15,13 +15,11 @@ package org.finos.legend.engine.changetoken.generation; import com.fasterxml.jackson.core.JsonProcessingException; -import org.junit.Assert; import org.junit.BeforeClass; import org.junit.Test; import java.io.IOException; import java.lang.reflect.InvocationTargetException; -import java.util.Map; public class GenerateCast4Test extends GenerateCastTestBase { @@ -56,24 +54,20 @@ public static void setupSuite() throws IOException, ClassNotFoundException @Test public void testUpcast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = "{\n" + - " \"version\": \"ftdm:abcdefg123\",\n" + - " \"@type\": \"meta::pure::changetoken::tests::SomeClassWithAnArray\",\n" + - " \"array\": [\n" + - " {\n" + - " \"@type\": \"meta::pure::changetoken::tests::OuterClass\",\n" + - " \"existingValue\": \"someValue\",\n" + - " \"innerObject\": {\n" + - " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + - " \"abc\": 123\n" + - " }\n" + - " }\n" + - " ]\n" + - "}\n"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("upcast", Map.class).invoke(null, jsonNode); - - Map expectedJsonNodeOut = mapper.readValue( + expect(upcast("{\n" + + " \"version\": \"ftdm:abcdefg123\",\n" + + " \"@type\": \"meta::pure::changetoken::tests::SomeClassWithAnArray\",\n" + + " \"array\": [\n" + + " {\n" + + " \"@type\": \"meta::pure::changetoken::tests::OuterClass\",\n" + + " \"existingValue\": \"someValue\",\n" + + " \"innerObject\": {\n" + + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + + " \"abc\": 123\n" + + " }\n" + + " }\n" + + " ]\n" + + "}\n"), "{\n" + " \"version\": \"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SomeClassWithAnArray\",\n" + @@ -87,36 +81,26 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " }\n" + " }\n" + " ]\n" + - "}\n", Map.class); // 123 converted to 123 optional - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - - // assert that the input is not mutated - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = "{\n" + - " \"version\": \"ftdm:abcdefg456\",\n" + - " \"@type\": \"meta::pure::changetoken::tests::SomeClassWithAnArray\",\n" + - " \"array\": [\n" + - " {\n" + - " \"@type\": \"meta::pure::changetoken::tests::OuterClass\",\n" + - " \"existingValue\": \"someValue\",\n" + - " \"innerObject\": {\n" + - " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + - " \"abc\": \"123\"\n" + - " }\n" + - " }\n" + - " ]\n" + - "}\n"; - Map jsonNode = mapper.readValue(input, Map.class); - - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class).invoke(null, jsonNode, "ftdm:abcdefg123"); -// Map jsonNodeOut = TempGenerated.downcast(jsonNode, "ftdm:abcdefg123"); - - Map expectedJsonNodeOut = mapper.readValue( + expect(downcast("{\n" + + " \"version\": \"ftdm:abcdefg456\",\n" + + " \"@type\": \"meta::pure::changetoken::tests::SomeClassWithAnArray\",\n" + + " \"array\": [\n" + + " {\n" + + " \"@type\": \"meta::pure::changetoken::tests::OuterClass\",\n" + + " \"existingValue\": \"someValue\",\n" + + " \"innerObject\": {\n" + + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + + " \"abc\": \"123\"\n" + + " }\n" + + " }\n" + + " ]\n" + + "}\n", "ftdm:abcdefg123"), "{\n" + " \"version\": \"ftdm:abcdefg123\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SomeClassWithAnArray\",\n" + @@ -130,10 +114,6 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " }\n" + " }\n" + " ]\n" + - "}\n", Map.class); // "123" optional converted to "123" - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - - // assert that the input is not mutated - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } } diff --git a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastBooleanStringTest.java b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastBooleanStringTest.java index 850ce32b872..f1218adb444 100644 --- a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastBooleanStringTest.java +++ b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastBooleanStringTest.java @@ -15,17 +15,11 @@ package org.finos.legend.engine.changetoken.generation; import com.fasterxml.jackson.core.JsonProcessingException; -import com.fasterxml.jackson.databind.ObjectMapper; -import org.junit.Assert; import org.junit.BeforeClass; import org.junit.Test; import java.io.IOException; import java.lang.reflect.InvocationTargetException; -import java.lang.reflect.Method; -import java.util.Map; - -import static org.junit.Assert.assertThrows; public class GenerateCastBooleanStringTest extends GenerateCastTestBase { @@ -64,8 +58,7 @@ public static void setupSuite() throws IOException, ClassNotFoundException @Test public void testUpcast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"},\n" + @@ -73,11 +66,7 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}, \n" + " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}]\n" + " ]\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("upcast", Map.class).invoke(null, jsonNode); - - Map expectedJsonNodeOut = mapper.readValue( + "}"), "{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -87,16 +76,13 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": true}]\n" + " ],\n" + " \"abc\": true\n" + - "}", Map.class); // updated version and new default value field added - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": true},\n" + @@ -105,11 +91,7 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": true}]\n" + " ],\n" + " \"abc\": true\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class) - .invoke(null, jsonNode, "ftdm:abcdefg123"); - Map expectedJsonNodeOut = mapper.readValue( + "}", "ftdm:abcdefg123"), "{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -118,16 +100,13 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}, \n" + " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}]\n" + " ]\n" + - "}", Map.class); // remove default values - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncastNonDefault() throws JsonProcessingException, NoSuchMethodException { - String input = - "{\n" + + exception(() -> downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": true},\n" + @@ -136,11 +115,7 @@ public void testDowncastNonDefault() throws JsonProcessingException, NoSuchMetho " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": true}]\n" + " ],\n" + " \"abc\": false\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Method downcastMethod = compiledClass.getMethod("downcast", Map.class, String.class); - InvocationTargetException re = assertThrows("non-default", InvocationTargetException.class, () -> downcastMethod.invoke(null, jsonNode, "ftdm:abcdefg123")); - Assert.assertEquals("Cannot remove non-default value:false", re.getCause().getMessage()); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}", "ftdm:abcdefg123"), + "Cannot remove non-default value:false"); } } diff --git a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastBooleanTest.java b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastBooleanTest.java index eaffd6b2806..73af6a72109 100644 --- a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastBooleanTest.java +++ b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastBooleanTest.java @@ -15,17 +15,11 @@ package org.finos.legend.engine.changetoken.generation; import com.fasterxml.jackson.core.JsonProcessingException; -import com.fasterxml.jackson.databind.ObjectMapper; -import org.junit.Assert; import org.junit.BeforeClass; import org.junit.Test; import java.io.IOException; import java.lang.reflect.InvocationTargetException; -import java.lang.reflect.Method; -import java.util.Map; - -import static org.junit.Assert.assertThrows; public class GenerateCastBooleanTest extends GenerateCastTestBase { @@ -64,8 +58,7 @@ public static void setupSuite() throws IOException, ClassNotFoundException @Test public void testUpcast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"},\n" + @@ -73,11 +66,7 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}, \n" + " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}]\n" + " ]\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("upcast", Map.class).invoke(null, jsonNode); - - Map expectedJsonNodeOut = mapper.readValue( + "}"), "{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -87,16 +76,13 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": true}]\n" + " ],\n" + " \"abc\": true\n" + - "}", Map.class); // updated version and new default value field added - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": true},\n" + @@ -105,11 +91,7 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": true}]\n" + " ],\n" + " \"abc\": true\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class) - .invoke(null, jsonNode, "ftdm:abcdefg123"); - Map expectedJsonNodeOut = mapper.readValue( + "}", "ftdm:abcdefg123"), "{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -118,16 +100,13 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}, \n" + " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}]\n" + " ]\n" + - "}", Map.class); // remove default values - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncastNonDefault() throws JsonProcessingException, NoSuchMethodException { - String input = - "{\n" + + exception(() -> downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": true},\n" + @@ -136,11 +115,7 @@ public void testDowncastNonDefault() throws JsonProcessingException, NoSuchMetho " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": true}]\n" + " ],\n" + " \"abc\": false\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Method downcastMethod = compiledClass.getMethod("downcast", Map.class, String.class); - InvocationTargetException re = assertThrows("non-default", InvocationTargetException.class, () -> downcastMethod.invoke(null, jsonNode, "ftdm:abcdefg123")); - Assert.assertEquals("Cannot remove non-default value:false", re.getCause().getMessage()); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}", "ftdm:abcdefg123"), + "Cannot remove non-default value:false"); } } diff --git a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastChainTest.java b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastChainTest.java index af8d0cc12ec..bf8d11307e0 100644 --- a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastChainTest.java +++ b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastChainTest.java @@ -15,19 +15,14 @@ package org.finos.legend.engine.changetoken.generation; import com.fasterxml.jackson.core.JsonProcessingException; -import com.fasterxml.jackson.databind.ObjectMapper; import org.junit.Assert; import org.junit.BeforeClass; import org.junit.Test; import java.io.IOException; import java.lang.reflect.InvocationTargetException; -import java.lang.reflect.Method; import java.util.Arrays; import java.util.List; -import java.util.Map; - -import static org.junit.Assert.assertThrows; public class GenerateCastChainTest extends GenerateCastTestBase { @@ -92,8 +87,7 @@ public void testVersions() throws NoSuchMethodException, InvocationTargetExcepti @Test public void testUpcast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"},\n" + @@ -101,11 +95,7 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}, \n" + " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}]\n" + " ]\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("upcast", Map.class).invoke(null, jsonNode); - - Map expectedJsonNodeOut = mapper.readValue( + "}"), "{\n" + " \"version\":\"ftdm:abcdefg789\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -115,16 +105,13 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": 100, \"def\": 200}]\n" + " ],\n" + " \"abc\": 100, \"def\": 200\n" + - "}", Map.class); // updated version and new default value field added - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(downcast("{\n" + " \"version\":\"ftdm:abcdefg789\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": 100, \"def\": 200},\n" + @@ -133,11 +120,7 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": 100, \"def\": 200}]\n" + " ],\n" + " \"abc\": 100, \"def\": 200\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class) - .invoke(null, jsonNode, "ftdm:abcdefg123"); - Map expectedJsonNodeOut = mapper.readValue( + "}", "ftdm:abcdefg123"), "{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -146,16 +129,13 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}, \n" + " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}]\n" + " ]\n" + - "}", Map.class); // remove default values - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncastNonDefault() throws JsonProcessingException, NoSuchMethodException { - String input = - "{\n" + + exception(() -> downcast("{\n" + " \"version\":\"ftdm:abcdefg789\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": 100, \"def\": 200},\n" + @@ -164,11 +144,7 @@ public void testDowncastNonDefault() throws JsonProcessingException, NoSuchMetho " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": 100, \"def\": 200}]\n" + " ],\n" + " \"abc\": 100, \"def\": 300\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Method downcastMethod = compiledClass.getMethod("downcast", Map.class, String.class); - InvocationTargetException re = assertThrows("non-default", InvocationTargetException.class, () -> downcastMethod.invoke(null, jsonNode, "ftdm:abcdefg123")); - Assert.assertEquals("Cannot remove non-default value:300", re.getCause().getMessage()); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}", "ftdm:abcdefg123"), + "Cannot remove non-default value:300"); } } diff --git a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastCustomMapTest.java b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastCustomMapTest.java index 241a46cb52a..d72f00fbd06 100644 --- a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastCustomMapTest.java +++ b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastCustomMapTest.java @@ -15,17 +15,11 @@ package org.finos.legend.engine.changetoken.generation; import com.fasterxml.jackson.core.JsonProcessingException; -import com.fasterxml.jackson.databind.ObjectMapper; -import org.junit.Assert; import org.junit.BeforeClass; import org.junit.Test; import java.io.IOException; import java.lang.reflect.InvocationTargetException; -import java.lang.reflect.Method; -import java.util.Map; - -import static org.junit.Assert.assertThrows; public class GenerateCastCustomMapTest extends GenerateCastTestBase { @@ -38,8 +32,7 @@ public static void setupSuite() throws IOException, ClassNotFoundException @Test public void testUpcast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"},\n" + @@ -47,11 +40,7 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}, \n" + " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}]\n" + " ]\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("upcast", Map.class).invoke(null, jsonNode); - - Map expectedJsonNodeOut = mapper.readValue( + "}"), "{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -61,16 +50,13 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"restricted\":true, \"range\":{\"min\":-1, \"max\":1, \"@type\":\"intMinMax\", \"round\":0.5}, \"value\":0}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"restricted\":true, \"range\":{\"min\":-1, \"max\":1, \"@type\":\"intMinMax\", \"round\":0.5}, \"value\":0}}\n" + - "}", Map.class); // updated version and new default value field added - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"restricted\":true, \"range\":{\"min\":-1, \"max\":1, \"@type\":\"intMinMax\", \"round\":0.5}, \"value\":0}},\n" + @@ -79,11 +65,7 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"restricted\":true, \"range\":{\"min\":-1, \"max\":1, \"@type\":\"intMinMax\", \"round\":0.5}, \"value\":0}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"restricted\":true, \"range\":{\"min\":-1, \"max\":1, \"@type\":\"intMinMax\", \"round\":0.5}, \"value\":0}}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class) - .invoke(null, jsonNode, "ftdm:abcdefg123"); - Map expectedJsonNodeOut = mapper.readValue( + "}", "ftdm:abcdefg123"), "{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -92,16 +74,13 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}, \n" + " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}]\n" + " ]\n" + - "}", Map.class); // remove default values - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncastNonDefault() throws JsonProcessingException, NoSuchMethodException { - String input = - "{\n" + + exception(() -> downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"restricted\":true, \"range\":{\"min\":-1, \"max\":1, \"@type\":\"intMinMax\", \"round\":0.5}, \"value\":0}},\n" + @@ -110,11 +89,7 @@ public void testDowncastNonDefault() throws JsonProcessingException, NoSuchMetho " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"restricted\":true, \"range\":{\"min\":-1, \"max\":1, \"@type\":\"intMinMax\", \"round\":0.5}, \"value\":0}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"restricted\":true, \"range\":{\"min\":-1, \"max\":1, \"@type\":\"intMinMax\", \"round\":0.0}, \"value\":1}}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Method downcastMethod = compiledClass.getMethod("downcast", Map.class, String.class); - InvocationTargetException re = assertThrows("non-default", InvocationTargetException.class, () -> downcastMethod.invoke(null, jsonNode, "ftdm:abcdefg123")); - Assert.assertEquals("Cannot remove non-default value:{@type=Custom, restricted=true, range={min=-1, round=0.0, max=1, @type=intMinMax}, value=1}", re.getCause().getMessage()); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}", "ftdm:abcdefg123"), + "Cannot remove non-default value:{@type=Custom, restricted=true, range={min=-1, round=0.0, max=1, @type=intMinMax}, value=1}"); } } diff --git a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastCustomNestedTest.java b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastCustomNestedTest.java index 7137edf8328..3e7e2a39ffb 100644 --- a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastCustomNestedTest.java +++ b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastCustomNestedTest.java @@ -15,17 +15,11 @@ package org.finos.legend.engine.changetoken.generation; import com.fasterxml.jackson.core.JsonProcessingException; -import com.fasterxml.jackson.databind.ObjectMapper; -import org.junit.Assert; import org.junit.BeforeClass; import org.junit.Test; import java.io.IOException; import java.lang.reflect.InvocationTargetException; -import java.lang.reflect.Method; -import java.util.Map; - -import static org.junit.Assert.assertThrows; public class GenerateCastCustomNestedTest extends GenerateCastTestBase { @@ -64,8 +58,7 @@ public static void setupSuite() throws IOException, ClassNotFoundException @Test public void testUpcast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"},\n" + @@ -73,11 +66,7 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}, \n" + " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}]\n" + " ]\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("upcast", Map.class).invoke(null, jsonNode); - - Map expectedJsonNodeOut = mapper.readValue( + "}"), "{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -87,16 +76,13 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"restricted\":true, \"range\":{\"min\":-1, \"max\":1, \"@type\":\"intMinMax\", \"round\":0.5}, \"value\":0}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"restricted\":true, \"range\":{\"min\":-1, \"max\":1, \"@type\":\"intMinMax\", \"round\":0.5}, \"value\":0}}\n" + - "}", Map.class); // updated version and new default value field added - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"restricted\":true, \"range\":{\"min\":-1, \"max\":1, \"@type\":\"intMinMax\", \"round\":0.5}, \"value\":0}},\n" + @@ -105,11 +91,7 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"restricted\":true, \"range\":{\"min\":-1, \"max\":1, \"@type\":\"intMinMax\", \"round\":0.5}, \"value\":0}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"restricted\":true, \"range\":{\"min\":-1, \"max\":1, \"@type\":\"intMinMax\", \"round\":0.5}, \"value\":0}}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class) - .invoke(null, jsonNode, "ftdm:abcdefg123"); - Map expectedJsonNodeOut = mapper.readValue( + "}", "ftdm:abcdefg123"), "{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -118,16 +100,13 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}, \n" + " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}]\n" + " ]\n" + - "}", Map.class); // remove default values - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncastNonDefault() throws JsonProcessingException, NoSuchMethodException { - String input = - "{\n" + + exception(() -> downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"restricted\":true, \"range\":{\"min\":-1, \"max\":1, \"@type\":\"intMinMax\", \"round\":0.5}, \"value\":0}},\n" + @@ -136,11 +115,7 @@ public void testDowncastNonDefault() throws JsonProcessingException, NoSuchMetho " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"restricted\":true, \"range\":{\"min\":-1, \"max\":1, \"@type\":\"intMinMax\", \"round\":0.5}, \"value\":0}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"restricted\":true, \"range\":{\"min\":-1, \"max\":1, \"@type\":\"intMinMax\", \"round\":0.0}, \"value\":1}}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Method downcastMethod = compiledClass.getMethod("downcast", Map.class, String.class); - InvocationTargetException re = assertThrows("non-default", InvocationTargetException.class, () -> downcastMethod.invoke(null, jsonNode, "ftdm:abcdefg123")); - Assert.assertEquals("Cannot remove non-default value:{@type=Custom, restricted=true, range={min=-1, round=0.0, max=1, @type=intMinMax}, value=1}", re.getCause().getMessage()); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}", "ftdm:abcdefg123"), + "Cannot remove non-default value:{@type=Custom, restricted=true, range={min=-1, round=0.0, max=1, @type=intMinMax}, value=1}"); } } diff --git a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastCustomObjectTest.java b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastCustomObjectTest.java index 5c54d1a7c38..0b81983ace2 100644 --- a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastCustomObjectTest.java +++ b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastCustomObjectTest.java @@ -15,17 +15,11 @@ package org.finos.legend.engine.changetoken.generation; import com.fasterxml.jackson.core.JsonProcessingException; -import com.fasterxml.jackson.databind.ObjectMapper; -import org.junit.Assert; import org.junit.BeforeClass; import org.junit.Test; import java.io.IOException; import java.lang.reflect.InvocationTargetException; -import java.lang.reflect.Method; -import java.util.Map; - -import static org.junit.Assert.assertThrows; public class GenerateCastCustomObjectTest extends GenerateCastTestBase { @@ -74,8 +68,7 @@ public static void setupSuite() throws IOException, ClassNotFoundException @Test public void testUpcast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"},\n" + @@ -83,11 +76,7 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}, \n" + " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}]\n" + " ]\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("upcast", Map.class).invoke(null, jsonNode); - - Map expectedJsonNodeOut = mapper.readValue( + "}"), "{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -97,16 +86,13 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"restricted\":true, \"range\":{\"min\":-1, \"max\":1, \"@type\":\"intMinMax\", \"round\":0.5}, \"value\":0}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"restricted\":true, \"range\":{\"min\":-1, \"max\":1, \"@type\":\"intMinMax\", \"round\":0.5}, \"value\":0}}\n" + - "}", Map.class); // updated version and new default value field added - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"restricted\":true, \"range\":{\"min\":-1, \"max\":1, \"@type\":\"intMinMax\", \"round\":0.5}, \"value\":0}},\n" + @@ -115,11 +101,7 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"restricted\":true, \"range\":{\"min\":-1, \"max\":1, \"@type\":\"intMinMax\", \"round\":0.5}, \"value\":0}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"restricted\":true, \"range\":{\"min\":-1, \"max\":1, \"@type\":\"intMinMax\", \"round\":0.5}, \"value\":0}}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class) - .invoke(null, jsonNode, "ftdm:abcdefg123"); - Map expectedJsonNodeOut = mapper.readValue( + "}", "ftdm:abcdefg123"), "{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -128,16 +110,13 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}, \n" + " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}]\n" + " ]\n" + - "}", Map.class); // remove default values - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncastNonDefault() throws JsonProcessingException, NoSuchMethodException { - String input = - "{\n" + + exception(() -> downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"restricted\":true, \"range\":{\"min\":-1, \"max\":1, \"@type\":\"intMinMax\", \"round\":0.5}, \"value\":0}},\n" + @@ -146,11 +125,7 @@ public void testDowncastNonDefault() throws JsonProcessingException, NoSuchMetho " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"restricted\":true, \"range\":{\"min\":-1, \"max\":1, \"@type\":\"intMinMax\", \"round\":0.5}, \"value\":0}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"restricted\":true, \"range\":{\"min\":-1, \"max\":1, \"@type\":\"intMinMax\", \"round\":0.0}, \"value\":1}}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Method downcastMethod = compiledClass.getMethod("downcast", Map.class, String.class); - InvocationTargetException re = assertThrows("non-default", InvocationTargetException.class, () -> downcastMethod.invoke(null, jsonNode, "ftdm:abcdefg123")); - Assert.assertEquals("Cannot remove non-default value:{@type=Custom, restricted=true, range={min=-1, round=0.0, max=1, @type=intMinMax}, value=1}", re.getCause().getMessage()); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}", "ftdm:abcdefg123"), + "Cannot remove non-default value:{@type=Custom, restricted=true, range={min=-1, round=0.0, max=1, @type=intMinMax}, value=1}"); } } \ No newline at end of file diff --git a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastCustomPrimitiveStringTest.java b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastCustomPrimitiveStringTest.java index 3831851c0dd..89e157ecb15 100644 --- a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastCustomPrimitiveStringTest.java +++ b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastCustomPrimitiveStringTest.java @@ -15,17 +15,11 @@ package org.finos.legend.engine.changetoken.generation; import com.fasterxml.jackson.core.JsonProcessingException; -import com.fasterxml.jackson.databind.ObjectMapper; -import org.junit.Assert; import org.junit.BeforeClass; import org.junit.Test; import java.io.IOException; import java.lang.reflect.InvocationTargetException; -import java.lang.reflect.Method; -import java.util.Map; - -import static org.junit.Assert.assertThrows; public class GenerateCastCustomPrimitiveStringTest extends GenerateCastTestBase { @@ -64,8 +58,7 @@ public static void setupSuite() throws IOException, ClassNotFoundException @Test public void testUpcast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"},\n" + @@ -73,11 +66,7 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}, \n" + " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}]\n" + " ]\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("upcast", Map.class).invoke(null, jsonNode); - - Map expectedJsonNodeOut = mapper.readValue( + "}"), "{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -87,16 +76,13 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": \"1970-01-01T00:00:01Z\"}]\n" + " ],\n" + " \"abc\": \"1970-01-01T00:00:01Z\"\n" + - "}", Map.class); // updated version and new default value field added - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": \"1970-01-01T00:00:01Z\"},\n" + @@ -105,11 +91,7 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": \"1970-01-01T00:00:01Z\"}]\n" + " ],\n" + " \"abc\": \"1970-01-01T00:00:01Z\"\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class) - .invoke(null, jsonNode, "ftdm:abcdefg123"); - Map expectedJsonNodeOut = mapper.readValue( + "}", "ftdm:abcdefg123"), "{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -118,16 +100,13 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}, \n" + " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}]\n" + " ]\n" + - "}", Map.class); // remove default values - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncastNonDefault() throws JsonProcessingException, NoSuchMethodException { - String input = - "{\n" + + exception(() -> downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": \"1970-01-01T00:00:01Z\"},\n" + @@ -136,11 +115,7 @@ public void testDowncastNonDefault() throws JsonProcessingException, NoSuchMetho " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": \"1970-01-01T00:00:01Z\"}]\n" + " ],\n" + " \"abc\": \"2023-06-22T18:30:01Z\"\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Method downcastMethod = compiledClass.getMethod("downcast", Map.class, String.class); - InvocationTargetException re = assertThrows("non-default", InvocationTargetException.class, () -> downcastMethod.invoke(null, jsonNode, "ftdm:abcdefg123")); - Assert.assertEquals("Cannot remove non-default value:2023-06-22T18:30:01Z", re.getCause().getMessage()); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}", "ftdm:abcdefg123"), + "Cannot remove non-default value:2023-06-22T18:30:01Z"); } } diff --git a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastCustomPrimitiveTest.java b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastCustomPrimitiveTest.java index 96260577a22..c8b2886e3c2 100644 --- a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastCustomPrimitiveTest.java +++ b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastCustomPrimitiveTest.java @@ -15,17 +15,11 @@ package org.finos.legend.engine.changetoken.generation; import com.fasterxml.jackson.core.JsonProcessingException; -import com.fasterxml.jackson.databind.ObjectMapper; -import org.junit.Assert; import org.junit.BeforeClass; import org.junit.Test; import java.io.IOException; import java.lang.reflect.InvocationTargetException; -import java.lang.reflect.Method; -import java.util.Map; - -import static org.junit.Assert.assertThrows; public class GenerateCastCustomPrimitiveTest extends GenerateCastTestBase { @@ -64,8 +58,7 @@ public static void setupSuite() throws IOException, ClassNotFoundException @Test public void testUpcast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"},\n" + @@ -73,11 +66,7 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}, \n" + " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}]\n" + " ]\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("upcast", Map.class).invoke(null, jsonNode); - - Map expectedJsonNodeOut = mapper.readValue( + "}"), "{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -87,16 +76,13 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": \"1970-01-01T00:00:01Z\"}]\n" + " ],\n" + " \"abc\": \"1970-01-01T00:00:01Z\"\n" + - "}", Map.class); // updated version and new default value field added - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": \"1970-01-01T00:00:01Z\"},\n" + @@ -105,11 +91,7 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": \"1970-01-01T00:00:01Z\"}]\n" + " ],\n" + " \"abc\": \"1970-01-01T00:00:01Z\"\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class) - .invoke(null, jsonNode, "ftdm:abcdefg123"); - Map expectedJsonNodeOut = mapper.readValue( + "}", "ftdm:abcdefg123"), "{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -118,16 +100,13 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}, \n" + " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}]\n" + " ]\n" + - "}", Map.class); // remove default values - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncastNonDefault() throws JsonProcessingException, NoSuchMethodException { - String input = - "{\n" + + exception(() -> downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": \"1970-01-01T00:00:01Z\"},\n" + @@ -136,11 +115,7 @@ public void testDowncastNonDefault() throws JsonProcessingException, NoSuchMetho " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": \"1970-01-01T00:00:01Z\"}]\n" + " ],\n" + " \"abc\": \"2023-06-22T18:30:01Z\"\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Method downcastMethod = compiledClass.getMethod("downcast", Map.class, String.class); - InvocationTargetException re = assertThrows("non-default", InvocationTargetException.class, () -> downcastMethod.invoke(null, jsonNode, "ftdm:abcdefg123")); - Assert.assertEquals("Cannot remove non-default value:2023-06-22T18:30:01Z", re.getCause().getMessage()); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}", "ftdm:abcdefg123"), + "Cannot remove non-default value:2023-06-22T18:30:01Z"); } } diff --git a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastCustomTest.java b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastCustomTest.java index eb480c0fc56..4c3ba0d0ceb 100644 --- a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastCustomTest.java +++ b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastCustomTest.java @@ -15,17 +15,11 @@ package org.finos.legend.engine.changetoken.generation; import com.fasterxml.jackson.core.JsonProcessingException; -import com.fasterxml.jackson.databind.ObjectMapper; -import org.junit.Assert; import org.junit.BeforeClass; import org.junit.Test; import java.io.IOException; import java.lang.reflect.InvocationTargetException; -import java.lang.reflect.Method; -import java.util.Map; - -import static org.junit.Assert.assertThrows; public class GenerateCastCustomTest extends GenerateCastTestBase { @@ -64,8 +58,7 @@ public static void setupSuite() throws IOException, ClassNotFoundException @Test public void testUpcast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"},\n" + @@ -73,11 +66,7 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}, \n" + " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}]\n" + " ]\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("upcast", Map.class).invoke(null, jsonNode); - - Map expectedJsonNodeOut = mapper.readValue( + "}"), "{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -87,16 +76,13 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"0d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"value\":\"0d\"}\n" + - "}", Map.class); // updated version and new default value field added - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"0d\"}},\n" + @@ -105,11 +91,7 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"0d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"value\":\"0d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class) - .invoke(null, jsonNode, "ftdm:abcdefg123"); - Map expectedJsonNodeOut = mapper.readValue( + "}", "ftdm:abcdefg123"), "{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -118,16 +100,13 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}, \n" + " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}]\n" + " ]\n" + - "}", Map.class); // remove default values - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncastNonDefault() throws JsonProcessingException, NoSuchMethodException { - String input = - "{\n" + + exception(() -> downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"0d\"}},\n" + @@ -136,11 +115,7 @@ public void testDowncastNonDefault() throws JsonProcessingException, NoSuchMetho " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"0d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"value\":\"1d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Method downcastMethod = compiledClass.getMethod("downcast", Map.class, String.class); - InvocationTargetException re = assertThrows("non-default", InvocationTargetException.class, () -> downcastMethod.invoke(null, jsonNode, "ftdm:abcdefg123")); - Assert.assertEquals("Cannot remove non-default value:{@type=Custom, value=1d}", re.getCause().getMessage()); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}", "ftdm:abcdefg123"), + "Cannot remove non-default value:{@type=Custom, value=1d}"); } } diff --git a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastDoubleStringTest.java b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastDoubleStringTest.java index e5426094b96..224fbc8ca6c 100644 --- a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastDoubleStringTest.java +++ b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastDoubleStringTest.java @@ -15,17 +15,11 @@ package org.finos.legend.engine.changetoken.generation; import com.fasterxml.jackson.core.JsonProcessingException; -import com.fasterxml.jackson.databind.ObjectMapper; -import org.junit.Assert; import org.junit.BeforeClass; import org.junit.Test; import java.io.IOException; import java.lang.reflect.InvocationTargetException; -import java.lang.reflect.Method; -import java.util.Map; - -import static org.junit.Assert.assertThrows; public class GenerateCastDoubleStringTest extends GenerateCastTestBase { @@ -64,8 +58,7 @@ public static void setupSuite() throws IOException, ClassNotFoundException @Test public void testUpcast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"},\n" + @@ -73,11 +66,7 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}, \n" + " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}]\n" + " ]\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("upcast", Map.class).invoke(null, jsonNode); - - Map expectedJsonNodeOut = mapper.readValue( + "}"), "{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -87,16 +76,13 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": 123.45}]\n" + " ],\n" + " \"abc\": 123.45\n" + - "}", Map.class); // updated version and new default value field added - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": 123.45},\n" + @@ -105,11 +91,7 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": 123.45}]\n" + " ],\n" + " \"abc\": 123.45\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class) - .invoke(null, jsonNode, "ftdm:abcdefg123"); - Map expectedJsonNodeOut = mapper.readValue( + "}", "ftdm:abcdefg123"), "{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -118,16 +100,13 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}, \n" + " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}]\n" + " ]\n" + - "}", Map.class); // remove default values - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncastNonDefault() throws JsonProcessingException, NoSuchMethodException { - String input = - "{\n" + + exception(() -> downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": 123.45},\n" + @@ -136,11 +115,7 @@ public void testDowncastNonDefault() throws JsonProcessingException, NoSuchMetho " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": 123.45}]\n" + " ],\n" + " \"abc\": 67.89\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Method downcastMethod = compiledClass.getMethod("downcast", Map.class, String.class); - InvocationTargetException re = assertThrows("non-default", InvocationTargetException.class, () -> downcastMethod.invoke(null, jsonNode, "ftdm:abcdefg123")); - Assert.assertEquals("Cannot remove non-default value:67.89", re.getCause().getMessage()); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}", "ftdm:abcdefg123"), + "Cannot remove non-default value:67.89"); } } diff --git a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastDoubleTest.java b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastDoubleTest.java index f4e65ce51ff..df96a82d589 100644 --- a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastDoubleTest.java +++ b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastDoubleTest.java @@ -15,17 +15,11 @@ package org.finos.legend.engine.changetoken.generation; import com.fasterxml.jackson.core.JsonProcessingException; -import com.fasterxml.jackson.databind.ObjectMapper; -import org.junit.Assert; import org.junit.BeforeClass; import org.junit.Test; import java.io.IOException; import java.lang.reflect.InvocationTargetException; -import java.lang.reflect.Method; -import java.util.Map; - -import static org.junit.Assert.assertThrows; public class GenerateCastDoubleTest extends GenerateCastTestBase { @@ -64,8 +58,7 @@ public static void setupSuite() throws IOException, ClassNotFoundException @Test public void testUpcast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"},\n" + @@ -73,11 +66,7 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}, \n" + " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}]\n" + " ]\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("upcast", Map.class).invoke(null, jsonNode); - - Map expectedJsonNodeOut = mapper.readValue( + "}"), "{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -87,16 +76,13 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": 123.45}]\n" + " ],\n" + " \"abc\": 123.45\n" + - "}", Map.class); // updated version and new default value field added - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": 123.45},\n" + @@ -105,11 +91,7 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": 123.45}]\n" + " ],\n" + " \"abc\": 123.45\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class) - .invoke(null, jsonNode, "ftdm:abcdefg123"); - Map expectedJsonNodeOut = mapper.readValue( + "}", "ftdm:abcdefg123"), "{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -118,16 +100,13 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}, \n" + " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}]\n" + " ]\n" + - "}", Map.class); // remove default values - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncastNonDefault() throws JsonProcessingException, NoSuchMethodException { - String input = - "{\n" + + exception(() -> downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": 123.45},\n" + @@ -136,11 +115,7 @@ public void testDowncastNonDefault() throws JsonProcessingException, NoSuchMetho " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": 123.45}]\n" + " ],\n" + " \"abc\": 67.89\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Method downcastMethod = compiledClass.getMethod("downcast", Map.class, String.class); - InvocationTargetException re = assertThrows("non-default", InvocationTargetException.class, () -> downcastMethod.invoke(null, jsonNode, "ftdm:abcdefg123")); - Assert.assertEquals("Cannot remove non-default value:67.89", re.getCause().getMessage()); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}", "ftdm:abcdefg123"), + "Cannot remove non-default value:67.89"); } } diff --git a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastFromJsonTest.java b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastFromJsonTest.java index d88b76b45e8..4611d8d3a95 100644 --- a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastFromJsonTest.java +++ b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastFromJsonTest.java @@ -15,18 +15,11 @@ package org.finos.legend.engine.changetoken.generation; import com.fasterxml.jackson.core.JsonProcessingException; -import com.fasterxml.jackson.databind.ObjectMapper; -import org.finos.legend.pure.generated.*; -import org.junit.Assert; import org.junit.BeforeClass; import org.junit.Test; import java.io.IOException; import java.lang.reflect.InvocationTargetException; -import java.lang.reflect.Method; -import java.util.Map; - -import static org.junit.Assert.assertThrows; public class GenerateCastFromJsonTest extends GenerateCastTestBase { @@ -65,8 +58,7 @@ public static void setupSuite() throws IOException, ClassNotFoundException @Test public void testUpcast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"},\n" + @@ -74,11 +66,7 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}, \n" + " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}]\n" + " ]\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("upcast", Map.class).invoke(null, jsonNode); - - Map expectedJsonNodeOut = mapper.readValue( + "}"), "{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -88,16 +76,13 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": 100}]\n" + " ],\n" + " \"abc\": 100\n" + - "}", Map.class); // updated version and new default value field added - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": 100},\n" + @@ -106,11 +91,7 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": 100}]\n" + " ],\n" + " \"abc\": 100\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class) - .invoke(null, jsonNode, "ftdm:abcdefg123"); - Map expectedJsonNodeOut = mapper.readValue( + "}", "ftdm:abcdefg123"), "{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -119,16 +100,13 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}, \n" + " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}]\n" + " ]\n" + - "}", Map.class); // remove default values - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncastNull() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": null},\n" + @@ -137,11 +115,7 @@ public void testDowncastNull() throws JsonProcessingException, NoSuchMethodExcep " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": null}]\n" + " ],\n" + " \"abc\": null\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class) - .invoke(null, jsonNode, "ftdm:abcdefg123"); - Map expectedJsonNodeOut = mapper.readValue( + "}", "ftdm:abcdefg123"), "{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -150,16 +124,13 @@ public void testDowncastNull() throws JsonProcessingException, NoSuchMethodExcep " {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}, \n" + " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}]\n" + " ]\n" + - "}", Map.class); // remove default values - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncastNonDefault() throws JsonProcessingException, NoSuchMethodException { - String input = - "{\n" + + exception(() -> downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": 100},\n" + @@ -168,11 +139,7 @@ public void testDowncastNonDefault() throws JsonProcessingException, NoSuchMetho " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": 100}]\n" + " ],\n" + " \"abc\": 300\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Method downcastMethod = compiledClass.getMethod("downcast", Map.class, String.class); - InvocationTargetException re = assertThrows("non-default", InvocationTargetException.class, () -> downcastMethod.invoke(null, jsonNode, "ftdm:abcdefg123")); - Assert.assertEquals("Cannot remove non-default value:300", re.getCause().getMessage()); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}", "ftdm:abcdefg123"), + "Cannot remove non-default value:300"); } } diff --git a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastFromVersionsTest.java b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastFromVersionsTest.java index f50c9e3c137..8af0c5d917a 100644 --- a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastFromVersionsTest.java +++ b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastFromVersionsTest.java @@ -15,18 +15,12 @@ package org.finos.legend.engine.changetoken.generation; import com.fasterxml.jackson.core.JsonProcessingException; -import com.fasterxml.jackson.databind.ObjectMapper; import org.finos.legend.pure.generated.*; -import org.junit.Assert; import org.junit.BeforeClass; import org.junit.Test; import java.io.IOException; import java.lang.reflect.InvocationTargetException; -import java.lang.reflect.Method; -import java.util.Map; - -import static org.junit.Assert.assertThrows; public class GenerateCastFromVersionsTest extends GenerateCastTestBase { @@ -43,7 +37,7 @@ public static void setupSuite() throws IOException, ClassNotFoundException addField._fieldName("abc"); addField._fieldType("Integer[1]"); addField._safeCast(true); - Root_meta_pure_changetoken_ConstValue value = new Root_meta_pure_changetoken_ConstValue_Impl("Anonymous_NoCounter"); + Root_meta_pure_changetoken_ConstValue value = new Root_meta_pure_changetoken_ConstValue_Impl("Anonymous_NoCounter"); value._value(100L); addField._defaultValue(value); abcdefg456._changeTokensAdd(addField); @@ -56,8 +50,7 @@ public static void setupSuite() throws IOException, ClassNotFoundException @Test public void testUpcast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"},\n" + @@ -65,11 +58,7 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}, \n" + " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}]\n" + " ]\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("upcast", Map.class).invoke(null, jsonNode); - - Map expectedJsonNodeOut = mapper.readValue( + "}"), "{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -79,16 +68,13 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": 100}]\n" + " ],\n" + " \"abc\": 100\n" + - "}", Map.class); // updated version and new default value field added - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": 100},\n" + @@ -97,11 +83,7 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": 100}]\n" + " ],\n" + " \"abc\": 100\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class) - .invoke(null, jsonNode, "ftdm:abcdefg123"); - Map expectedJsonNodeOut = mapper.readValue( + "}", "ftdm:abcdefg123"), "{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -110,16 +92,13 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}, \n" + " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}]\n" + " ]\n" + - "}", Map.class); // remove default values - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncastNull() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": null},\n" + @@ -128,11 +107,7 @@ public void testDowncastNull() throws JsonProcessingException, NoSuchMethodExcep " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": null}]\n" + " ],\n" + " \"abc\": null\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class) - .invoke(null, jsonNode, "ftdm:abcdefg123"); - Map expectedJsonNodeOut = mapper.readValue( + "}", "ftdm:abcdefg123"), "{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -141,16 +116,13 @@ public void testDowncastNull() throws JsonProcessingException, NoSuchMethodExcep " {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}, \n" + " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}]\n" + " ]\n" + - "}", Map.class); // remove default values - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncastNonDefault() throws JsonProcessingException, NoSuchMethodException { - String input = - "{\n" + + exception(() -> downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": 100},\n" + @@ -159,11 +131,7 @@ public void testDowncastNonDefault() throws JsonProcessingException, NoSuchMetho " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": 100}]\n" + " ],\n" + " \"abc\": 300\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Method downcastMethod = compiledClass.getMethod("downcast", Map.class, String.class); - InvocationTargetException re = assertThrows("non-default", InvocationTargetException.class, () -> downcastMethod.invoke(null, jsonNode, "ftdm:abcdefg123")); - Assert.assertEquals("Cannot remove non-default value:300", re.getCause().getMessage()); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}", "ftdm:abcdefg123"), + "Cannot remove non-default value:300"); } } diff --git a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastIntegerStringTest.java b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastIntegerStringTest.java index 74e1a4b00db..c853e37bd71 100644 --- a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastIntegerStringTest.java +++ b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastIntegerStringTest.java @@ -15,17 +15,11 @@ package org.finos.legend.engine.changetoken.generation; import com.fasterxml.jackson.core.JsonProcessingException; -import com.fasterxml.jackson.databind.ObjectMapper; -import org.junit.Assert; import org.junit.BeforeClass; import org.junit.Test; import java.io.IOException; import java.lang.reflect.InvocationTargetException; -import java.lang.reflect.Method; -import java.util.Map; - -import static org.junit.Assert.assertThrows; public class GenerateCastIntegerStringTest extends GenerateCastTestBase { @@ -64,8 +58,7 @@ public static void setupSuite() throws IOException, ClassNotFoundException @Test public void testUpcast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"},\n" + @@ -73,11 +66,7 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}, \n" + " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}]\n" + " ]\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("upcast", Map.class).invoke(null, jsonNode); - - Map expectedJsonNodeOut = mapper.readValue( + "}"), "{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -87,16 +76,13 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": 100}]\n" + " ],\n" + " \"abc\": 100\n" + - "}", Map.class); // updated version and new default value field added - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": 100},\n" + @@ -105,11 +91,7 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": 100}]\n" + " ],\n" + " \"abc\": 100\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class) - .invoke(null, jsonNode, "ftdm:abcdefg123"); - Map expectedJsonNodeOut = mapper.readValue( + "}", "ftdm:abcdefg123"), "{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -118,16 +100,13 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}, \n" + " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}]\n" + " ]\n" + - "}", Map.class); // remove default values - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncastNonDefault() throws JsonProcessingException, NoSuchMethodException { - String input = - "{\n" + + exception(() -> downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": 100},\n" + @@ -136,11 +115,7 @@ public void testDowncastNonDefault() throws JsonProcessingException, NoSuchMetho " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": 100}]\n" + " ],\n" + " \"abc\": 300\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Method downcastMethod = compiledClass.getMethod("downcast", Map.class, String.class); - InvocationTargetException re = assertThrows("non-default", InvocationTargetException.class, () -> downcastMethod.invoke(null, jsonNode, "ftdm:abcdefg123")); - Assert.assertEquals("Cannot remove non-default value:300", re.getCause().getMessage()); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}", "ftdm:abcdefg123"), + "Cannot remove non-default value:300"); } } diff --git a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastMoveExtractTest.java b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastMoveExtractTest.java index 7eafd09bd30..40f9576508f 100644 --- a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastMoveExtractTest.java +++ b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastMoveExtractTest.java @@ -15,14 +15,11 @@ package org.finos.legend.engine.changetoken.generation; import com.fasterxml.jackson.core.JsonProcessingException; -import com.fasterxml.jackson.databind.ObjectMapper; -import org.junit.Assert; import org.junit.BeforeClass; import org.junit.Test; import java.io.IOException; import java.lang.reflect.InvocationTargetException; -import java.util.Map; public class GenerateCastMoveExtractTest extends GenerateCastTestBase { @@ -83,8 +80,7 @@ public static void setupSuite() throws IOException, ClassNotFoundException @Test public void testUpcast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"names\": {\"@type\":\"NamesClass\", \"first\":\"1d\", \"middle\":\"\", \"last\":\"2d\"}},\n" + @@ -93,11 +89,7 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"names\": {\"@type\":\"NamesClass\", \"first\":\"5d\", \"middle\":\"\", \"last\":\"6d\"}}]\n" + " ],\n" + " \"names\": {\"@type\":\"NamesClass\", \"first\":\"7d\", \"middle\":\"\", \"last\":\"8d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("upcast", Map.class).invoke(null, jsonNode); - - Map expectedJsonNodeOut = mapper.readValue( + "}"), "{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -107,16 +99,13 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"firstName\":\"5d\", \"lastName\":\"6d\"}]\n" + " ],\n" + " \"firstName\":\"7d\", \"lastName\":\"8d\"\n" + - "}", Map.class); // updated version and new default value field added - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"firstName\":\"1d\", \"lastName\":\"2d\"},\n" + @@ -125,11 +114,7 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"firstName\":\"5d\", \"lastName\":\"6d\"}]\n" + " ],\n" + " \"firstName\":\"7d\", \"lastName\":\"8d\"\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class) - .invoke(null, jsonNode, "ftdm:abcdefg123"); - Map expectedJsonNodeOut = mapper.readValue( + "}", "ftdm:abcdefg123"), "{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -139,8 +124,6 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"names\": {\"@type\":\"NamesClass\", \"first\":\"5d\", \"middle\":\"\", \"last\":\"6d\"}}]\n" + " ],\n" + " \"names\": {\"@type\":\"NamesClass\", \"first\":\"7d\", \"middle\":\"\", \"last\":\"8d\"}\n" + - "}", Map.class); // remove default values - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } } diff --git a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastMoveNestedTest.java b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastMoveNestedTest.java index c2c8b4efca4..4d8af2165bd 100644 --- a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastMoveNestedTest.java +++ b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastMoveNestedTest.java @@ -15,17 +15,11 @@ package org.finos.legend.engine.changetoken.generation; import com.fasterxml.jackson.core.JsonProcessingException; -import com.fasterxml.jackson.databind.ObjectMapper; -import org.junit.Assert; import org.junit.BeforeClass; import org.junit.Test; import java.io.IOException; import java.lang.reflect.InvocationTargetException; -import java.lang.reflect.Method; -import java.util.Map; - -import static org.junit.Assert.assertThrows; public class GenerateCastMoveNestedTest extends GenerateCastTestBase { @@ -65,8 +59,7 @@ public static void setupSuite() throws IOException, ClassNotFoundException @Test public void testUpcast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"String\", \"value\":\"1d\"}, \"xyz\": {\"@type\":\"String\"}},\n" + @@ -75,11 +68,7 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"String\", \"value\":\"3d\"}, \"xyz\": {\"@type\":\"String\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"String\", \"value\":\"4d\"}, \"xyz\": {\"@type\":\"String\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("upcast", Map.class).invoke(null, jsonNode); - - Map expectedJsonNodeOut = mapper.readValue( + "}"), "{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -89,16 +78,13 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"xyz\": {\"@type\":\"String\", \"value\":\"3d\"}, \"abc\": {\"@type\":\"String\"}}]\n" + " ],\n" + " \"xyz\": {\"@type\":\"String\", \"value\":\"4d\"}, \"abc\": {\"@type\":\"String\"}\n" + - "}", Map.class); // updated version and new default value field added - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"xyz\": {\"@type\":\"String\", \"value\":\"1d\"}, \"abc\": {\"@type\":\"String\"}},\n" + @@ -107,11 +93,7 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"xyz\": {\"@type\":\"String\", \"value\":\"3d\"}, \"abc\": {\"@type\":\"String\"}}]\n" + " ],\n" + " \"xyz\": {\"@type\":\"String\", \"value\":\"4d\"}, \"abc\": {\"@type\":\"String\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class) - .invoke(null, jsonNode, "ftdm:abcdefg123"); - Map expectedJsonNodeOut = mapper.readValue( + "}", "ftdm:abcdefg123"), "{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -121,16 +103,13 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"String\", \"value\":\"3d\"}, \"xyz\": {\"@type\":\"String\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"String\", \"value\":\"4d\"}, \"xyz\": {\"@type\":\"String\"}\n" + - "}", Map.class); // remove default values - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testUpcastSame() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"String\", \"value\":\"1d\"}, \"xyz\": {\"@type\":\"String\"}},\n" + @@ -139,11 +118,7 @@ public void testUpcastSame() throws JsonProcessingException, NoSuchMethodExcepti " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"String\", \"value\":\"3d\"}, \"xyz\": {\"@type\":\"String\", \"value\":\"3d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"String\", \"value\":\"4d\"}, \"xyz\": {\"@type\":\"String\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("upcast", Map.class).invoke(null, jsonNode); - - Map expectedJsonNodeOut = mapper.readValue( + "}"), "{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -153,16 +128,13 @@ public void testUpcastSame() throws JsonProcessingException, NoSuchMethodExcepti " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"xyz\": {\"@type\":\"String\", \"value\":\"3d\"}, \"abc\": {\"@type\":\"String\"}}]\n" + " ],\n" + " \"xyz\": {\"@type\":\"String\", \"value\":\"4d\"}, \"abc\": {\"@type\":\"String\"}\n" + - "}", Map.class); // updated version and new default value field added - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncastSame() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"xyz\": {\"@type\":\"String\", \"value\":\"1d\"}, \"abc\": {\"@type\":\"String\"}},\n" + @@ -171,11 +143,7 @@ public void testDowncastSame() throws JsonProcessingException, NoSuchMethodExcep " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"xyz\": {\"@type\":\"String\", \"value\":\"3d\"}, \"abc\": {\"@type\":\"String\", \"value\":\"3d\"}}]\n" + " ],\n" + " \"xyz\": {\"@type\":\"String\", \"value\":\"4d\"}, \"abc\": {\"@type\":\"String\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class) - .invoke(null, jsonNode, "ftdm:abcdefg123"); - Map expectedJsonNodeOut = mapper.readValue( + "}", "ftdm:abcdefg123"), "{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -185,16 +153,13 @@ public void testDowncastSame() throws JsonProcessingException, NoSuchMethodExcep " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"String\", \"value\":\"3d\"}, \"xyz\": {\"@type\":\"String\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"String\", \"value\":\"4d\"}, \"xyz\": {\"@type\":\"String\"}\n" + - "}", Map.class); // remove default values - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testUpcastDifferent() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + exception(() -> upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"String\", \"value\":\"1d\"}, \"xyz\": {\"@type\":\"String\"}},\n" + @@ -203,19 +168,14 @@ public void testUpcastDifferent() throws JsonProcessingException, NoSuchMethodEx " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"String\", \"value\":\"3d\"}, \"xyz\": {\"@type\":\"String\", \"value\":\"5d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"String\", \"value\":\"4d\"}, \"xyz\": {\"@type\":\"String\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Method upcastMethod = compiledClass.getMethod("upcast", Map.class); - InvocationTargetException re = assertThrows("non-default", InvocationTargetException.class, () -> upcastMethod.invoke(null, jsonNode)); - Assert.assertEquals("Cannot overwrite with different value:5d", re.getCause().getMessage()); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}"), + "Cannot overwrite with different value:5d"); } @Test public void testDowncastDifferent() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + exception(() -> downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"xyz\": {\"@type\":\"String\", \"value\":\"1d\"}, \"abc\": {\"@type\":\"String\"}},\n" + @@ -224,19 +184,14 @@ public void testDowncastDifferent() throws JsonProcessingException, NoSuchMethod " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"xyz\": {\"@type\":\"String\", \"value\":\"3d\"}, \"abc\": {\"@type\":\"String\", \"value\":\"6d\"}}]\n" + " ],\n" + " \"xyz\": {\"@type\":\"String\", \"value\":\"4d\"}, \"abc\": {\"@type\":\"String\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Method downcastMethod = compiledClass.getMethod("downcast", Map.class, String.class); - InvocationTargetException re = assertThrows("non-default", InvocationTargetException.class, () -> downcastMethod.invoke(null, jsonNode, "ftdm:abcdefg123")); - Assert.assertEquals("Cannot overwrite with different value:6d", re.getCause().getMessage()); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}", "ftdm:abcdefg123"), + "Cannot overwrite with different value:6d"); } @Test public void testUpcastInvalidDestination() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + exception(() -> upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"String\", \"value\":\"1d\"}, \"xyz\": {\"@type\":\"String\"}},\n" + @@ -245,19 +200,14 @@ public void testUpcastInvalidDestination() throws JsonProcessingException, NoSuc " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"String\", \"value\":\"3d\"}, \"xyz\": \"invalid\"}]\n" + " ],\n" + " \"abc\": {\"@type\":\"String\", \"value\":\"4d\"}, \"xyz\": {\"@type\":\"String\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Method upcastMethod = compiledClass.getMethod("upcast", Map.class); - InvocationTargetException re = assertThrows("non-default", InvocationTargetException.class, () -> upcastMethod.invoke(null, jsonNode)); - Assert.assertEquals("Destination is not a map: xyz", re.getCause().getMessage()); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}"), + "Destination is not a map: xyz"); } @Test public void testDowncastInvalidDestination() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + exception(() -> downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"xyz\": {\"@type\":\"String\", \"value\":\"1d\"}, \"abc\": {\"@type\":\"String\"}},\n" + @@ -266,19 +216,14 @@ public void testDowncastInvalidDestination() throws JsonProcessingException, NoS " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"xyz\": {\"@type\":\"String\", \"value\":\"3d\"}, \"abc\": \"invalid\"}]\n" + " ],\n" + " \"xyz\": {\"@type\":\"String\", \"value\":\"4d\"}, \"abc\": {\"@type\":\"String\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Method downcastMethod = compiledClass.getMethod("downcast", Map.class, String.class); - InvocationTargetException re = assertThrows("non-default", InvocationTargetException.class, () -> downcastMethod.invoke(null, jsonNode, "ftdm:abcdefg123")); - Assert.assertEquals("Destination is not a map: abc", re.getCause().getMessage()); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}", "ftdm:abcdefg123"), + "Destination is not a map: abc"); } @Test public void testUpcastInvalidSource() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + exception(() -> upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"String\", \"value\":\"1d\"}, \"xyz\": {\"@type\":\"String\"}},\n" + @@ -287,19 +232,14 @@ public void testUpcastInvalidSource() throws JsonProcessingException, NoSuchMeth " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": \"invalid\", \"xyz\": {\"@type\":\"String\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"String\", \"value\":\"4d\"}, \"xyz\": {\"@type\":\"String\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Method upcastMethod = compiledClass.getMethod("upcast", Map.class); - InvocationTargetException re = assertThrows("non-default", InvocationTargetException.class, () -> upcastMethod.invoke(null, jsonNode)); - Assert.assertEquals("Source is not a map: abc", re.getCause().getMessage()); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}"), + "Source is not a map: abc"); } @Test public void testDowncastInvalidSource() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + exception(() -> downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"xyz\": {\"@type\":\"String\", \"value\":\"1d\"}, \"abc\": {\"@type\":\"String\"}},\n" + @@ -308,11 +248,7 @@ public void testDowncastInvalidSource() throws JsonProcessingException, NoSuchMe " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"xyz\": \"invalid\", \"abc\": {\"@type\":\"String\"}}]\n" + " ],\n" + " \"xyz\": {\"@type\":\"String\", \"value\":\"4d\"}, \"abc\": {\"@type\":\"String\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Method downcastMethod = compiledClass.getMethod("downcast", Map.class, String.class); - InvocationTargetException re = assertThrows("non-default", InvocationTargetException.class, () -> downcastMethod.invoke(null, jsonNode, "ftdm:abcdefg123")); - Assert.assertEquals("Source is not a map: xyz", re.getCause().getMessage()); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}", "ftdm:abcdefg123"), + "Source is not a map: xyz"); } } diff --git a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastMoveTest.java b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastMoveTest.java index 1725c972e71..0241f0ab169 100644 --- a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastMoveTest.java +++ b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastMoveTest.java @@ -15,17 +15,11 @@ package org.finos.legend.engine.changetoken.generation; import com.fasterxml.jackson.core.JsonProcessingException; -import com.fasterxml.jackson.databind.ObjectMapper; -import org.junit.Assert; import org.junit.BeforeClass; import org.junit.Test; import java.io.IOException; import java.lang.reflect.InvocationTargetException; -import java.lang.reflect.Method; -import java.util.Map; - -import static org.junit.Assert.assertThrows; public class GenerateCastMoveTest extends GenerateCastTestBase { @@ -75,8 +69,7 @@ public static void setupSuite() throws IOException, ClassNotFoundException @Test public void testUpcast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"1d\"}},\n" + @@ -85,11 +78,7 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"3d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"value\":\"4d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("upcast", Map.class).invoke(null, jsonNode); - - Map expectedJsonNodeOut = mapper.readValue( + "}"), "{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -99,16 +88,13 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"xyz\": {\"@type\":\"SampleNestedClass\", \"active\":true, \"step\":0, \"def\": {\"@type\":\"Custom\", \"value\":\"3d\"}}}]\n" + " ],\n" + " \"xyz\": {\"@type\":\"SampleNestedClass\", \"active\":true, \"step\":0, \"def\": {\"@type\":\"Custom\", \"value\":\"4d\"}}\n" + - "}", Map.class); // updated version and new default value field added - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testUpcastType() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::OtherClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::OtherClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"1d\"}},\n" + @@ -117,11 +103,7 @@ public void testUpcastType() throws JsonProcessingException, NoSuchMethodExcepti " [{\"@type\": \"meta::pure::changetoken::tests::OtherClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"3d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"value\":\"4d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("upcast", Map.class).invoke(null, jsonNode); - - Map expectedJsonNodeOut = mapper.readValue( + "}"), "{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::OtherClass\",\n" + @@ -131,17 +113,13 @@ public void testUpcastType() throws JsonProcessingException, NoSuchMethodExcepti " [{\"@type\": \"meta::pure::changetoken::tests::OtherClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"3d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"value\":\"4d\"}\n" + - "}", Map.class); // updated version and new default value field added - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } - @Test public void testUpcastMissing() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"def\": {\"@type\":\"Custom\", \"value\":\"1d\"}},\n" + @@ -150,11 +128,7 @@ public void testUpcastMissing() throws JsonProcessingException, NoSuchMethodExce " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"def\": {\"@type\":\"Custom\", \"value\":\"3d\"}}]\n" + " ],\n" + " \"def\": {\"@type\":\"Custom\", \"value\":\"4d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("upcast", Map.class).invoke(null, jsonNode); - - Map expectedJsonNodeOut = mapper.readValue( + "}"), "{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -164,16 +138,13 @@ public void testUpcastMissing() throws JsonProcessingException, NoSuchMethodExce " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"xyz\": {\"@type\":\"SampleNestedClass\", \"active\":true, \"step\":0}, \"def\": {\"@type\":\"Custom\", \"value\":\"3d\"}}]\n" + " ],\n" + " \"xyz\": {\"@type\":\"SampleNestedClass\", \"active\":true, \"step\":0}, \"def\": {\"@type\":\"Custom\", \"value\":\"4d\"}\n" + - "}", Map.class); // updated version and new default value field added - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"xyz\": {\"@type\":\"SampleNestedClass\", \"active\":true, \"step\":0, \"def\": {\"@type\":\"Custom\", \"value\":\"1d\"}}},\n" + @@ -182,11 +153,7 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"xyz\": {\"@type\":\"SampleNestedClass\", \"active\":true, \"step\":0, \"def\": {\"@type\":\"Custom\", \"value\":\"3d\"}}}]\n" + " ],\n" + " \"xyz\": {\"@type\":\"SampleNestedClass\", \"active\":true, \"step\":0, \"def\": {\"@type\":\"Custom\", \"value\":\"4d\"}}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class) - .invoke(null, jsonNode, "ftdm:abcdefg123"); - Map expectedJsonNodeOut = mapper.readValue( + "}", "ftdm:abcdefg123"), "{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -196,16 +163,13 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"3d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"value\":\"4d\"}\n" + - "}", Map.class); // remove default values - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncastType() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::OtherClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::OtherClass\", \"xyz\": {\"@type\":\"Custom\", \"value\":\"4d\"}},\n" + @@ -214,11 +178,7 @@ public void testDowncastType() throws JsonProcessingException, NoSuchMethodExcep " [{\"@type\": \"meta::pure::changetoken::tests::OtherClass\", \"xyz\": {\"@type\":\"Custom\", \"value\":\"2d\"}}]\n" + " ],\n" + " \"xyz\": {\"@type\":\"Custom\", \"value\":\"1d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class) - .invoke(null, jsonNode, "ftdm:abcdefg123"); - Map expectedJsonNodeOut = mapper.readValue( + "}", "ftdm:abcdefg123"), "{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::OtherClass\",\n" + @@ -228,16 +188,13 @@ public void testDowncastType() throws JsonProcessingException, NoSuchMethodExcep " [{\"@type\": \"meta::pure::changetoken::tests::OtherClass\", \"xyz\": {\"@type\":\"Custom\", \"value\":\"2d\"}}]\n" + " ],\n" + " \"xyz\": {\"@type\":\"Custom\", \"value\":\"1d\"}\n" + - "}", Map.class); // remove default values - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncastMissing() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"def\": {\"@type\":\"Custom\", \"value\":\"4d\"}},\n" + @@ -246,11 +203,7 @@ public void testDowncastMissing() throws JsonProcessingException, NoSuchMethodEx " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"def\": {\"@type\":\"Custom\", \"value\":\"2d\"}}]\n" + " ],\n" + " \"def\": {\"@type\":\"Custom\", \"value\":\"1d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class) - .invoke(null, jsonNode, "ftdm:abcdefg123"); - Map expectedJsonNodeOut = mapper.readValue( + "}", "ftdm:abcdefg123"), "{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -260,8 +213,6 @@ public void testDowncastMissing() throws JsonProcessingException, NoSuchMethodEx " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"def\": {\"@type\":\"Custom\", \"value\":\"2d\"}}]\n" + " ],\n" + " \"def\": {\"@type\":\"Custom\", \"value\":\"1d\"}\n" + - "}", Map.class); // remove default values - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } } diff --git a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastRemoveTest.java b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastRemoveTest.java index 7948799723e..f02987e157c 100644 --- a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastRemoveTest.java +++ b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastRemoveTest.java @@ -15,17 +15,11 @@ package org.finos.legend.engine.changetoken.generation; import com.fasterxml.jackson.core.JsonProcessingException; -import com.fasterxml.jackson.databind.ObjectMapper; -import org.junit.Assert; import org.junit.BeforeClass; import org.junit.Test; import java.io.IOException; import java.lang.reflect.InvocationTargetException; -import java.lang.reflect.Method; -import java.util.Map; - -import static org.junit.Assert.assertThrows; public class GenerateCastRemoveTest extends GenerateCastTestBase { @@ -64,8 +58,7 @@ public static void setupSuite() throws IOException, ClassNotFoundException @Test public void testUpcast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(upcast("{\n" + " \"version\":\"ftdm:abcdefg123\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": 100},\n" + @@ -74,10 +67,7 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": 100}]\n" + " ],\n" + " \"abc\": 100\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("upcast", Map.class).invoke(null, jsonNode); - Map expectedJsonNodeOut = mapper.readValue( + "}"), "{\n" + " \"version\":\"ftdm:abcdefg456\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -86,16 +76,13 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}, \n" + " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}]\n" + " ]\n" + - "}", Map.class); // remove default values - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void tesUpcastNull() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(upcast("{\n" + " \"version\":\"ftdm:abcdefg123\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": null},\n" + @@ -104,10 +91,7 @@ public void tesUpcastNull() throws JsonProcessingException, NoSuchMethodExceptio " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": null}]\n" + " ],\n" + " \"abc\": null\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("upcast", Map.class).invoke(null, jsonNode); - Map expectedJsonNodeOut = mapper.readValue( + "}"), "{\n" + " \"version\":\"ftdm:abcdefg456\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -116,16 +100,13 @@ public void tesUpcastNull() throws JsonProcessingException, NoSuchMethodExceptio " {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}, \n" + " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}]\n" + " ]\n" + - "}", Map.class); // remove default values - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testUpcastNonDefault() throws JsonProcessingException, NoSuchMethodException { - String input = - "{\n" + + exception(() -> upcast("{\n" + " \"version\":\"ftdm:abcdefg123\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": 100},\n" + @@ -134,19 +115,14 @@ public void testUpcastNonDefault() throws JsonProcessingException, NoSuchMethodE " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": 100}]\n" + " ],\n" + " \"abc\": 300\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Method upcastMethod = compiledClass.getMethod("upcast", Map.class); - InvocationTargetException re = assertThrows("non-default", InvocationTargetException.class, () -> upcastMethod.invoke(null, jsonNode)); - Assert.assertEquals("Cannot remove non-default value:300", re.getCause().getMessage()); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}"), + "Cannot remove non-default value:300"); } @Test public void testDowncast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(downcast("{\n" + " \"version\":\"ftdm:abcdefg456\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"},\n" + @@ -154,11 +130,7 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}, \n" + " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}]\n" + " ]\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class) - .invoke(null, jsonNode, "ftdm:abcdefg123"); - Map expectedJsonNodeOut = mapper.readValue( + "}", "ftdm:abcdefg123"), "{\n" + " \"version\":\"ftdm:abcdefg123\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -168,8 +140,6 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": 100}]\n" + " ],\n" + " \"abc\": 100\n" + - "}", Map.class); // updated version and new default value field added - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); - } + "}\n"); + } } diff --git a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastRenameFieldRenamedClassTest.java b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastRenameFieldRenamedClassTest.java index e29eede5c00..09f096071f2 100644 --- a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastRenameFieldRenamedClassTest.java +++ b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastRenameFieldRenamedClassTest.java @@ -15,17 +15,11 @@ package org.finos.legend.engine.changetoken.generation; import com.fasterxml.jackson.core.JsonProcessingException; -import com.fasterxml.jackson.databind.ObjectMapper; -import org.junit.Assert; import org.junit.BeforeClass; import org.junit.Test; import java.io.IOException; import java.lang.reflect.InvocationTargetException; -import java.lang.reflect.Method; -import java.util.Map; - -import static org.junit.Assert.assertThrows; public class GenerateCastRenameFieldRenamedClassTest extends GenerateCastTestBase { @@ -68,8 +62,7 @@ public static void setupSuite() throws IOException, ClassNotFoundException @Test public void testUpcast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"1d\"}},\n" + @@ -78,11 +71,7 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"3d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"value\":\"4d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("upcast", Map.class).invoke(null, jsonNode); - - Map expectedJsonNodeOut = mapper.readValue( + "}"), "{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::nested::NewSampleClass\",\n" + @@ -92,16 +81,13 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " [{\"@type\": \"meta::pure::changetoken::tests::nested::NewSampleClass\", \"xyz\": {\"@type\":\"Custom\", \"value\":\"3d\"}}]\n" + " ],\n" + " \"xyz\": {\"@type\":\"Custom\", \"value\":\"4d\"}\n" + - "}", Map.class); // updated version and new default value field added - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testUpcastType() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::OtherClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::OtherClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"1d\"}},\n" + @@ -110,11 +96,7 @@ public void testUpcastType() throws JsonProcessingException, NoSuchMethodExcepti " [{\"@type\": \"meta::pure::changetoken::tests::OtherClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"3d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"value\":\"4d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("upcast", Map.class).invoke(null, jsonNode); - - Map expectedJsonNodeOut = mapper.readValue( + "}"), "{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::OtherClass\",\n" + @@ -124,17 +106,13 @@ public void testUpcastType() throws JsonProcessingException, NoSuchMethodExcepti " [{\"@type\": \"meta::pure::changetoken::tests::OtherClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"3d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"value\":\"4d\"}\n" + - "}", Map.class); // updated version and new default value field added - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } - @Test public void testUpcastMissing() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"def\": {\"@type\":\"Custom\", \"value\":\"1d\"}},\n" + @@ -143,11 +121,7 @@ public void testUpcastMissing() throws JsonProcessingException, NoSuchMethodExce " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"def\": {\"@type\":\"Custom\", \"value\":\"3d\"}}]\n" + " ],\n" + " \"def\": {\"@type\":\"Custom\", \"value\":\"4d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("upcast", Map.class).invoke(null, jsonNode); - - Map expectedJsonNodeOut = mapper.readValue( + "}"), "{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::nested::NewSampleClass\",\n" + @@ -157,16 +131,13 @@ public void testUpcastMissing() throws JsonProcessingException, NoSuchMethodExce " [{\"@type\": \"meta::pure::changetoken::tests::nested::NewSampleClass\", \"def\": {\"@type\":\"Custom\", \"value\":\"3d\"}}]\n" + " ],\n" + " \"def\": {\"@type\":\"Custom\", \"value\":\"4d\"}\n" + - "}", Map.class); // updated version and new default value field added - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::nested::NewSampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::nested::NewSampleClass\", \"xyz\": {\"@type\":\"Custom\", \"value\":\"4d\"}},\n" + @@ -175,11 +146,7 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " [{\"@type\": \"meta::pure::changetoken::tests::nested::NewSampleClass\", \"xyz\": {\"@type\":\"Custom\", \"value\":\"2d\"}}]\n" + " ],\n" + " \"xyz\": {\"@type\":\"Custom\", \"value\":\"1d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class) - .invoke(null, jsonNode, "ftdm:abcdefg123"); - Map expectedJsonNodeOut = mapper.readValue( + "}", "ftdm:abcdefg123"), "{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -189,16 +156,13 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"2d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"value\":\"1d\"}\n" + - "}", Map.class); // remove default values - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncastType() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::OtherClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::OtherClass\", \"xyz\": {\"@type\":\"Custom\", \"value\":\"4d\"}},\n" + @@ -207,11 +171,7 @@ public void testDowncastType() throws JsonProcessingException, NoSuchMethodExcep " [{\"@type\": \"meta::pure::changetoken::tests::OtherClass\", \"xyz\": {\"@type\":\"Custom\", \"value\":\"2d\"}}]\n" + " ],\n" + " \"xyz\": {\"@type\":\"Custom\", \"value\":\"1d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class) - .invoke(null, jsonNode, "ftdm:abcdefg123"); - Map expectedJsonNodeOut = mapper.readValue( + "}", "ftdm:abcdefg123"), "{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::OtherClass\",\n" + @@ -221,16 +181,13 @@ public void testDowncastType() throws JsonProcessingException, NoSuchMethodExcep " [{\"@type\": \"meta::pure::changetoken::tests::OtherClass\", \"xyz\": {\"@type\":\"Custom\", \"value\":\"2d\"}}]\n" + " ],\n" + " \"xyz\": {\"@type\":\"Custom\", \"value\":\"1d\"}\n" + - "}", Map.class); // remove default values - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncastMissing() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::nested::NewSampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::nested::NewSampleClass\", \"def\": {\"@type\":\"Custom\", \"value\":\"4d\"}},\n" + @@ -239,11 +196,7 @@ public void testDowncastMissing() throws JsonProcessingException, NoSuchMethodEx " [{\"@type\": \"meta::pure::changetoken::tests::nested::NewSampleClass\", \"def\": {\"@type\":\"Custom\", \"value\":\"2d\"}}]\n" + " ],\n" + " \"def\": {\"@type\":\"Custom\", \"value\":\"1d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class) - .invoke(null, jsonNode, "ftdm:abcdefg123"); - Map expectedJsonNodeOut = mapper.readValue( + "}", "ftdm:abcdefg123"), "{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -253,16 +206,13 @@ public void testDowncastMissing() throws JsonProcessingException, NoSuchMethodEx " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"def\": {\"@type\":\"Custom\", \"value\":\"2d\"}}]\n" + " ],\n" + " \"def\": {\"@type\":\"Custom\", \"value\":\"1d\"}\n" + - "}", Map.class); // remove default values - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testUpcastExistingTheSame() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"1d\"}, \"xyz\": {\"@type\":\"Custom\", \"value\":\"1d\"}},\n" + @@ -271,11 +221,7 @@ public void testUpcastExistingTheSame() throws JsonProcessingException, NoSuchMe " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"3d\"}, \"xyz\": {\"@type\":\"Custom\", \"value\":\"3d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"value\":\"4d\"}, \"xyz\": {\"@type\":\"Custom\", \"value\":\"4d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("upcast", Map.class).invoke(null, jsonNode); - - Map expectedJsonNodeOut = mapper.readValue( + "}"), "{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::nested::NewSampleClass\",\n" + @@ -285,16 +231,13 @@ public void testUpcastExistingTheSame() throws JsonProcessingException, NoSuchMe " [{\"@type\": \"meta::pure::changetoken::tests::nested::NewSampleClass\", \"xyz\": {\"@type\":\"Custom\", \"value\":\"3d\"}}]\n" + " ],\n" + " \"xyz\": {\"@type\":\"Custom\", \"value\":\"4d\"}\n" + - "}", Map.class); // updated version and new default value field added - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncastExistingTheSame() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::nested::NewSampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::nested::NewSampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"5d\"}, \"xyz\": {\"@type\":\"Custom\", \"value\":\"5d\"}},\n" + @@ -303,11 +246,7 @@ public void testDowncastExistingTheSame() throws JsonProcessingException, NoSuch " [{\"@type\": \"meta::pure::changetoken::tests::nested::NewSampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"7d\"}, \"xyz\": {\"@type\":\"Custom\", \"value\":\"7d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"value\":\"8d\"}, \"xyz\": {\"@type\":\"Custom\", \"value\":\"8d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class) - .invoke(null, jsonNode, "ftdm:abcdefg123"); - Map expectedJsonNodeOut = mapper.readValue( + "}", "ftdm:abcdefg123"), "{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -317,16 +256,13 @@ public void testDowncastExistingTheSame() throws JsonProcessingException, NoSuch " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"7d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"value\":\"8d\"}\n" + - "}", Map.class); // remove default values - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testUpcastExistingTheDifferent() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + exception(() -> upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"1d\"}, \"xyz\": {\"@type\":\"Custom\", \"value\":\"1d\"}},\n" + @@ -335,19 +271,14 @@ public void testUpcastExistingTheDifferent() throws JsonProcessingException, NoS " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"3d\"}, \"xyz\": {\"@type\":\"Custom\", \"value\":\"3d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"value\":\"4d\"}, \"xyz\": {\"@type\":\"Custom\", \"value\":\"9d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Method upcastMethod = compiledClass.getMethod("upcast", Map.class); - InvocationTargetException re = assertThrows("non-default", InvocationTargetException.class, () -> upcastMethod.invoke(null, jsonNode)); - Assert.assertEquals("Cannot overwrite with different value:{@type=Custom, value=9d}", re.getCause().getMessage()); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}"), + "Cannot overwrite with different value:{@type=Custom, value=9d}"); } @Test public void testDowncastExistingTheDifferent() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + exception(() -> downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::nested::NewSampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::nested::NewSampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"5d\"}, \"xyz\": {\"@type\":\"Custom\", \"value\":\"5d\"}},\n" + @@ -356,11 +287,7 @@ public void testDowncastExistingTheDifferent() throws JsonProcessingException, N " [{\"@type\": \"meta::pure::changetoken::tests::nested::NewSampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"7d\"}, \"xyz\": {\"@type\":\"Custom\", \"value\":\"7d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"value\":\"8d\"}, \"xyz\": {\"@type\":\"Custom\", \"value\":\"9d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Method downcastMethod = compiledClass.getMethod("downcast", Map.class, String.class); - InvocationTargetException re = assertThrows("non-default", InvocationTargetException.class, () -> downcastMethod.invoke(null, jsonNode, "ftdm:abcdefg123")); - Assert.assertEquals("Cannot overwrite with different value:{@type=Custom, value=8d}", re.getCause().getMessage()); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}", "ftdm:abcdefg123"), + "Cannot overwrite with different value:{@type=Custom, value=8d}"); } } diff --git a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastRenameNestedPropertyTest.java b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastRenameNestedPropertyTest.java index 4d52fe6641c..3ce0a394284 100644 --- a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastRenameNestedPropertyTest.java +++ b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastRenameNestedPropertyTest.java @@ -15,17 +15,11 @@ package org.finos.legend.engine.changetoken.generation; import com.fasterxml.jackson.core.JsonProcessingException; -import com.fasterxml.jackson.databind.ObjectMapper; -import org.junit.Assert; import org.junit.BeforeClass; import org.junit.Test; import java.io.IOException; import java.lang.reflect.InvocationTargetException; -import java.lang.reflect.Method; -import java.util.Map; - -import static org.junit.Assert.assertThrows; public class GenerateCastRenameNestedPropertyTest extends GenerateCastTestBase { @@ -65,8 +59,7 @@ public static void setupSuite() throws IOException, ClassNotFoundException @Test public void testUpcast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"1d\"}},\n" + @@ -75,11 +68,7 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"3d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"value\":\"4d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("upcast", Map.class).invoke(null, jsonNode); - - Map expectedJsonNodeOut = mapper.readValue( + "}"), "{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -89,16 +78,13 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"valueCustom\":\"3d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"valueCustom\":\"4d\"}\n" + - "}", Map.class); // updated version and new default value field added - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testUpcastType() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::OtherClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::OtherClass\", \"abc\": {\"@type\":\"OtherCustom\", \"value\":\"1d\"}},\n" + @@ -107,11 +93,7 @@ public void testUpcastType() throws JsonProcessingException, NoSuchMethodExcepti " [{\"@type\": \"meta::pure::changetoken::tests::OtherClass\", \"abc\": {\"@type\":\"OtherCustom\", \"value\":\"3d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"OtherCustom\", \"value\":\"4d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("upcast", Map.class).invoke(null, jsonNode); - - Map expectedJsonNodeOut = mapper.readValue( + "}"), "{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::OtherClass\",\n" + @@ -121,17 +103,13 @@ public void testUpcastType() throws JsonProcessingException, NoSuchMethodExcepti " [{\"@type\": \"meta::pure::changetoken::tests::OtherClass\", \"abc\": {\"@type\":\"OtherCustom\", \"value\":\"3d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"OtherCustom\", \"value\":\"4d\"}\n" + - "}", Map.class); // updated version and new default value field added - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } - @Test public void testUpcastMissing() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"def\": {\"@type\":\"Custom\", \"valueOther\":\"1d\"}},\n" + @@ -140,11 +118,7 @@ public void testUpcastMissing() throws JsonProcessingException, NoSuchMethodExce " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"def\": {\"@type\":\"Custom\", \"valueOther\":\"3d\"}}]\n" + " ],\n" + " \"def\": {\"@type\":\"Custom\", \"valueOther\":\"4d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("upcast", Map.class).invoke(null, jsonNode); - - Map expectedJsonNodeOut = mapper.readValue( + "}"), "{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -154,16 +128,13 @@ public void testUpcastMissing() throws JsonProcessingException, NoSuchMethodExce " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"def\": {\"@type\":\"Custom\", \"valueOther\":\"3d\"}}]\n" + " ],\n" + " \"def\": {\"@type\":\"Custom\", \"valueOther\":\"4d\"}\n" + - "}", Map.class); // updated version and new default value field added - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"valueCustom\":\"4d\"}},\n" + @@ -172,11 +143,7 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"valueCustom\":\"2d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"valueCustom\":\"1d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class) - .invoke(null, jsonNode, "ftdm:abcdefg123"); - Map expectedJsonNodeOut = mapper.readValue( + "}", "ftdm:abcdefg123"), "{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -186,16 +153,13 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"2d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"value\":\"1d\"}\n" + - "}", Map.class); // remove default values - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncastType() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::OtherClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::OtherClass\", \"abc\": {\"@type\":\"OtherCustom\", \"value\":\"4d\"}},\n" + @@ -204,11 +168,7 @@ public void testDowncastType() throws JsonProcessingException, NoSuchMethodExcep " [{\"@type\": \"meta::pure::changetoken::tests::OtherClass\", \"abc\": {\"@type\":\"OtherCustom\", \"value\":\"2d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"OtherCustom\", \"value\":\"1d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class) - .invoke(null, jsonNode, "ftdm:abcdefg123"); - Map expectedJsonNodeOut = mapper.readValue( + "}", "ftdm:abcdefg123"), "{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::OtherClass\",\n" + @@ -218,16 +178,13 @@ public void testDowncastType() throws JsonProcessingException, NoSuchMethodExcep " [{\"@type\": \"meta::pure::changetoken::tests::OtherClass\", \"abc\": {\"@type\":\"OtherCustom\", \"value\":\"2d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"OtherCustom\", \"value\":\"1d\"}\n" + - "}", Map.class); // remove default values - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncastMissing() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"def\": {\"@type\":\"Custom\", \"valueOther\":\"4d\"}},\n" + @@ -236,11 +193,7 @@ public void testDowncastMissing() throws JsonProcessingException, NoSuchMethodEx " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"def\": {\"@type\":\"Custom\", \"valueOther\":\"2d\"}}]\n" + " ],\n" + " \"def\": {\"@type\":\"Custom\", \"value\":\"1d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class) - .invoke(null, jsonNode, "ftdm:abcdefg123"); - Map expectedJsonNodeOut = mapper.readValue( + "}", "ftdm:abcdefg123"), "{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -250,16 +203,13 @@ public void testDowncastMissing() throws JsonProcessingException, NoSuchMethodEx " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"def\": {\"@type\":\"Custom\", \"valueOther\":\"2d\"}}]\n" + " ],\n" + " \"def\": {\"@type\":\"Custom\", \"value\":\"1d\"}\n" + - "}", Map.class); // remove default values - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testUpcastExistingTheSame() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"1d\", \"valueCustom\":\"1d\"}},\n" + @@ -268,11 +218,7 @@ public void testUpcastExistingTheSame() throws JsonProcessingException, NoSuchMe " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"3d\", \"valueCustom\":\"3d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"value\":\"4d\", \"valueCustom\":\"4d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("upcast", Map.class).invoke(null, jsonNode); - - Map expectedJsonNodeOut = mapper.readValue( + "}"), "{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -282,16 +228,13 @@ public void testUpcastExistingTheSame() throws JsonProcessingException, NoSuchMe " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"valueCustom\":\"3d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"valueCustom\":\"4d\"}\n" + - "}", Map.class); // updated version and new default value field added - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncastExistingTheSame() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"5d\", \"valueCustom\":\"5d\"}},\n" + @@ -300,11 +243,7 @@ public void testDowncastExistingTheSame() throws JsonProcessingException, NoSuch " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"7d\", \"valueCustom\":\"7d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"value\":\"8d\", \"valueCustom\":\"8d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class) - .invoke(null, jsonNode, "ftdm:abcdefg123"); - Map expectedJsonNodeOut = mapper.readValue( + "}", "ftdm:abcdefg123"), "{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -314,16 +253,13 @@ public void testDowncastExistingTheSame() throws JsonProcessingException, NoSuch " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"7d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"value\":\"8d\"}\n" + - "}", Map.class); // remove default values - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testUpcastExistingTheDifferent() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + exception(() -> upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"1d\", \"valueCustom\":\"1d\"}},\n" + @@ -332,19 +268,14 @@ public void testUpcastExistingTheDifferent() throws JsonProcessingException, NoS " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"3d\", \"valueCustom\":\"3d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"value\":\"4d\", \"valueCustom\":\"9d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Method upcastMethod = compiledClass.getMethod("upcast", Map.class); - InvocationTargetException re = assertThrows("non-default", InvocationTargetException.class, () -> upcastMethod.invoke(null, jsonNode)); - Assert.assertEquals("Cannot overwrite with different value:9d", re.getCause().getMessage()); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); - } + "}"), + "Cannot overwrite with different value:9d"); + } @Test public void testDowncastExistingTheDifferent() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + exception(() -> downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"5d\", \"valueCustom\":\"5d\"}},\n" + @@ -353,11 +284,7 @@ public void testDowncastExistingTheDifferent() throws JsonProcessingException, N " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"7d\", \"valueCustom\":\"7d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"value\":\"8d\", \"valueCustom\":\"9d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Method downcastMethod = compiledClass.getMethod("downcast", Map.class, String.class); - InvocationTargetException re = assertThrows("non-default", InvocationTargetException.class, () -> downcastMethod.invoke(null, jsonNode, "ftdm:abcdefg123")); - Assert.assertEquals("Cannot overwrite with different value:8d", re.getCause().getMessage()); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}", "ftdm:abcdefg123"), + "Cannot overwrite with different value:8d"); } } diff --git a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastRenamePropertyTest.java b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastRenamePropertyTest.java index 014d52358fa..0458f6c6aba 100644 --- a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastRenamePropertyTest.java +++ b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastRenamePropertyTest.java @@ -15,17 +15,11 @@ package org.finos.legend.engine.changetoken.generation; import com.fasterxml.jackson.core.JsonProcessingException; -import com.fasterxml.jackson.databind.ObjectMapper; -import org.junit.Assert; import org.junit.BeforeClass; import org.junit.Test; import java.io.IOException; import java.lang.reflect.InvocationTargetException; -import java.lang.reflect.Method; -import java.util.Map; - -import static org.junit.Assert.assertThrows; public class GenerateCastRenamePropertyTest extends GenerateCastTestBase { @@ -63,8 +57,7 @@ public static void setupSuite() throws IOException, ClassNotFoundException @Test public void testUpcast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"1d\"}},\n" + @@ -73,11 +66,7 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"3d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"value\":\"4d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("upcast", Map.class).invoke(null, jsonNode); - - Map expectedJsonNodeOut = mapper.readValue( + "}"), "{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -87,16 +76,13 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"valueCustom\":\"3d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"valueCustom\":\"4d\"}\n" + - "}", Map.class); // updated version and new default value field added - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testUpcastType() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::OtherClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::OtherClass\", \"abc\": {\"@type\":\"OtherCustom\", \"value\":\"1d\"}},\n" + @@ -105,11 +91,7 @@ public void testUpcastType() throws JsonProcessingException, NoSuchMethodExcepti " [{\"@type\": \"meta::pure::changetoken::tests::OtherClass\", \"abc\": {\"@type\":\"OtherCustom\", \"value\":\"3d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"OtherCustom\", \"value\":\"4d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("upcast", Map.class).invoke(null, jsonNode); - - Map expectedJsonNodeOut = mapper.readValue( + "}"), "{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::OtherClass\",\n" + @@ -119,17 +101,13 @@ public void testUpcastType() throws JsonProcessingException, NoSuchMethodExcepti " [{\"@type\": \"meta::pure::changetoken::tests::OtherClass\", \"abc\": {\"@type\":\"OtherCustom\", \"value\":\"3d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"OtherCustom\", \"value\":\"4d\"}\n" + - "}", Map.class); // updated version and new default value field added - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } - @Test public void testUpcastMissing() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"def\": {\"@type\":\"Custom\", \"valueOther\":\"1d\"}},\n" + @@ -138,11 +116,7 @@ public void testUpcastMissing() throws JsonProcessingException, NoSuchMethodExce " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"def\": {\"@type\":\"Custom\", \"valueOther\":\"3d\"}}]\n" + " ],\n" + " \"def\": {\"@type\":\"Custom\", \"valueOther\":\"4d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("upcast", Map.class).invoke(null, jsonNode); - - Map expectedJsonNodeOut = mapper.readValue( + "}"), "{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -152,16 +126,13 @@ public void testUpcastMissing() throws JsonProcessingException, NoSuchMethodExce " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"def\": {\"@type\":\"Custom\", \"valueOther\":\"3d\"}}]\n" + " ],\n" + " \"def\": {\"@type\":\"Custom\", \"valueOther\":\"4d\"}\n" + - "}", Map.class); // updated version and new default value field added - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"xyz\": {\"@type\":\"Custom\", \"valueCustom\":\"4d\"}},\n" + @@ -170,11 +141,7 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"xyz\": {\"@type\":\"Custom\", \"valueCustom\":\"2d\"}}]\n" + " ],\n" + " \"xyz\": {\"@type\":\"Custom\", \"valueCustom\":\"1d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class) - .invoke(null, jsonNode, "ftdm:abcdefg123"); - Map expectedJsonNodeOut = mapper.readValue( + "}", "ftdm:abcdefg123"), "{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -184,16 +151,13 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"xyz\": {\"@type\":\"Custom\", \"value\":\"2d\"}}]\n" + " ],\n" + " \"xyz\": {\"@type\":\"Custom\", \"value\":\"1d\"}\n" + - "}", Map.class); // remove default values - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncastType() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::OtherClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::OtherClass\", \"xyz\": {\"@type\":\"OtherCustom\", \"value\":\"4d\"}},\n" + @@ -202,11 +166,7 @@ public void testDowncastType() throws JsonProcessingException, NoSuchMethodExcep " [{\"@type\": \"meta::pure::changetoken::tests::OtherClass\", \"xyz\": {\"@type\":\"OtherCustom\", \"value\":\"2d\"}}]\n" + " ],\n" + " \"xyz\": {\"@type\":\"OtherCustom\", \"value\":\"1d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class) - .invoke(null, jsonNode, "ftdm:abcdefg123"); - Map expectedJsonNodeOut = mapper.readValue( + "}", "ftdm:abcdefg123"), "{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::OtherClass\",\n" + @@ -216,16 +176,13 @@ public void testDowncastType() throws JsonProcessingException, NoSuchMethodExcep " [{\"@type\": \"meta::pure::changetoken::tests::OtherClass\", \"xyz\": {\"@type\":\"OtherCustom\", \"value\":\"2d\"}}]\n" + " ],\n" + " \"xyz\": {\"@type\":\"OtherCustom\", \"value\":\"1d\"}\n" + - "}", Map.class); // remove default values - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncastMissing() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"def\": {\"@type\":\"Custom\", \"valueOther\":\"4d\"}},\n" + @@ -234,11 +191,7 @@ public void testDowncastMissing() throws JsonProcessingException, NoSuchMethodEx " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"def\": {\"@type\":\"Custom\", \"valueOther\":\"2d\"}}]\n" + " ],\n" + " \"def\": {\"@type\":\"Custom\", \"value\":\"1d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class) - .invoke(null, jsonNode, "ftdm:abcdefg123"); - Map expectedJsonNodeOut = mapper.readValue( + "}", "ftdm:abcdefg123"), "{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -248,16 +201,13 @@ public void testDowncastMissing() throws JsonProcessingException, NoSuchMethodEx " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"def\": {\"@type\":\"Custom\", \"valueOther\":\"2d\"}}]\n" + " ],\n" + " \"def\": {\"@type\":\"Custom\", \"value\":\"1d\"}\n" + - "}", Map.class); // remove default values - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testUpcastExistingTheSame() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"1d\", \"valueCustom\":\"1d\"}},\n" + @@ -266,11 +216,7 @@ public void testUpcastExistingTheSame() throws JsonProcessingException, NoSuchMe " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"3d\", \"valueCustom\":\"3d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"value\":\"4d\", \"valueCustom\":\"4d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("upcast", Map.class).invoke(null, jsonNode); - - Map expectedJsonNodeOut = mapper.readValue( + "}"), "{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -280,16 +226,13 @@ public void testUpcastExistingTheSame() throws JsonProcessingException, NoSuchMe " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"valueCustom\":\"3d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"valueCustom\":\"4d\"}\n" + - "}", Map.class); // updated version and new default value field added - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncastExistingTheSame() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"5d\", \"valueCustom\":\"5d\"}},\n" + @@ -298,11 +241,7 @@ public void testDowncastExistingTheSame() throws JsonProcessingException, NoSuch " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"7d\", \"valueCustom\":\"7d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"value\":\"8d\", \"valueCustom\":\"8d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class) - .invoke(null, jsonNode, "ftdm:abcdefg123"); - Map expectedJsonNodeOut = mapper.readValue( + "}", "ftdm:abcdefg123"), "{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -312,16 +251,13 @@ public void testDowncastExistingTheSame() throws JsonProcessingException, NoSuch " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"7d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"value\":\"8d\"}\n" + - "}", Map.class); // remove default values - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testUpcastExistingTheDifferent() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + exception(() -> upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"1d\", \"valueCustom\":\"1d\"}},\n" + @@ -330,19 +266,14 @@ public void testUpcastExistingTheDifferent() throws JsonProcessingException, NoS " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"3d\", \"valueCustom\":\"3d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"value\":\"4d\", \"valueCustom\":\"9d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Method upcastMethod = compiledClass.getMethod("upcast", Map.class); - InvocationTargetException re = assertThrows("non-default", InvocationTargetException.class, () -> upcastMethod.invoke(null, jsonNode)); - Assert.assertEquals("Cannot overwrite with different value:9d", re.getCause().getMessage()); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); - } + "}"), + "Cannot overwrite with different value:9d"); + } @Test public void testDowncastExistingTheDifferent() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + exception(() -> downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"5d\", \"valueCustom\":\"5d\"}},\n" + @@ -351,11 +282,7 @@ public void testDowncastExistingTheDifferent() throws JsonProcessingException, N " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"7d\", \"valueCustom\":\"7d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"value\":\"8d\", \"valueCustom\":\"9d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Method downcastMethod = compiledClass.getMethod("downcast", Map.class, String.class); - InvocationTargetException re = assertThrows("non-default", InvocationTargetException.class, () -> downcastMethod.invoke(null, jsonNode, "ftdm:abcdefg123")); - Assert.assertEquals("Cannot overwrite with different value:8d", re.getCause().getMessage()); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}", "ftdm:abcdefg123"), + "Cannot overwrite with different value:8d"); } } diff --git a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastRenameTest.java b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastRenameTest.java index f345a9017f9..4fa70b49728 100644 --- a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastRenameTest.java +++ b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastRenameTest.java @@ -15,17 +15,11 @@ package org.finos.legend.engine.changetoken.generation; import com.fasterxml.jackson.core.JsonProcessingException; -import com.fasterxml.jackson.databind.ObjectMapper; -import org.junit.Assert; import org.junit.BeforeClass; import org.junit.Test; import java.io.IOException; import java.lang.reflect.InvocationTargetException; -import java.lang.reflect.Method; -import java.util.Map; - -import static org.junit.Assert.assertThrows; public class GenerateCastRenameTest extends GenerateCastTestBase { @@ -63,8 +57,7 @@ public static void setupSuite() throws IOException, ClassNotFoundException @Test public void testUpcast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"1d\"}},\n" + @@ -73,11 +66,7 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"3d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"value\":\"4d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("upcast", Map.class).invoke(null, jsonNode); - - Map expectedJsonNodeOut = mapper.readValue( + "}"), "{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -87,16 +76,13 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"xyz\": {\"@type\":\"Custom\", \"value\":\"3d\"}}]\n" + " ],\n" + " \"xyz\": {\"@type\":\"Custom\", \"value\":\"4d\"}\n" + - "}", Map.class); // updated version and new default value field added - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testUpcastType() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::OtherClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::OtherClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"1d\"}},\n" + @@ -105,11 +91,7 @@ public void testUpcastType() throws JsonProcessingException, NoSuchMethodExcepti " [{\"@type\": \"meta::pure::changetoken::tests::OtherClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"3d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"value\":\"4d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("upcast", Map.class).invoke(null, jsonNode); - - Map expectedJsonNodeOut = mapper.readValue( + "}"), "{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::OtherClass\",\n" + @@ -119,17 +101,13 @@ public void testUpcastType() throws JsonProcessingException, NoSuchMethodExcepti " [{\"@type\": \"meta::pure::changetoken::tests::OtherClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"3d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"value\":\"4d\"}\n" + - "}", Map.class); // updated version and new default value field added - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } - @Test public void testUpcastMissing() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"def\": {\"@type\":\"Custom\", \"value\":\"1d\"}},\n" + @@ -138,11 +116,7 @@ public void testUpcastMissing() throws JsonProcessingException, NoSuchMethodExce " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"def\": {\"@type\":\"Custom\", \"value\":\"3d\"}}]\n" + " ],\n" + " \"def\": {\"@type\":\"Custom\", \"value\":\"4d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("upcast", Map.class).invoke(null, jsonNode); - - Map expectedJsonNodeOut = mapper.readValue( + "}"), "{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -152,16 +126,13 @@ public void testUpcastMissing() throws JsonProcessingException, NoSuchMethodExce " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"def\": {\"@type\":\"Custom\", \"value\":\"3d\"}}]\n" + " ],\n" + " \"def\": {\"@type\":\"Custom\", \"value\":\"4d\"}\n" + - "}", Map.class); // updated version and new default value field added - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"xyz\": {\"@type\":\"Custom\", \"value\":\"4d\"}},\n" + @@ -170,11 +141,7 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"xyz\": {\"@type\":\"Custom\", \"value\":\"2d\"}}]\n" + " ],\n" + " \"xyz\": {\"@type\":\"Custom\", \"value\":\"1d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class) - .invoke(null, jsonNode, "ftdm:abcdefg123"); - Map expectedJsonNodeOut = mapper.readValue( + "}", "ftdm:abcdefg123"), "{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -184,16 +151,13 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"2d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"value\":\"1d\"}\n" + - "}", Map.class); // remove default values - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncastType() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::OtherClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::OtherClass\", \"xyz\": {\"@type\":\"Custom\", \"value\":\"4d\"}},\n" + @@ -202,11 +166,7 @@ public void testDowncastType() throws JsonProcessingException, NoSuchMethodExcep " [{\"@type\": \"meta::pure::changetoken::tests::OtherClass\", \"xyz\": {\"@type\":\"Custom\", \"value\":\"2d\"}}]\n" + " ],\n" + " \"xyz\": {\"@type\":\"Custom\", \"value\":\"1d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class) - .invoke(null, jsonNode, "ftdm:abcdefg123"); - Map expectedJsonNodeOut = mapper.readValue( + "}", "ftdm:abcdefg123"), "{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::OtherClass\",\n" + @@ -216,16 +176,13 @@ public void testDowncastType() throws JsonProcessingException, NoSuchMethodExcep " [{\"@type\": \"meta::pure::changetoken::tests::OtherClass\", \"xyz\": {\"@type\":\"Custom\", \"value\":\"2d\"}}]\n" + " ],\n" + " \"xyz\": {\"@type\":\"Custom\", \"value\":\"1d\"}\n" + - "}", Map.class); // remove default values - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncastMissing() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"def\": {\"@type\":\"Custom\", \"value\":\"4d\"}},\n" + @@ -234,11 +191,7 @@ public void testDowncastMissing() throws JsonProcessingException, NoSuchMethodEx " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"def\": {\"@type\":\"Custom\", \"value\":\"2d\"}}]\n" + " ],\n" + " \"def\": {\"@type\":\"Custom\", \"value\":\"1d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class) - .invoke(null, jsonNode, "ftdm:abcdefg123"); - Map expectedJsonNodeOut = mapper.readValue( + "}", "ftdm:abcdefg123"), "{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -248,16 +201,13 @@ public void testDowncastMissing() throws JsonProcessingException, NoSuchMethodEx " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"def\": {\"@type\":\"Custom\", \"value\":\"2d\"}}]\n" + " ],\n" + " \"def\": {\"@type\":\"Custom\", \"value\":\"1d\"}\n" + - "}", Map.class); // remove default values - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testUpcastExistingTheSame() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"1d\"}, \"xyz\": {\"@type\":\"Custom\", \"value\":\"1d\"}},\n" + @@ -266,11 +216,7 @@ public void testUpcastExistingTheSame() throws JsonProcessingException, NoSuchMe " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"3d\"}, \"xyz\": {\"@type\":\"Custom\", \"value\":\"3d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"value\":\"4d\"}, \"xyz\": {\"@type\":\"Custom\", \"value\":\"4d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("upcast", Map.class).invoke(null, jsonNode); - - Map expectedJsonNodeOut = mapper.readValue( + "}"), "{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -280,16 +226,13 @@ public void testUpcastExistingTheSame() throws JsonProcessingException, NoSuchMe " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"xyz\": {\"@type\":\"Custom\", \"value\":\"3d\"}}]\n" + " ],\n" + " \"xyz\": {\"@type\":\"Custom\", \"value\":\"4d\"}\n" + - "}", Map.class); // updated version and new default value field added - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncastExistingTheSame() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"5d\"}, \"xyz\": {\"@type\":\"Custom\", \"value\":\"5d\"}},\n" + @@ -298,11 +241,7 @@ public void testDowncastExistingTheSame() throws JsonProcessingException, NoSuch " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"7d\"}, \"xyz\": {\"@type\":\"Custom\", \"value\":\"7d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"value\":\"8d\"}, \"xyz\": {\"@type\":\"Custom\", \"value\":\"8d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class) - .invoke(null, jsonNode, "ftdm:abcdefg123"); - Map expectedJsonNodeOut = mapper.readValue( + "}", "ftdm:abcdefg123"), "{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -312,16 +251,13 @@ public void testDowncastExistingTheSame() throws JsonProcessingException, NoSuch " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"7d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"value\":\"8d\"}\n" + - "}", Map.class); // remove default values - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testUpcastExistingTheDifferent() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + exception(() -> upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"1d\"}, \"xyz\": {\"@type\":\"Custom\", \"value\":\"1d\"}},\n" + @@ -330,19 +266,14 @@ public void testUpcastExistingTheDifferent() throws JsonProcessingException, NoS " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"3d\"}, \"xyz\": {\"@type\":\"Custom\", \"value\":\"3d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"value\":\"4d\"}, \"xyz\": {\"@type\":\"Custom\", \"value\":\"9d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Method upcastMethod = compiledClass.getMethod("upcast", Map.class); - InvocationTargetException re = assertThrows("non-default", InvocationTargetException.class, () -> upcastMethod.invoke(null, jsonNode)); - Assert.assertEquals("Cannot overwrite with different value:{@type=Custom, value=9d}", re.getCause().getMessage()); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); - } + "}"), + "Cannot overwrite with different value:{@type=Custom, value=9d}"); + } @Test public void testDowncastExistingTheDifferent() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + exception(() -> downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"5d\"}, \"xyz\": {\"@type\":\"Custom\", \"value\":\"5d\"}},\n" + @@ -351,11 +282,7 @@ public void testDowncastExistingTheDifferent() throws JsonProcessingException, N " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"7d\"}, \"xyz\": {\"@type\":\"Custom\", \"value\":\"7d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"value\":\"8d\"}, \"xyz\": {\"@type\":\"Custom\", \"value\":\"9d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Method downcastMethod = compiledClass.getMethod("downcast", Map.class, String.class); - InvocationTargetException re = assertThrows("non-default", InvocationTargetException.class, () -> downcastMethod.invoke(null, jsonNode, "ftdm:abcdefg123")); - Assert.assertEquals("Cannot overwrite with different value:{@type=Custom, value=8d}", re.getCause().getMessage()); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}", "ftdm:abcdefg123"), + "Cannot overwrite with different value:{@type=Custom, value=8d}"); } } diff --git a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastRenamedClassRenameFieldTest.java b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastRenamedClassRenameFieldTest.java index dd777085af9..45442796a27 100644 --- a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastRenamedClassRenameFieldTest.java +++ b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastRenamedClassRenameFieldTest.java @@ -15,17 +15,11 @@ package org.finos.legend.engine.changetoken.generation; import com.fasterxml.jackson.core.JsonProcessingException; -import com.fasterxml.jackson.databind.ObjectMapper; -import org.junit.Assert; import org.junit.BeforeClass; import org.junit.Test; import java.io.IOException; import java.lang.reflect.InvocationTargetException; -import java.lang.reflect.Method; -import java.util.Map; - -import static org.junit.Assert.assertThrows; public class GenerateCastRenamedClassRenameFieldTest extends GenerateCastTestBase { @@ -68,8 +62,7 @@ public static void setupSuite() throws IOException, ClassNotFoundException @Test public void testUpcast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"1d\"}},\n" + @@ -78,11 +71,7 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"3d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"value\":\"4d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("upcast", Map.class).invoke(null, jsonNode); - - Map expectedJsonNodeOut = mapper.readValue( + "}"), "{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::nested::NewSampleClass\",\n" + @@ -92,16 +81,13 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " [{\"@type\": \"meta::pure::changetoken::tests::nested::NewSampleClass\", \"xyz\": {\"@type\":\"Custom\", \"value\":\"3d\"}}]\n" + " ],\n" + " \"xyz\": {\"@type\":\"Custom\", \"value\":\"4d\"}\n" + - "}", Map.class); // updated version and new default value field added - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testUpcastType() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::OtherClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::OtherClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"1d\"}},\n" + @@ -110,11 +96,7 @@ public void testUpcastType() throws JsonProcessingException, NoSuchMethodExcepti " [{\"@type\": \"meta::pure::changetoken::tests::OtherClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"3d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"value\":\"4d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("upcast", Map.class).invoke(null, jsonNode); - - Map expectedJsonNodeOut = mapper.readValue( + "}"), "{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::OtherClass\",\n" + @@ -124,17 +106,13 @@ public void testUpcastType() throws JsonProcessingException, NoSuchMethodExcepti " [{\"@type\": \"meta::pure::changetoken::tests::OtherClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"3d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"value\":\"4d\"}\n" + - "}", Map.class); // updated version and new default value field added - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } - @Test public void testUpcastMissing() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"def\": {\"@type\":\"Custom\", \"value\":\"1d\"}},\n" + @@ -143,11 +121,7 @@ public void testUpcastMissing() throws JsonProcessingException, NoSuchMethodExce " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"def\": {\"@type\":\"Custom\", \"value\":\"3d\"}}]\n" + " ],\n" + " \"def\": {\"@type\":\"Custom\", \"value\":\"4d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("upcast", Map.class).invoke(null, jsonNode); - - Map expectedJsonNodeOut = mapper.readValue( + "}"), "{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::nested::NewSampleClass\",\n" + @@ -157,16 +131,13 @@ public void testUpcastMissing() throws JsonProcessingException, NoSuchMethodExce " [{\"@type\": \"meta::pure::changetoken::tests::nested::NewSampleClass\", \"def\": {\"@type\":\"Custom\", \"value\":\"3d\"}}]\n" + " ],\n" + " \"def\": {\"@type\":\"Custom\", \"value\":\"4d\"}\n" + - "}", Map.class); // updated version and new default value field added - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::nested::NewSampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::nested::NewSampleClass\", \"xyz\": {\"@type\":\"Custom\", \"value\":\"4d\"}},\n" + @@ -175,11 +146,7 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " [{\"@type\": \"meta::pure::changetoken::tests::nested::NewSampleClass\", \"xyz\": {\"@type\":\"Custom\", \"value\":\"2d\"}}]\n" + " ],\n" + " \"xyz\": {\"@type\":\"Custom\", \"value\":\"1d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class) - .invoke(null, jsonNode, "ftdm:abcdefg123"); - Map expectedJsonNodeOut = mapper.readValue( + "}", "ftdm:abcdefg123"), "{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -189,16 +156,13 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"2d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"value\":\"1d\"}\n" + - "}", Map.class); // remove default values - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncastType() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::OtherClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::OtherClass\", \"xyz\": {\"@type\":\"Custom\", \"value\":\"4d\"}},\n" + @@ -207,11 +171,7 @@ public void testDowncastType() throws JsonProcessingException, NoSuchMethodExcep " [{\"@type\": \"meta::pure::changetoken::tests::OtherClass\", \"xyz\": {\"@type\":\"Custom\", \"value\":\"2d\"}}]\n" + " ],\n" + " \"xyz\": {\"@type\":\"Custom\", \"value\":\"1d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class) - .invoke(null, jsonNode, "ftdm:abcdefg123"); - Map expectedJsonNodeOut = mapper.readValue( + "}", "ftdm:abcdefg123"), "{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::OtherClass\",\n" + @@ -221,16 +181,13 @@ public void testDowncastType() throws JsonProcessingException, NoSuchMethodExcep " [{\"@type\": \"meta::pure::changetoken::tests::OtherClass\", \"xyz\": {\"@type\":\"Custom\", \"value\":\"2d\"}}]\n" + " ],\n" + " \"xyz\": {\"@type\":\"Custom\", \"value\":\"1d\"}\n" + - "}", Map.class); // remove default values - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncastMissing() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::nested::NewSampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::nested::NewSampleClass\", \"def\": {\"@type\":\"Custom\", \"value\":\"4d\"}},\n" + @@ -239,11 +196,7 @@ public void testDowncastMissing() throws JsonProcessingException, NoSuchMethodEx " [{\"@type\": \"meta::pure::changetoken::tests::nested::NewSampleClass\", \"def\": {\"@type\":\"Custom\", \"value\":\"2d\"}}]\n" + " ],\n" + " \"def\": {\"@type\":\"Custom\", \"value\":\"1d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class) - .invoke(null, jsonNode, "ftdm:abcdefg123"); - Map expectedJsonNodeOut = mapper.readValue( + "}", "ftdm:abcdefg123"), "{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -253,16 +206,13 @@ public void testDowncastMissing() throws JsonProcessingException, NoSuchMethodEx " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"def\": {\"@type\":\"Custom\", \"value\":\"2d\"}}]\n" + " ],\n" + " \"def\": {\"@type\":\"Custom\", \"value\":\"1d\"}\n" + - "}", Map.class); // remove default values - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testUpcastExistingTheSame() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"1d\"}, \"xyz\": {\"@type\":\"Custom\", \"value\":\"1d\"}},\n" + @@ -271,11 +221,7 @@ public void testUpcastExistingTheSame() throws JsonProcessingException, NoSuchMe " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"3d\"}, \"xyz\": {\"@type\":\"Custom\", \"value\":\"3d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"value\":\"4d\"}, \"xyz\": {\"@type\":\"Custom\", \"value\":\"4d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("upcast", Map.class).invoke(null, jsonNode); - - Map expectedJsonNodeOut = mapper.readValue( + "}"), "{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::nested::NewSampleClass\",\n" + @@ -285,16 +231,13 @@ public void testUpcastExistingTheSame() throws JsonProcessingException, NoSuchMe " [{\"@type\": \"meta::pure::changetoken::tests::nested::NewSampleClass\", \"xyz\": {\"@type\":\"Custom\", \"value\":\"3d\"}}]\n" + " ],\n" + " \"xyz\": {\"@type\":\"Custom\", \"value\":\"4d\"}\n" + - "}", Map.class); // updated version and new default value field added - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncastExistingTheSame() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::nested::NewSampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::nested::NewSampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"5d\"}, \"xyz\": {\"@type\":\"Custom\", \"value\":\"5d\"}},\n" + @@ -303,11 +246,7 @@ public void testDowncastExistingTheSame() throws JsonProcessingException, NoSuch " [{\"@type\": \"meta::pure::changetoken::tests::nested::NewSampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"7d\"}, \"xyz\": {\"@type\":\"Custom\", \"value\":\"7d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"value\":\"8d\"}, \"xyz\": {\"@type\":\"Custom\", \"value\":\"8d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class) - .invoke(null, jsonNode, "ftdm:abcdefg123"); - Map expectedJsonNodeOut = mapper.readValue( + "}", "ftdm:abcdefg123"), "{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -317,16 +256,13 @@ public void testDowncastExistingTheSame() throws JsonProcessingException, NoSuch " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"7d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"value\":\"8d\"}\n" + - "}", Map.class); // remove default values - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testUpcastExistingTheDifferent() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + exception(() -> upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"1d\"}, \"xyz\": {\"@type\":\"Custom\", \"value\":\"1d\"}},\n" + @@ -335,19 +271,14 @@ public void testUpcastExistingTheDifferent() throws JsonProcessingException, NoS " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"3d\"}, \"xyz\": {\"@type\":\"Custom\", \"value\":\"3d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"value\":\"4d\"}, \"xyz\": {\"@type\":\"Custom\", \"value\":\"9d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Method upcastMethod = compiledClass.getMethod("upcast", Map.class); - InvocationTargetException re = assertThrows("non-default", InvocationTargetException.class, () -> upcastMethod.invoke(null, jsonNode)); - Assert.assertEquals("Cannot overwrite with different value:{@type=Custom, value=9d}", re.getCause().getMessage()); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}"), + "Cannot overwrite with different value:{@type=Custom, value=9d}"); } @Test public void testDowncastExistingTheDifferent() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + exception(() -> downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::nested::NewSampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::nested::NewSampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"5d\"}, \"xyz\": {\"@type\":\"Custom\", \"value\":\"5d\"}},\n" + @@ -356,11 +287,7 @@ public void testDowncastExistingTheDifferent() throws JsonProcessingException, N " [{\"@type\": \"meta::pure::changetoken::tests::nested::NewSampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"7d\"}, \"xyz\": {\"@type\":\"Custom\", \"value\":\"7d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"value\":\"8d\"}, \"xyz\": {\"@type\":\"Custom\", \"value\":\"9d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Method downcastMethod = compiledClass.getMethod("downcast", Map.class, String.class); - InvocationTargetException re = assertThrows("non-default", InvocationTargetException.class, () -> downcastMethod.invoke(null, jsonNode, "ftdm:abcdefg123")); - Assert.assertEquals("Cannot overwrite with different value:{@type=Custom, value=8d}", re.getCause().getMessage()); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}", "ftdm:abcdefg123"), + "Cannot overwrite with different value:{@type=Custom, value=8d}"); } } diff --git a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastRenamedClassTest.java b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastRenamedClassTest.java index c84b7a95b88..79c6b745cd6 100644 --- a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastRenamedClassTest.java +++ b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastRenamedClassTest.java @@ -15,17 +15,11 @@ package org.finos.legend.engine.changetoken.generation; import com.fasterxml.jackson.core.JsonProcessingException; -import com.fasterxml.jackson.databind.ObjectMapper; -import org.junit.Assert; import org.junit.BeforeClass; import org.junit.Test; import java.io.IOException; import java.lang.reflect.InvocationTargetException; -import java.lang.reflect.Method; -import java.util.Map; - -import static org.junit.Assert.assertThrows; public class GenerateCastRenamedClassTest extends GenerateCastTestBase { @@ -58,8 +52,7 @@ public static void setupSuite() throws IOException, ClassNotFoundException @Test public void testUpcast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"1d\"}},\n" + @@ -68,11 +61,7 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"3d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"value\":\"4d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("upcast", Map.class).invoke(null, jsonNode); - - Map expectedJsonNodeOut = mapper.readValue( + "}"), "{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::nested::NewSampleClass\",\n" + @@ -82,16 +71,13 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " [{\"@type\": \"meta::pure::changetoken::tests::nested::NewSampleClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"3d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"value\":\"4d\"}\n" + - "}", Map.class); // updated version and new default value field added - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testUpcastType() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::OtherClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::OtherClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"1d\"}},\n" + @@ -100,11 +86,7 @@ public void testUpcastType() throws JsonProcessingException, NoSuchMethodExcepti " [{\"@type\": \"meta::pure::changetoken::tests::OtherClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"3d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"value\":\"4d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("upcast", Map.class).invoke(null, jsonNode); - - Map expectedJsonNodeOut = mapper.readValue( + "}"), "{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::OtherClass\",\n" + @@ -114,16 +96,13 @@ public void testUpcastType() throws JsonProcessingException, NoSuchMethodExcepti " [{\"@type\": \"meta::pure::changetoken::tests::OtherClass\", \"abc\": {\"@type\":\"Custom\", \"value\":\"3d\"}}]\n" + " ],\n" + " \"abc\": {\"@type\":\"Custom\", \"value\":\"4d\"}\n" + - "}", Map.class); // updated version and new default value field added - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::nested::NewSampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::nested::NewSampleClass\", \"xyz\": {\"@type\":\"Custom\", \"value\":\"4d\"}},\n" + @@ -132,11 +111,7 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " [{\"@type\": \"meta::pure::changetoken::tests::nested::NewSampleClass\", \"xyz\": {\"@type\":\"Custom\", \"value\":\"2d\"}}]\n" + " ],\n" + " \"xyz\": {\"@type\":\"Custom\", \"value\":\"1d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class) - .invoke(null, jsonNode, "ftdm:abcdefg123"); - Map expectedJsonNodeOut = mapper.readValue( + "}", "ftdm:abcdefg123"), "{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -146,16 +121,13 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"xyz\": {\"@type\":\"Custom\", \"value\":\"2d\"}}]\n" + " ],\n" + " \"xyz\": {\"@type\":\"Custom\", \"value\":\"1d\"}\n" + - "}", Map.class); // remove default values - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncastType() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::OtherClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::OtherClass\", \"xyz\": {\"@type\":\"Custom\", \"value\":\"4d\"}},\n" + @@ -164,11 +136,7 @@ public void testDowncastType() throws JsonProcessingException, NoSuchMethodExcep " [{\"@type\": \"meta::pure::changetoken::tests::OtherClass\", \"xyz\": {\"@type\":\"Custom\", \"value\":\"2d\"}}]\n" + " ],\n" + " \"xyz\": {\"@type\":\"Custom\", \"value\":\"1d\"}\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class) - .invoke(null, jsonNode, "ftdm:abcdefg123"); - Map expectedJsonNodeOut = mapper.readValue( + "}", "ftdm:abcdefg123"), "{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::OtherClass\",\n" + @@ -178,9 +146,6 @@ public void testDowncastType() throws JsonProcessingException, NoSuchMethodExcep " [{\"@type\": \"meta::pure::changetoken::tests::OtherClass\", \"xyz\": {\"@type\":\"Custom\", \"value\":\"2d\"}}]\n" + " ],\n" + " \"xyz\": {\"@type\":\"Custom\", \"value\":\"1d\"}\n" + - "}", Map.class); // remove default values - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } } - diff --git a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastStringQuotesTest.java b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastStringQuotesTest.java index 321f56c92e4..15c8f783a21 100644 --- a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastStringQuotesTest.java +++ b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastStringQuotesTest.java @@ -15,17 +15,11 @@ package org.finos.legend.engine.changetoken.generation; import com.fasterxml.jackson.core.JsonProcessingException; -import com.fasterxml.jackson.databind.ObjectMapper; -import org.junit.Assert; import org.junit.BeforeClass; import org.junit.Test; import java.io.IOException; import java.lang.reflect.InvocationTargetException; -import java.lang.reflect.Method; -import java.util.Map; - -import static org.junit.Assert.assertThrows; public class GenerateCastStringQuotesTest extends GenerateCastTestBase { @@ -64,8 +58,7 @@ public static void setupSuite() throws IOException, ClassNotFoundException @Test public void testUpcast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"},\n" + @@ -73,11 +66,7 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}, \n" + " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}]\n" + " ]\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("upcast", Map.class).invoke(null, jsonNode); - - Map expectedJsonNodeOut = mapper.readValue( + "}"), "{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -87,16 +76,13 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": \"one \\\" two\"}]\n" + " ],\n" + " \"abc\": \"one \\\" two\"\n" + - "}", Map.class); // updated version and new default value field added - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": \"one \\\" two\"},\n" + @@ -105,11 +91,7 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": \"one \\\" two\"}]\n" + " ],\n" + " \"abc\": \"one \\\" two\"\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class) - .invoke(null, jsonNode, "ftdm:abcdefg123"); - Map expectedJsonNodeOut = mapper.readValue( + "}", "ftdm:abcdefg123"), "{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -118,16 +100,13 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}, \n" + " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}]\n" + " ]\n" + - "}", Map.class); // remove default values - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncastNonDefault() throws JsonProcessingException, NoSuchMethodException { - String input = - "{\n" + + exception(() -> downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": \"one \\\" two\"},\n" + @@ -136,11 +115,7 @@ public void testDowncastNonDefault() throws JsonProcessingException, NoSuchMetho " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": \"one \\\" two\"}]\n" + " ],\n" + " \"abc\": \"two \\\" one\"\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Method downcastMethod = compiledClass.getMethod("downcast", Map.class, String.class); - InvocationTargetException re = assertThrows("non-default", InvocationTargetException.class, () -> downcastMethod.invoke(null, jsonNode, "ftdm:abcdefg123")); - Assert.assertEquals("Cannot remove non-default value:two \" one", re.getCause().getMessage()); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}", "ftdm:abcdefg123"), + "Cannot remove non-default value:two \" one"); } } diff --git a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastStringTest.java b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastStringTest.java index 7029ee0d75f..ef87ca95cef 100644 --- a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastStringTest.java +++ b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastStringTest.java @@ -15,17 +15,11 @@ package org.finos.legend.engine.changetoken.generation; import com.fasterxml.jackson.core.JsonProcessingException; -import com.fasterxml.jackson.databind.ObjectMapper; -import org.junit.Assert; import org.junit.BeforeClass; import org.junit.Test; import java.io.IOException; import java.lang.reflect.InvocationTargetException; -import java.lang.reflect.Method; -import java.util.Map; - -import static org.junit.Assert.assertThrows; public class GenerateCastStringTest extends GenerateCastTestBase { @@ -64,8 +58,7 @@ public static void setupSuite() throws IOException, ClassNotFoundException @Test public void testUpcast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"},\n" + @@ -73,11 +66,7 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}, \n" + " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}]\n" + " ]\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("upcast", Map.class).invoke(null, jsonNode); - - Map expectedJsonNodeOut = mapper.readValue( + "}"), "{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -87,16 +76,13 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": \"one \\\" two\"}]\n" + " ],\n" + " \"abc\": \"one \\\" two\"\n" + - "}", Map.class); // updated version and new default value field added - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": \"one \\\" two\"},\n" + @@ -105,11 +91,7 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": \"one \\\" two\"}]\n" + " ],\n" + " \"abc\": \"one \\\" two\"\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class) - .invoke(null, jsonNode, "ftdm:abcdefg123"); - Map expectedJsonNodeOut = mapper.readValue( + "}", "ftdm:abcdefg123"), "{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -118,16 +100,13 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}, \n" + " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}]\n" + " ]\n" + - "}", Map.class); // remove default values - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncastNonDefault() throws JsonProcessingException, NoSuchMethodException { - String input = - "{\n" + + exception(() -> downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": \"one \\\" two\"},\n" + @@ -136,11 +115,7 @@ public void testDowncastNonDefault() throws JsonProcessingException, NoSuchMetho " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": \"one \\\" two\"}]\n" + " ],\n" + " \"abc\": \"two \\\" one\"\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Method downcastMethod = compiledClass.getMethod("downcast", Map.class, String.class); - InvocationTargetException re = assertThrows("non-default", InvocationTargetException.class, () -> downcastMethod.invoke(null, jsonNode, "ftdm:abcdefg123")); - Assert.assertEquals("Cannot remove non-default value:two \" one", re.getCause().getMessage()); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}", "ftdm:abcdefg123"), + "Cannot remove non-default value:two \" one"); } } diff --git a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastTest.java b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastTest.java index 547200cb93e..15b1e1840f8 100644 --- a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastTest.java +++ b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastTest.java @@ -15,17 +15,11 @@ package org.finos.legend.engine.changetoken.generation; import com.fasterxml.jackson.core.JsonProcessingException; -import com.fasterxml.jackson.databind.ObjectMapper; -import org.junit.Assert; import org.junit.BeforeClass; import org.junit.Test; import java.io.IOException; import java.lang.reflect.InvocationTargetException; -import java.lang.reflect.Method; -import java.util.Map; - -import static org.junit.Assert.assertThrows; public class GenerateCastTest extends GenerateCastTestBase { @@ -64,8 +58,7 @@ public static void setupSuite() throws IOException, ClassNotFoundException @Test public void testUpcast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(upcast("{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"},\n" + @@ -73,11 +66,7 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}, \n" + " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}]\n" + " ]\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("upcast", Map.class).invoke(null, jsonNode); - - Map expectedJsonNodeOut = mapper.readValue( + "}"), "{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -87,16 +76,13 @@ public void testUpcast() throws JsonProcessingException, NoSuchMethodException, " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": 100}]\n" + " ],\n" + " \"abc\": 100\n" + - "}", Map.class); // updated version and new default value field added - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncast() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": 100},\n" + @@ -105,11 +91,7 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": 100}]\n" + " ],\n" + " \"abc\": 100\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class) - .invoke(null, jsonNode, "ftdm:abcdefg123"); - Map expectedJsonNodeOut = mapper.readValue( + "}", "ftdm:abcdefg123"), "{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -118,16 +100,13 @@ public void testDowncast() throws JsonProcessingException, NoSuchMethodException " {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}, \n" + " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}]\n" + " ]\n" + - "}", Map.class); // remove default values - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncastNull() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { - String input = - "{\n" + + expect(downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": null},\n" + @@ -136,11 +115,7 @@ public void testDowncastNull() throws JsonProcessingException, NoSuchMethodExcep " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": null}]\n" + " ],\n" + " \"abc\": null\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Map jsonNodeOut = (Map) compiledClass.getMethod("downcast", Map.class, String.class) - .invoke(null, jsonNode, "ftdm:abcdefg123"); - Map expectedJsonNodeOut = mapper.readValue( + "}", "ftdm:abcdefg123"), "{\n" + " \"version\":\"ftdm:abcdefg123\", \n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + @@ -149,16 +124,13 @@ public void testDowncastNull() throws JsonProcessingException, NoSuchMethodExcep " {\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}, \n" + " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\"}]\n" + " ]\n" + - "}", Map.class); // remove default values - Assert.assertEquals(expectedJsonNodeOut, jsonNodeOut); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}\n"); } @Test public void testDowncastNonDefault() throws JsonProcessingException, NoSuchMethodException { - String input = - "{\n" + + exception(() -> downcast("{\n" + " \"version\":\"ftdm:abcdefg456\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SampleClass\",\n" + " \"innerObject\": {\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": 100},\n" + @@ -167,11 +139,7 @@ public void testDowncastNonDefault() throws JsonProcessingException, NoSuchMetho " [{\"@type\": \"meta::pure::changetoken::tests::SampleClass\", \"abc\": 100}]\n" + " ],\n" + " \"abc\": 300\n" + - "}"; - Map jsonNode = mapper.readValue(input, Map.class); - Method downcastMethod = compiledClass.getMethod("downcast", Map.class, String.class); - InvocationTargetException re = assertThrows("non-default", InvocationTargetException.class, () -> downcastMethod.invoke(null, jsonNode, "ftdm:abcdefg123")); - Assert.assertEquals("Cannot remove non-default value:300", re.getCause().getMessage()); - Assert.assertEquals(mapper.readValue(input, Map.class), jsonNode); + "}", "ftdm:abcdefg123"), + "Cannot remove non-default value:300"); } } diff --git a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastTestBase.java b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastTestBase.java index 7beacf2a2cf..5863d50d323 100644 --- a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastTestBase.java +++ b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastTestBase.java @@ -14,6 +14,7 @@ package org.finos.legend.engine.changetoken.generation; +import com.fasterxml.jackson.core.JsonProcessingException; import com.fasterxml.jackson.databind.ObjectMapper; import io.github.classgraph.ClassGraph; import org.finos.legend.engine.external.language.java.generation.GenerateJavaProject; @@ -22,26 +23,27 @@ import org.finos.legend.pure.runtime.java.compiled.compiler.MemoryFileManager; import org.junit.Assert; import org.junit.ClassRule; +import org.junit.function.ThrowingRunnable; import org.junit.rules.TemporaryFolder; -import javax.tools.DiagnosticCollector; -import javax.tools.JavaCompiler; -import javax.tools.JavaFileObject; -import javax.tools.SimpleJavaFileObject; -import javax.tools.ToolProvider; +import javax.tools.*; import java.io.IOException; +import java.lang.reflect.InvocationTargetException; import java.nio.charset.StandardCharsets; import java.nio.file.Files; import java.nio.file.Path; import java.util.Arrays; import java.util.Collections; +import java.util.Map; + +import static org.junit.Assert.assertThrows; public abstract class GenerateCastTestBase { private static final org.slf4j.Logger LOGGER = org.slf4j.LoggerFactory.getLogger(GenerateCastTestBase.class); protected static Class compiledClass; - protected static final ObjectMapper mapper = new ObjectMapper(); + private static final ObjectMapper mapper = new ObjectMapper(); @ClassRule public static TemporaryFolder tmpFolder = new TemporaryFolder(); @@ -105,6 +107,58 @@ private static void setupSuiteFrom(Object fromValue, String generatorType) throw compiledClass = new MemoryClassLoader(fileManager, Thread.currentThread().getContextClassLoader()).loadClass(fullClassName); } + private Map upcast(Map objectNode) throws NoSuchMethodException, InvocationTargetException, IllegalAccessException + { + return (Map) compiledClass.getMethod("upcast", Map.class).invoke(null, objectNode); + } + + private Map downcast(Map objectNode, String targetVersion) throws NoSuchMethodException, InvocationTargetException, IllegalAccessException + { + return (Map) compiledClass.getMethod("downcast", Map.class, String.class).invoke(null, objectNode, targetVersion); + } + + protected Map parse(String value) throws JsonProcessingException + { + return mapper.readValue(value, Map.class); + } + + public Map upcast(String input) throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException + { + Map jsonNode = parse(input); + try + { + return upcast(jsonNode); + } + finally + { + Assert.assertEquals(parse(input), jsonNode); + } + } + + public Map downcast(String input, String targetVersion) throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException + { + Map jsonNode = parse(input); + try + { + return downcast(jsonNode, targetVersion); + } + finally + { + Assert.assertEquals(parse(input), jsonNode); + } + } + + public void expect(Map actual, String expected) throws JsonProcessingException + { + Assert.assertEquals(parse(expected), actual); + } + + public void exception(ThrowingRunnable runnable, String expected) + { + InvocationTargetException re = assertThrows("non-default", InvocationTargetException.class, runnable); + Assert.assertEquals(expected, re.getCause().getMessage()); + } + private static class SourceFile extends SimpleJavaFileObject { private final Path path; diff --git a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastUtilTest.java b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastUtilTest.java index 8413368d138..f024e2dbc0f 100644 --- a/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastUtilTest.java +++ b/legend-engine-xts-changetoken/legend-engine-xt-changetoken-compiler/src/test/java/org/finos/legend/engine/changetoken/generation/GenerateCastUtilTest.java @@ -62,12 +62,10 @@ public static void setupSuite() throws IOException, ClassNotFoundException public void testResolvePath() throws NoSuchMethodException, InvocationTargetException, IllegalAccessException { Method m = compiledClass.getMethod("resolvePath", List.class, String.class); - // note that "0" is cast to int in resolveRelativeReference or setRelativeReference Assert.assertArrayEquals( Arrays.asList("a", "b", 1, "c", "0").toArray(), - ((List)m.invoke(null, Arrays.asList("a", "b", 1, "c", 2), "../0")).toArray()); - + ((List) m.invoke(null, Arrays.asList("a", "b", 1, "c", 2), "../0")).toArray()); InvocationTargetException ex = Assert.assertThrows(InvocationTargetException.class, () -> m.invoke(null, Arrays.asList("a", "b", 1, "c", 2), "../../../../../../x")); Assert.assertEquals("Relative reference escapes root (a/b/1/c/2) at index 5 of ../../../../../../x", ex.getCause().getMessage()); @@ -77,7 +75,6 @@ public void testResolvePath() throws NoSuchMethodException, InvocationTargetExce public void testResolveRelativeReference() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { Method m = compiledClass.getMethod("resolveRelativeReference", Map.class, List.class, String.class); - ObjectMapper mapper = new ObjectMapper(); String input = "{\n" + " \"version\": \"ftdm:abcdefg123\",\n" + @@ -92,18 +89,15 @@ public void testResolveRelativeReference() throws JsonProcessingException, NoSuc " }\n" + " ]\n" + "}\n"; - Map jsonNode = mapper.readValue(input, Map.class); - + Map jsonNode = parse(input); Assert.assertEquals("someValue", m.invoke(null, jsonNode, Arrays.asList("array", 0, "innerObject", "@type"), "../../existingValue")); - Assert.assertEquals("meta::pure::changetoken::tests::SampleClass", m.invoke(null, jsonNode, Collections.emptyList(), "array/0/innerObject/@type")); - InvocationTargetException ex = Assert.assertThrows(InvocationTargetException.class, () -> m.invoke(null, jsonNode, Collections.emptyList(), @@ -115,8 +109,7 @@ public void testResolveRelativeReference() throws JsonProcessingException, NoSuc public void testSetRelativeReference() throws JsonProcessingException, NoSuchMethodException, InvocationTargetException, IllegalAccessException { Method m = compiledClass.getMethod("setRelativeReference", Map.class, List.class, String.class, Object.class); - - ObjectMapper mapper = new ObjectMapper(); + String input = "{\n" + " \"version\": \"ftdm:abcdefg123\",\n" + " \"@type\": \"meta::pure::changetoken::tests::SomeClassWithAnArray\",\n" + @@ -130,15 +123,13 @@ public void testSetRelativeReference() throws JsonProcessingException, NoSuchMet " }\n" + " ]\n" + "}\n"; - Map jsonNode = mapper.readValue(input, Map.class); - + Map jsonNode = parse(input); m.invoke(null, jsonNode, Arrays.asList("array", 0, "innerObject", "@type"), "../newValue", 123); Assert.assertEquals(123, compiledClass.getMethod("resolveRelativeReference", Map.class, List.class, String.class).invoke(null, jsonNode, Arrays.asList("array", 0, "innerObject", "@type"), "../newValue")); - { InvocationTargetException ex = Assert.assertThrows(InvocationTargetException.class, () -> m.invoke(null, jsonNode, @@ -146,7 +137,6 @@ public void testSetRelativeReference() throws JsonProcessingException, NoSuchMet "array/blah", 456)); Assert.assertEquals("java.lang.NumberFormatException: For input string: \"blah\": at index 1 of array/blah", ex.getCause().getMessage()); } - { InvocationTargetException ex = Assert.assertThrows(InvocationTargetException.class, () -> m.invoke(null, jsonNode,