+ @Test
+ public void testGetSnapshot() throws Throwable {
+ JavaTestKit kit = new JavaTestKit(getSystem());
+
+ MockConfiguration mockConfig = new MockConfiguration(ImmutableMap.<String, List<String>>builder().
+ put("shard1", Arrays.asList("member-1")).
+ put("shard2", Arrays.asList("member-1")).build());
+
+ ActorRef shardManager = getSystem().actorOf(newShardMgrProps(mockConfig).withDispatcher(
+ Dispatchers.DefaultDispatcherId()));
+
+ shardManager.tell(GetSnapshot.INSTANCE, kit.getRef());
+ Failure failure = kit.expectMsgClass(Failure.class);
+ assertEquals("Failure cause type", IllegalStateException.class, failure.cause().getClass());
+
+ kit = new JavaTestKit(getSystem());
+
+ shardManager.tell(new UpdateSchemaContext(TestModel.createTestContext()), ActorRef.noSender());
+
+ shardManager.tell(new FindLocalShard("shard1", true), kit.getRef());
+ kit.expectMsgClass(LocalShardFound.class);
+ shardManager.tell(new FindLocalShard("shard2", true), kit.getRef());
+ kit.expectMsgClass(LocalShardFound.class);
+
+ shardManager.tell(GetSnapshot.INSTANCE, kit.getRef());
+
+ DatastoreSnapshot datastoreSnapshot = kit.expectMsgClass(DatastoreSnapshot.class);
+
+ assertEquals("getType", shardMrgIDSuffix, datastoreSnapshot.getType());
+ List<ShardSnapshot> shardSnapshots = datastoreSnapshot.getShardSnapshots();
+ Set<String> actualShardNames = new HashSet<>();
+ for(ShardSnapshot s: shardSnapshots) {
+ actualShardNames.add(s.getName());
+ }
+
+ assertEquals("Shard names", Sets.newHashSet("shard1", "shard2"), actualShardNames);
+
+ shardManager.tell(PoisonPill.getInstance(), ActorRef.noSender());
+ }
+