From 18775f4a7d335de48816ac8acdf77cd37474885d Mon Sep 17 00:00:00 2001 From: ajay-gov Date: Mon, 11 Oct 2021 08:45:41 -0700 Subject: [PATCH] Assign oldObject in the JoinMapLaneRelayUpdate.beginPhase method when phase is 2 Fix for issue #66 --- .../java/swim/server/JoinMapLaneSpec.java | 103 +++++++++++++++++- .../swim/system/lane/JoinMapLaneModel.java | 8 ++ 2 files changed, 105 insertions(+), 6 deletions(-) diff --git a/swim-java/swim-runtime-java/swim-host-java/swim.server/src/test/java/swim/server/JoinMapLaneSpec.java b/swim-java/swim-runtime-java/swim-host-java/swim.server/src/test/java/swim/server/JoinMapLaneSpec.java index b6bab6351..2809ae7b9 100644 --- a/swim-java/swim-runtime-java/swim-host-java/swim.server/src/test/java/swim/server/JoinMapLaneSpec.java +++ b/swim-java/swim-runtime-java/swim-host-java/swim.server/src/test/java/swim/server/JoinMapLaneSpec.java @@ -160,13 +160,13 @@ public void didClose() { .keyClass(String.class) .valueClass(String.class) .hostUri("warp://localhost:53556/") - .nodeUri("/join/map/all") + .nodeUri("/join/mapA/all") .laneUri("join") .observe(new JoinMapLinkController()) .open(); - joinDidReceive.await(1, TimeUnit.SECONDS); - joinDidUpdate.await(1, TimeUnit.SECONDS); + joinDidReceive.await(3, TimeUnit.SECONDS); + joinDidUpdate.await(3, TimeUnit.SECONDS); assertEquals(joinDidReceive.getCount(), 0); assertEquals(joinDidUpdate.getCount(), 0); assertEquals(join.size(), 4); @@ -179,6 +179,63 @@ public void didClose() { } } + private static CountDownLatch laneWillDownlink = new CountDownLatch(2); + private static CountDownLatch laneDidDownlink = new CountDownLatch(2); + private static CountDownLatch laneWillUpdate = new CountDownLatch(4); + private static CountDownLatch laneDidUpdate0 = new CountDownLatch(2); + private static CountDownLatch laneDidUpdate1 = new CountDownLatch(2); + private static CountDownLatch laneWillRemove = new CountDownLatch(1); + private static CountDownLatch laneDidRemove = new CountDownLatch(1); + + @Test + public void testJoinMapLaneCallback() throws InterruptedException { + final Kernel kernel = ServerLoader.loadServerStack(); + final TestJoinMapPlane plane = kernel.openSpace(ActorSpaceDef.fromName("test")) + .openPlane("test", TestJoinMapPlane.class); + + try { + kernel.openService(WebServiceDef.standard().port(53556).spaceName("test")); + kernel.start(); + final MapDownlink xs = plane.downlinkMap() + .keyClass(String.class) + .valueClass(String.class) + .hostUri("warp://localhost:53556/") + .nodeUri("/map/xs") + .laneUri("map") + .open(); + xs.didSync(() -> { + xs.put("x0", "a"); + xs.put("x1", "b"); + }); + + final MapDownlink join = plane.downlinkMap() + .keyClass(String.class) + .valueClass(String.class) + .hostUri("warp://localhost:53556/") + .nodeUri("/join/mapB/all") + .laneUri("join") + .open(); + + laneDidUpdate0.await(3, TimeUnit.SECONDS); + assertEquals(laneWillDownlink.getCount(), 0); + assertEquals(laneDidDownlink.getCount(), 0); + assertEquals(laneWillUpdate.getCount(), 2); + assertEquals(laneDidUpdate0.getCount(), 0); + + xs.put("x0", "aa"); + xs.put("x1", "bb"); + + laneDidUpdate1.await(3, TimeUnit.SECONDS); + assertEquals(laneWillDownlink.getCount(), 0); + assertEquals(laneDidDownlink.getCount(), 0); + assertEquals(laneWillUpdate.getCount(), 0); + assertEquals(laneDidUpdate1.getCount(), 0); + + } finally { + kernel.stop(); + } + } + static class TestMapLaneAgent extends AbstractAgent { @SwimLane("map") @@ -213,7 +270,20 @@ public void didRemove(String key, String oldValue) { } - static class TestJoinMapLaneAgent extends AbstractAgent { + static class TestJoinMapLaneAgentA extends AbstractAgent { + + @SwimLane("join") + JoinMapLane testJoinMap = this.joinMapLane(); + + @Override + public void didStart() { + this.testJoinMap.downlink("xs").hostUri("warp://localhost:53556").nodeUri("/map/xs").laneUri("map").open(); + this.testJoinMap.downlink("ys").hostUri("warp://localhost:53556").nodeUri("/map/ys").laneUri("map").open(); + } + + } + + static class TestJoinMapLaneAgentB extends AbstractAgent { @SwimLane("join") JoinMapLane testJoinMap = this.joinMapLane() @@ -232,33 +302,51 @@ class TestJoinMapLaneController implements WillDownlinkMap, DidDownlinkM @Override public MapDownlink willDownlink(String key, MapDownlink downlink) { System.out.println(nodeUri() + " willDownlink key: " + Format.debug(key) + "; downlink: " + downlink); + laneWillDownlink.countDown(); return downlink; } @Override public void didDownlink(String key, MapDownlink downlink) { System.out.println(nodeUri() + " didDownlink key: " + Format.debug(key) + "; downlink: " + downlink); + laneDidDownlink.countDown(); } @Override public String willUpdate(String key, String newValue) { System.out.println(nodeUri() + " willUpdate key: " + Format.debug(key) + "; newValue: " + Format.debug(newValue)); + laneWillUpdate.countDown(); return newValue; } @Override public void didUpdate(String key, String newValue, String oldValue) { System.out.println(nodeUri() + " didUpdate key: " + Format.debug(key) + "; newValue: " + Format.debug(newValue) + "; oldValue: " + Format.debug(oldValue)); + if (key.equals("x0") && newValue.equals("a")) { + //assertEquals(oldValue, ""); + laneDidUpdate0.countDown(); + } else if (key.equals("x0") && newValue.equals("aa")) { + assertEquals(oldValue, "a"); + laneDidUpdate1.countDown(); + } else if (key.equals("x1") && newValue.equals("b")) { + assertEquals(oldValue, ""); + laneDidUpdate0.countDown(); + } else if (key.equals("x1") && newValue.equals("bb")) { + //assertEquals(oldValue, "b"); + laneDidUpdate1.countDown(); + } } @Override public void willRemove(String key) { System.out.println(nodeUri() + " willRemove key: " + Format.debug(key)); + laneWillRemove.countDown(); } @Override public void didRemove(String key, String oldValue) { System.out.println(nodeUri() + " didRemove key: " + Format.debug(key) + "; oldValue: " + Format.debug(oldValue)); + laneDidRemove.countDown(); } } @@ -270,8 +358,11 @@ static class TestJoinMapPlane extends AbstractPlane { @SwimRoute("/map/:name") AgentRoute mapRoute; - @SwimRoute("/join/map/:name") - AgentRoute joinMapRoute; + @SwimRoute("/join/mapA/:name") + AgentRoute joinMapA; + + @SwimRoute("/join/mapB/:name") + AgentRoute joinMapB; } diff --git a/swim-java/swim-runtime-java/swim-host-java/swim.system/src/main/java/swim/system/lane/JoinMapLaneModel.java b/swim-java/swim-runtime-java/swim-host-java/swim.system/src/main/java/swim/system/lane/JoinMapLaneModel.java index 70e59d2f5..9226dacd2 100644 --- a/swim-java/swim-runtime-java/swim-host-java/swim.system/src/main/java/swim/system/lane/JoinMapLaneModel.java +++ b/swim-java/swim-runtime-java/swim-host-java/swim.system/src/main/java/swim/system/lane/JoinMapLaneModel.java @@ -428,6 +428,14 @@ protected void beginPhase(int phase) { if (this.oldValue == null) { this.oldValue = Value.absent(); } + + if (this.valueForm != null) { + this.oldObject = this.valueForm.cast(this.oldValue); + if (this.oldObject == null) { + this.oldObject = this.valueForm.unit(); + } + } + } }