SerialTest: OK
[nikiroo-utils.git] / src / be / nikiroo / utils / test_code / SerialTest.java
index 880f175b29889dec87751db0286fb9fdc9a1d826..1581965445abe7567f1d0cf65646d5c16f24eef7 100644 (file)
@@ -5,6 +5,7 @@ import java.io.ByteArrayOutputStream;
 import java.io.IOException;
 import java.io.InputStream;
 import java.io.NotSerializableException;
+import java.net.URL;
 import java.util.Arrays;
 
 import be.nikiroo.utils.serial.Exporter;
@@ -20,15 +21,36 @@ class SerialTest extends TestLauncher {
                this(null);
        }
 
+       private void encodeRecodeTest(TestCase test, Object data) throws Exception {
+               byte[] encoded = toBytes(data, true);
+               Object redata = fromBytes(toBytes(data, false));
+               byte[] reencoded = toBytes(redata, true);
+
+               // We suppose text mode
+               if (encoded.length < 256 && reencoded.length < 256) {
+                       test.assertEquals("Different data after encode/decode/encode",
+                                       new String(encoded, "UTF-8"),
+                                       new String(reencoded, "UTF-8"));
+               } else {
+                       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,
-                       IOException {
+       private byte[] toBytes(Object data, boolean clearRefs)
+                       throws NotSerializableException, IOException {
                ByteArrayOutputStream out = new ByteArrayOutputStream();
                new Exporter(out).append(data);
                out.flush();
-               String tmp = new String(out.toByteArray(), "UTF-8");
-               tmp = tmp.replaceAll("@[0-9]*", "@REF");
-               return tmp.getBytes("UTF-8");
+
+               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,
@@ -50,197 +72,121 @@ class SerialTest extends TestLauncher {
                        @Override
                        public void test() throws Exception {
                                Data data = new Data(42);
+                               encodeRecodeTest(this, 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");
 
-                               byte[] encoded = toBytes(data);
+                       @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(((Object[]) redata)[0], true);
 
                                assertEquals("Different data after encode/decode/encode", true,
-                                               Arrays.equals(encoded, reencoded));
+                                               Arrays.equals(encoded1, reencoded1));
+                       }
+               });
+               addTest(new TestCase("URL Import/Export") {
+                       @Override
+                       public void test() throws Exception {
+                               URL data = new URL("https://fanfan.be/");
+                               encodeRecodeTest(this, data);
+                       }
+               });
+               addTest(new TestCase("URL-String Import/Export") {
+                       @Override
+                       public void test() throws Exception {
+                               String data = new URL("https://fanfan.be/").toString();
+                               encodeRecodeTest(this, data);
+                       }
+               });
+               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 };
+
+                               byte[] encoded = toBytes(data, false);
+                               Object redata = fromBytes(encoded);
+
+                               // 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(((Object[]) redata)[0], true);
+                               byte[] encoded2 = toBytes(data[1], true);
+                               byte[] reencoded2 = toBytes(((Object[]) redata)[1], true);
+
+                               assertEquals("Different data 1 after encode/decode/encode",
+                                               true, Arrays.equals(encoded1, reencoded1));
+                               assertEquals("Different data 2 after encode/decode/encode",
+                                               true, Arrays.equals(encoded2, reencoded2));
+                       }
+               });
+               addTest(new TestCase("Import/Export with nested objects") {
+                       @Override
+                       public void test() throws Exception {
+                               Data data = new DataObject(new Data(21));
+                               encodeRecodeTest(this, data);
+                       }
+               });
+               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;
+                               encodeRecodeTest(this, data);
+                       }
+               });
+               addTest(new TestCase("Array in Object Import/Export") {
+                       @Override
+                       public void test() throws Exception {
+                               Object data = new DataArray();// new String[] { "un", "deux" };
+                               encodeRecodeTest(this, data);
+                       }
+               });
+               addTest(new TestCase("Array Import/Export") {
+                       @Override
+                       public void test() throws Exception {
+                               Object data = new String[] { "un", "deux" };
+                               encodeRecodeTest(this, data);
+                       }
+               });
+               addTest(new TestCase("Enum Import/Export") {
+                       @Override
+                       public void test() throws Exception {
+                               Object data = EnumToSend.FANFAN;
+                               encodeRecodeTest(this, 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; };
-                * 
-                * 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); } });
-                */
        }
 
        class DataArray {