Skip to content

Commit

Permalink
Add tests for the encode/decode methods of Types
Browse files Browse the repository at this point in the history
  • Loading branch information
ctrueden committed Jul 15, 2024
1 parent 0811a06 commit 2b9064a
Showing 1 changed file with 135 additions and 0 deletions.
135 changes: 135 additions & 0 deletions src/test/java/org/apposed/appose/TypesTest.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,135 @@
/*-
* #%L
* Appose: multi-language interprocess cooperation with shared memory.
* %%
* Copyright (C) 2023 Appose developers.
* %%
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* 1. Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright notice,
* this list of conditions and the following disclaimer in the documentation
* and/or other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDERS OR CONTRIBUTORS BE
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGE.
* #L%
*/

package org.apposed.appose;

import org.junit.jupiter.api.Test;

import java.io.IOException;
import java.math.BigDecimal;
import java.util.Arrays;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors;

import static org.junit.jupiter.api.Assertions.assertEquals;
import static org.junit.jupiter.api.Assertions.assertNotNull;

/**
* Tests {@link Types}.
*
* @author Curtis Rueden
*/
public class TypesTest {

private static String JSON = "{" +
"\"posByte\":123,\"negByte\":-98," +
"\"posDouble\":9.876543210123456,\"negDouble\":-1.234567890987654E302," +
"\"posFloat\":9.876543,\"negFloat\":-1.2345678," +
"\"posInt\":1234567890,\"negInt\":-987654321," +
"\"posLong\":12345678987654321,\"negLong\":-98765432123456789," +
"\"posShort\":32109,\"negShort\":-23456," +
"\"trueBoolean\":true,\"falseBoolean\":false," +
"\"aChar\":\"\\u0000\"," +
"\"aString\":\"-=[]\\\\;',./_+{}|:\\\"<>?" +
"AaBbCcDdEeFfGgHhIiJjKkLlMmNnOoPpQqRrSsTtUuVvWwXxYyZz" +
"~!@#$%^&*()\"," +
"\"numbers\":[1,1,2,3,5,8]," +
"\"words\":[\"quick\",\"brown\",\"fox\"]" +
"}";

private static String STRING = "-=[]\\;',./_+{}|:\"<>?" +
"AaBbCcDdEeFfGgHhIiJjKkLlMmNnOoPpQqRrSsTtUuVvWwXxYyZz" +
"~!@#$%^&*()";

private static int[] NUMBERS = {1, 1, 2, 3, 5, 8};

private static String[] WORDS = {"quick", "brown", "fox"};

@Test
public void testEncode() {
Map<String, Object> data = new LinkedHashMap<>();
data.put("posByte", (byte) 123);
data.put("negByte", (byte) -98);
data.put("posDouble", 9.876543210123456);
data.put("negDouble", -1.234567890987654E302);
data.put("posFloat", 9.876543f);
data.put("negFloat", -1.2345678f);
data.put("posInt", 1234567890);
data.put("negInt", -987654321);
data.put("posLong", 12345678987654321L);
data.put("negLong", -98765432123456789L);
data.put("posShort", (short) 32109);
data.put("negShort", (short) -23456);
data.put("trueBoolean", true);
data.put("falseBoolean", false);
data.put("aChar", '\0');
data.put("aString", STRING);
data.put("numbers", NUMBERS);
data.put("words", WORDS);
String json = Types.encode(data);
assertNotNull(json);
System.out.println(json);
assertEquals(JSON, json);
}

@Test
public void testDecode() throws IOException {
Map<String, Object> data = Types.decode(JSON);
assertNotNull(data);
assertEquals(18, data.size());
assertEquals(123, data.get("posByte")); // NB: decodes back to int
assertEquals(-98, data.get("negByte")); // NB: decodes back to int
assertEquals(9.876543210123456, bd(data.get("posDouble")).doubleValue());
assertEquals(-1.234567890987654E302, bd(data.get("negDouble")).doubleValue());
assertEquals(9.876543f, bd(data.get("posFloat")).floatValue());
assertEquals(-1.2345678f, bd(data.get("negFloat")).floatValue());
assertEquals(1234567890, data.get("posInt"));
assertEquals(-987654321, data.get("negInt"));
assertEquals(12345678987654321L, data.get("posLong"));
assertEquals(-98765432123456789L, data.get("negLong"));
assertEquals(32109, data.get("posShort")); // NB: decodes back to int
assertEquals(-23456, data.get("negShort")); // NB: decodes back to int
assertEquals(true, data.get("trueBoolean"));
assertEquals(false, data.get("falseBoolean"));
assertEquals("\0", data.get("aChar"));
assertEquals(STRING, data.get("aString"));
List<Integer> numbersList = Arrays.stream(NUMBERS)
.boxed()
.collect(Collectors.toList());
assertEquals(numbersList, data.get("numbers"));
assertEquals(Arrays.asList(WORDS), data.get("words"));
}

private BigDecimal bd(Object posDouble) {
if (posDouble instanceof BigDecimal) return ((BigDecimal) posDouble);
throw new IllegalArgumentException("Not a BigDecimal: " + posDouble.getClass().getName());
}
}

0 comments on commit 2b9064a

Please sign in to comment.