summaryrefslogtreecommitdiff
path: root/src/test/java/bjc
diff options
context:
space:
mode:
authorbjculkin <bjculkin@localhost>2023-10-25 23:00:44 +0000
committerbjculkin <bjculkin@localhost>2023-10-25 23:00:44 +0000
commitcbf4dda5cc09dc6d2c3c10329e7941923cc04e2e (patch)
tree87d199f6b7eb45046ddb2489c6b8d85d846cab6c /src/test/java/bjc
parent0f958b08b3446a866418aa485bb60c208d952033 (diff)
Tweak for new setup
Also, add some tests for Context
Diffstat (limited to 'src/test/java/bjc')
-rw-r--r--src/test/java/bjc/test/TestUtils.java20
-rw-r--r--src/test/java/bjc/test/data/ContextsTest.java64
2 files changed, 84 insertions, 0 deletions
diff --git a/src/test/java/bjc/test/TestUtils.java b/src/test/java/bjc/test/TestUtils.java
index 04cdf70..664aaef 100644
--- a/src/test/java/bjc/test/TestUtils.java
+++ b/src/test/java/bjc/test/TestUtils.java
@@ -144,4 +144,24 @@ public class TestUtils {
public static <T> void assertStackEquals(bjc.esodata.Stack<T> src, T... exps) {
assertArrayEquals(exps, src.toArray());
}
+
+ public static <T> void assertOneOf(T actual, T... expecteds) {
+ for (T expected : expecteds) {
+ if (expected.equals(actual)) return;
+ }
+
+ StringBuilder builder = new StringBuilder();
+ builder.append("Value '");
+ builder.append(actual.toString());
+ builder.append("' was not one of the expected values: ");
+ for (T expected : expecteds) {
+ builder.append("'");
+ builder.append(expected.toString());
+ builder.append("', ");
+ }
+ builder.deleteCharAt(builder.length() - 1);
+ builder.deleteCharAt(builder.length() - 1);
+
+ assertFalse("Value '%' was no", true);
+ }
}
diff --git a/src/test/java/bjc/test/data/ContextsTest.java b/src/test/java/bjc/test/data/ContextsTest.java
new file mode 100644
index 0000000..cff6e06
--- /dev/null
+++ b/src/test/java/bjc/test/data/ContextsTest.java
@@ -0,0 +1,64 @@
+package bjc.test.data;
+
+import static org.junit.Assert.*;
+
+import org.junit.Test;
+
+import bjc.data.Context;
+import bjc.data.Contexts;
+import bjc.test.TestUtils;
+
+public class ContextsTest {
+
+ @Test(expected = UnsupportedOperationException.class)
+ public void testNull() {
+ Context ctx = Contexts.NULL;
+ ctx.register("a", "b");
+ }
+ @Test
+ public void testCreate() {
+ Context ctx = Contexts.create();
+
+ assertTrue(ctx.getParent() == Contexts.NULL);
+
+ ctx.register("a", "b");
+
+ assertEquals("b", ctx.get("a"));
+ assertEquals("b", ctx.get(String.class));
+ assertEquals("b", ctx.get("a", String.class));
+ }
+
+ @Test
+ public void testCreateContext() {
+ Context parent = Contexts.create();
+
+ assertTrue(parent.getParent() == Contexts.NULL);
+
+ parent.register("a", "1");
+
+ Context child1 = Contexts.create(parent);
+ Context child2 = Contexts.create(parent);
+
+ Context child11 = Contexts.create(child1);
+ Context child22 = Contexts.create(child2);
+
+ child1.register("b", "2");
+ child1.register("c", "3");
+
+ child2.register("d", "4");
+ child2.register("e", "5");
+
+ child11.register("a", "6");
+
+ child22.register("a", "7");
+ child22.register("f", "8");
+
+ assertEquals("2", child1.get("b"));
+ assertEquals("1", child1.get("a"));
+ assertEquals("6", child11.get("a"));
+ assertEquals("7", child22.get("a"));
+
+ TestUtils.assertOneOf(child1.get(String.class), "1", "2", "3");
+ }
+
+}