X-Git-Url: http://git.nikiroo.be/?a=blobdiff_plain;f=src%2Fbe%2Fnikiroo%2Futils%2Ftest_code%2FSerialTest.java;h=5ac53860eeb60818de4ddef3f37686181e4fe150;hb=4d31956549a05df6dca42d58a1150a348a58dcd1;hp=d761195ea8fdf938ed67281623dfe58ce5f497a8;hpb=564bbbdbc349805ff7fc1142facbedae87e5dc0e;p=nikiroo-utils.git diff --git a/src/be/nikiroo/utils/test_code/SerialTest.java b/src/be/nikiroo/utils/test_code/SerialTest.java index d761195..5ac5386 100644 --- a/src/be/nikiroo/utils/test_code/SerialTest.java +++ b/src/be/nikiroo/utils/test_code/SerialTest.java @@ -21,15 +21,29 @@ class SerialTest extends TestLauncher { this(null); } + private void encodeRecodeTest(TestCase test, Object data) throws Exception { + byte[] encoded = toBytes(data,true); + Object redata = fromBytes(encoded); + byte[] reencoded = toBytes(redata,true); + + test.assertEquals("Different data after encode/decode/encode", true, + Arrays.equals(encoded, reencoded)); + } + // try to remove pointer addresses - private byte[] toBytes(Object data) throws NotSerializableException, + private byte[] toBytes(Object data, boolean clearRefs) throws NotSerializableException, IOException { ByteArrayOutputStream out = new ByteArrayOutputStream(); new Exporter(out).append(data); out.flush(); + + if(clearRefs){ String tmp = new String(out.toByteArray(), "UTF-8"); tmp = tmp.replaceAll("@[0-9]*", "@REF"); return tmp.getBytes("UTF-8"); + } + + return out.toByteArray(); } private Object fromBytes(byte[] data) throws NoSuchFieldException, @@ -51,197 +65,204 @@ class SerialTest extends TestLauncher { @Override public void test() throws Exception { Data data = new Data(42); + encodeRecodeTest(this, data); + } + }); - byte[] encoded = toBytes(data); + addTest(new TestCase() { + @SuppressWarnings("unused") + private TestCase me = setName("Anonymous inner class"); + + @Override + public void test() throws Exception { + Data data = new Data() { + @SuppressWarnings("unused") + int value = 42; + }; + encodeRecodeTest(this, data); + } + }); + addTest(new TestCase() { + @SuppressWarnings("unused") + private TestCase me = setName("Array of anonymous inner classes"); + + @Override + public void test() throws Exception { + Data[] data = new Data[] { new Data() { + @SuppressWarnings("unused") + int value = 42; + }}; + + byte[] encoded = toBytes(data,false); Object redata = fromBytes(encoded); - byte[] reencoded = toBytes(redata); + + // Comparing the 2 arrays won't be useful, because the @REFs + // will be ZIP-encoded; so we parse and re-encode each object + + byte[] encoded1 = toBytes(data[0],true); + byte[] reencoded1 = toBytes(((Data[])redata)[0],true); assertEquals("Different data after encode/decode/encode", true, - Arrays.equals(encoded, reencoded)); + Arrays.equals(encoded1, reencoded1)); } }); /* - * addTest(new TestCase() { - * - * @SuppressWarnings("unused") private TestCase me = - * setName("Anonymous inner class"); - * - * @Override public void test() throws Exception { Data data = new - * Data() { - * - * @SuppressWarnings("unused") int value = 42; }; - * - * String encoded = new Exporter().append(data).toString(false, false); - * Object redata = new Importer().read(encoded).getValue(); String - * reencoded = new Exporter().append(redata).toString( false, false); - * - * assertEquals(encoded.replaceAll("@[0-9]*", "@REF"), - * reencoded.replaceAll("@[0-9]*", "@REF")); } }); - * - * addTest(new TestCase() { - * - * @SuppressWarnings("unused") private TestCase me = - * setName("Array of anonymous inner classes"); - * - * @Override public void test() throws Exception { Data[] data = new - * Data[] { new Data() { - * - * @SuppressWarnings("unused") int value = 42; } }; - * - * String encoded = new Exporter().append(data).toString(false, false); - * Object redata = new Importer().read(encoded).getValue(); String - * reencoded = new Exporter().append(redata).toString( false, false); - * - * // Comparing the 2 strings won't be useful, because the @REFs // will - * be ZIP-encoded; so we parse and re-encode the object encoded = new - * Exporter().append(data[0]).toString(false, false); try { reencoded = - * new Exporter().append(((Data[]) redata)[0]) .toString(false, false); - * } catch (Exception e) { - * fail("Cannot cast the returned data into its original object", e); } - * - * assertEquals(encoded.replaceAll("@[0-9]*", "@REF"), - * reencoded.replaceAll("@[0-9]*", "@REF")); } }); - * - * addTest(new TestCase("URL Import/Export") { - * - * @Override public void test() throws Exception { URL data = new - * URL("https://fanfan.be/"); String encoded = new - * Exporter().append(data).toString(false, false); Object redata = new - * Importer().read(encoded).getValue(); String reencoded = new - * Exporter().append(redata).toString( false, false); - * - * assertEquals(encoded.replaceAll("@[0-9]*", "@REF"), - * reencoded.replaceAll("@[0-9]*", "@REF")); } }); - * - * addTest(new TestCase("URL-String Import/Export") { - * - * @Override public void test() throws Exception { String data = new - * URL("https://fanfan.be/").toString(); String encoded = new - * Exporter().append(data).toString(false, false); Object redata = new - * Importer().read(encoded).getValue(); String reencoded = new - * Exporter().append(redata).toString( false, false); - * - * assertEquals(encoded.replaceAll("@[0-9]*", "@REF"), - * reencoded.replaceAll("@[0-9]*", "@REF")); assertEquals(data, redata); - * } }); - * - * addTest(new TestCase("URL/URL-String arrays Import/Export") { - * - * @Override public void test() throws Exception { final String url = - * "https://fanfan.be/"; - * - * Object[] data = new Object[] { new URL(url), url }; String encoded = - * new Exporter().append(data).toString(false, false); Object redata = - * new Importer().read(encoded).getValue(); String reencoded = new - * Exporter().append(redata).toString( false, false); - * - * assertEquals(encoded.replaceAll("@[0-9]*", "@REF"), - * reencoded.replaceAll("@[0-9]*", "@REF")); assertEquals(data[0], - * ((Object[]) redata)[0]); assertEquals(data[1], ((Object[]) - * redata)[1]); } }); - * - * addTest(new TestCase("Import/Export with nested objects") { - * - * @Override public void test() throws Exception { Data data = new - * DataObject(new Data(21)); String encoded = new - * Exporter().append(data).toString(false, false); Object redata = new - * Importer().read(encoded).getValue(); String reencoded = new - * Exporter().append(redata).toString( false, false); - * - * assertEquals(encoded.replaceAll("@[0-9]*", "@REF"), - * reencoded.replaceAll("@[0-9]*", "@REF")); } }); - * - * addTest(new - * TestCase("Import/Export with nested objects forming a loop") { - * - * @Override public void test() throws Exception { DataLoop data = new - * DataLoop("looping"); data.next = new DataLoop("level 2"); - * data.next.next = data; - * - * String encoded = new Exporter().append(data).toString(false, false); - * Object redata = new Importer().read(encoded).getValue(); String - * reencoded = new Exporter().append(redata).toString( false, false); - * - * assertEquals(encoded.replaceAll("@[0-9]*", "@REF"), - * reencoded.replaceAll("@[0-9]*", "@REF")); } }); - * - * addTest(new TestCase("Array in Object Import/Export") { - * - * @Override public void test() throws Exception { Object data = new - * DataArray();// new String[] { "un", "deux" }; String encoded = new - * Exporter().append(data).toString(false, false); Object redata = new - * Importer().read(encoded).getValue(); String reencoded = new - * Exporter().append(redata).toString( false, false); - * - * assertEquals(encoded.replaceAll("@[0-9]*", "@REF"), - * reencoded.replaceAll("@[0-9]*", "@REF")); } }); - * - * addTest(new TestCase("Array Import/Export") { - * - * @Override public void test() throws Exception { Object data = new - * String[] { "un", "deux" }; String encoded = new - * Exporter().append(data).toString(false, false); Object redata = new - * Importer().read(encoded).getValue(); String reencoded = new - * Exporter().append(redata).toString( false, false); - * - * assertEquals(encoded.replaceAll("@[0-9]*", "@REF"), - * reencoded.replaceAll("@[0-9]*", "@REF")); } }); - * - * addTest(new TestCase("Enum Import/Export") { - * - * @Override public void test() throws Exception { Object data = - * EnumToSend.FANFAN; String encoded = new - * Exporter().append(data).toString(false, false); Object redata = new - * Importer().read(encoded).getValue(); String reencoded = new - * Exporter().append(redata).toString( false, false); - * - * assertEquals(encoded.replaceAll("@[0-9]*", "@REF"), - * reencoded.replaceAll("@[0-9]*", "@REF")); } }); - * - * addTest(new TestCase("B64 and ZIP String test") { - * - * @Override public void test() throws Exception { Object data = - * "Fanfan la tulipe"; String encoded = new - * Exporter().append(data).toString(true, false); String redata = - * (String) new Importer().read(encoded) .getValue(); - * - * assertEquals("Items not identical after B64", data, redata); - * - * encoded = new Exporter().append(data).toString(true, true); redata = - * (String) new Importer().read(encoded).getValue(); - * - * assertEquals("Items not identical after ZIP", data, redata); } }); - * - * addTest(new TestCase("B64 and ZIP Data test") { - * - * @Override public void test() throws Exception { Object data = new - * Data(55); String encoded = new Exporter().append(data).toString(true, - * false); Data redata = (Data) new Importer().read(encoded).getValue(); - * - * assertEquals("Items not identical after B64", data, redata); - * - * encoded = new Exporter().append(data).toString(true, true); redata = - * (Data) new Importer().read(encoded).getValue(); - * - * assertEquals("Items not identical after ZIP", data, redata); } }); - * - * addTest(new TestCase("B64 and ZIP 70000 chars test") { - * - * @Override public void test() throws Exception { StringBuilder builder - * = new StringBuilder(); for (int i = 0; i < 7000; i++) { - * builder.append("0123456789"); } - * - * Object data = builder.toString(); String encoded = new - * Exporter().append(data).toString(true, false); String redata = - * (String) new Importer().read(encoded) .getValue(); - * - * assertEquals("Items not identical after B64", data, redata); - * - * encoded = new Exporter().append(data).toString(true, true); redata = - * (String) new Importer().read(encoded).getValue(); - * - * assertEquals("Items not identical after ZIP", data, redata); } }); - */ + addTest(new TestCase("URL Import/Export") { + @Override + public void test() throws Exception { + URL data = new URL("https://fanfan.be/"); + String encoded = new Exporter().append(data).toString(false, + false); + Object redata = new Importer().read(encoded).getValue(); + String reencoded = new Exporter().append(redata).toString( + false, false); + assertEquals(encoded.replaceAll("@[0-9]*", "@REF"), + reencoded.replaceAll("@[0-9]*", "@REF")); + } + }); + addTest(new TestCase("URL-String Import/Export") { + @Override + public void test() throws Exception { + String data = new URL("https://fanfan.be/").toString(); + String encoded = new Exporter().append(data).toString(false, + false); + Object redata = new Importer().read(encoded).getValue(); + String reencoded = new Exporter().append(redata).toString( + false, false); + assertEquals(encoded.replaceAll("@[0-9]*", "@REF"), + reencoded.replaceAll("@[0-9]*", "@REF")); + assertEquals(data, redata); + } + }); + addTest(new TestCase("URL/URL-String arrays Import/Export") { + @Override + public void test() throws Exception { + final String url = "https://fanfan.be/"; + Object[] data = new Object[] { new URL(url), url }; + String encoded = new Exporter().append(data).toString(false, + false); + Object redata = new Importer().read(encoded).getValue(); + String reencoded = new Exporter().append(redata).toString( + false, false); + assertEquals(encoded.replaceAll("@[0-9]*", "@REF"), + reencoded.replaceAll("@[0-9]*", "@REF")); + assertEquals(data[0], ((Object[]) redata)[0]); + assertEquals(data[1], ((Object[]) redata)[1]); + } + }); + addTest(new TestCase("Import/Export with nested objects") { + @Override + public void test() throws Exception { + Data data = new DataObject(new Data(21)); + String encoded = new Exporter().append(data).toString(false, + false); + Object redata = new Importer().read(encoded).getValue(); + String reencoded = new Exporter().append(redata).toString( + false, false); + assertEquals(encoded.replaceAll("@[0-9]*", "@REF"), + reencoded.replaceAll("@[0-9]*", "@REF")); + } + }); + addTest(new TestCase("Import/Export with nested objects forming a loop") { + @Override + public void test() throws Exception { + DataLoop data = new DataLoop("looping"); + data.next = new DataLoop("level 2"); + data.next.next = data; + String encoded = new Exporter().append(data).toString(false, + false); + Object redata = new Importer().read(encoded).getValue(); + String reencoded = new Exporter().append(redata).toString( + false, false); + assertEquals(encoded.replaceAll("@[0-9]*", "@REF"), + reencoded.replaceAll("@[0-9]*", "@REF")); + } + }); + addTest(new TestCase("Array in Object Import/Export") { + @Override + public void test() throws Exception { + Object data = new DataArray();// new String[] { "un", "deux" }; + String encoded = new Exporter().append(data).toString(false, + false); + Object redata = new Importer().read(encoded).getValue(); + String reencoded = new Exporter().append(redata).toString( + false, false); + assertEquals(encoded.replaceAll("@[0-9]*", "@REF"), + reencoded.replaceAll("@[0-9]*", "@REF")); + } + }); + addTest(new TestCase("Array Import/Export") { + @Override + public void test() throws Exception { + Object data = new String[] { "un", "deux" }; + String encoded = new Exporter().append(data).toString(false, + false); + Object redata = new Importer().read(encoded).getValue(); + String reencoded = new Exporter().append(redata).toString( + false, false); + assertEquals(encoded.replaceAll("@[0-9]*", "@REF"), + reencoded.replaceAll("@[0-9]*", "@REF")); + } + }); + addTest(new TestCase("Enum Import/Export") { + @Override + public void test() throws Exception { + Object data = EnumToSend.FANFAN; + String encoded = new Exporter().append(data).toString(false, + false); + Object redata = new Importer().read(encoded).getValue(); + String reencoded = new Exporter().append(redata).toString( + false, false); + assertEquals(encoded.replaceAll("@[0-9]*", "@REF"), + reencoded.replaceAll("@[0-9]*", "@REF")); + } + }); + addTest(new TestCase("B64 and ZIP String test") { + @Override + public void test() throws Exception { + Object data = "Fanfan la tulipe"; + String encoded = new Exporter().append(data).toString(true, + false); + String redata = (String) new Importer().read(encoded) + .getValue(); + assertEquals("Items not identical after B64", data, redata); + encoded = new Exporter().append(data).toString(true, true); + redata = (String) new Importer().read(encoded).getValue(); + assertEquals("Items not identical after ZIP", data, redata); + } + }); + addTest(new TestCase("B64 and ZIP Data test") { + @Override + public void test() throws Exception { + Object data = new Data(55); + String encoded = new Exporter().append(data).toString(true, + false); + Data redata = (Data) new Importer().read(encoded).getValue(); + assertEquals("Items not identical after B64", data, redata); + encoded = new Exporter().append(data).toString(true, true); + redata = (Data) new Importer().read(encoded).getValue(); + assertEquals("Items not identical after ZIP", data, redata); + } + }); + addTest(new TestCase("B64 and ZIP 70000 chars test") { + @Override + public void test() throws Exception { + StringBuilder builder = new StringBuilder(); + for (int i = 0; i < 7000; i++) { + builder.append("0123456789"); + } + Object data = builder.toString(); + String encoded = new Exporter().append(data).toString(true, + false); + String redata = (String) new Importer().read(encoded) + .getValue(); + assertEquals("Items not identical after B64", data, redata); + encoded = new Exporter().append(data).toString(true, true); + redata = (String) new Importer().read(encoded).getValue(); + assertEquals("Items not identical after ZIP", data, redata); + } + }); + */ } class DataArray {