diff --git a/modules/cells/src/main/java/dmg/cells/services/LocationManager.java b/modules/cells/src/main/java/dmg/cells/services/LocationManager.java index a417ddb9561..a5d5deb1c0d 100644 --- a/modules/cells/src/main/java/dmg/cells/services/LocationManager.java +++ b/modules/cells/src/main/java/dmg/cells/services/LocationManager.java @@ -225,7 +225,7 @@ public CoreDomainInfo(byte[] bytes) { } } catch (IOException ie) { throw new IllegalArgumentException( - "Failed deserializing LocationManager Cores as uri: {}", ie.getCause()); + "Failed deserializing LocationManager Cores as uri", ie); } } @@ -513,6 +513,10 @@ public void close() { public void reset(Mode mode, State state) { } + private static boolean hasNoData(ChildData data) { + return data == null || data.getData() == null || data.getData().length == 0; + } + public void update(PathChildrenCacheEvent event) { LOGGER.info("{}", event); String cell; @@ -525,12 +529,22 @@ public void update(PathChildrenCacheEvent event) { } break; case CHILD_UPDATED: - cell = connectors.remove(ZKPaths.getNodeFromPath(event.getData().getPath())); + if (hasNoData(event.getData())) { + LOGGER.warn("Ignoring empty data on UPDATED for {}", event.getData().getPath()); + break; + } + cell = connectors.remove( + ZKPaths.getNodeFromPath(event.getData().getPath())); if (cell != null) { killConnector(cell); } // fall through case CHILD_ADDED: + if (hasNoData(event.getData())) { + LOGGER.warn("Ignoring empty data on ADDED for {}", event.getData().getPath()); + break; + } + //Log if the Core Domain Information received is incompatible with previous CoreDomainInfo info = infoFromZKEvent(event); String domain = ZKPaths.getNodeFromPath(event.getData().getPath());