X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=opendaylight%2Fmd-sal%2Fsal-distributed-datastore%2Fsrc%2Ftest%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fcluster%2Fdatastore%2FDatastoreSnapshotRestoreTest.java;h=4cd7290498eeefc7d4a1123162f0120056129d09;hb=b9711f17a53a4fad48197df6c39b58e4faadc862;hp=bbbd95fd08ad777f3462bed408f66d994d4ec773;hpb=aafb8cb044e992dd784d1f4f66508599cc4cd588;p=controller.git diff --git a/opendaylight/md-sal/sal-distributed-datastore/src/test/java/org/opendaylight/controller/cluster/datastore/DatastoreSnapshotRestoreTest.java b/opendaylight/md-sal/sal-distributed-datastore/src/test/java/org/opendaylight/controller/cluster/datastore/DatastoreSnapshotRestoreTest.java index bbbd95fd08..4cd7290498 100644 --- a/opendaylight/md-sal/sal-distributed-datastore/src/test/java/org/opendaylight/controller/cluster/datastore/DatastoreSnapshotRestoreTest.java +++ b/opendaylight/md-sal/sal-distributed-datastore/src/test/java/org/opendaylight/controller/cluster/datastore/DatastoreSnapshotRestoreTest.java @@ -15,32 +15,30 @@ import static org.junit.Assert.assertTrue; import java.io.File; import java.io.FileOutputStream; -import java.math.BigInteger; import java.util.Arrays; import java.util.Collections; -import java.util.Objects; import org.apache.commons.lang3.SerializationUtils; import org.junit.After; import org.junit.Test; import org.opendaylight.controller.cluster.datastore.persisted.DatastoreSnapshot; import org.opendaylight.controller.cluster.datastore.persisted.DatastoreSnapshotList; import org.opendaylight.controller.cluster.datastore.persisted.MetadataShardDataTreeSnapshot; +import org.opendaylight.controller.cluster.datastore.persisted.ShardManagerSnapshot; import org.opendaylight.controller.cluster.datastore.persisted.ShardSnapshotState; -import org.opendaylight.controller.cluster.datastore.shardmanager.ShardManagerSnapshot; import org.opendaylight.controller.cluster.raft.ReplicatedLogEntry; import org.opendaylight.controller.cluster.raft.persisted.Snapshot; import org.opendaylight.controller.md.cluster.datastore.model.CarsModel; import org.opendaylight.controller.md.cluster.datastore.model.PeopleModel; import org.opendaylight.controller.md.cluster.datastore.model.SchemaContextHelper; import org.opendaylight.controller.md.cluster.datastore.model.TestModel; +import org.opendaylight.yangtools.yang.common.Uint64; import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier; import org.opendaylight.yangtools.yang.data.api.schema.NormalizedNode; import org.opendaylight.yangtools.yang.data.api.schema.tree.DataTree; -import org.opendaylight.yangtools.yang.data.api.schema.tree.TreeType; +import org.opendaylight.yangtools.yang.data.api.schema.tree.DataTreeConfiguration; import org.opendaylight.yangtools.yang.data.impl.schema.ImmutableNodes; import org.opendaylight.yangtools.yang.data.impl.schema.tree.InMemoryDataTreeFactory; - /** * Unit tests for DatastoreSnapshotRestore. * @@ -62,11 +60,10 @@ public class DatastoreSnapshotRestoreTest { assertTrue("Failed to mkdir " + restoreDirectoryPath, restoreDirectoryFile.mkdirs()); final DatastoreSnapshot configSnapshot = new DatastoreSnapshot("config", - SerializationUtils.serialize(newShardManagerSnapshot("config-one", "config-two")), + newShardManagerSnapshot("config-one", "config-two"), Arrays.asList(new DatastoreSnapshot.ShardSnapshot("config-one", newSnapshot(CarsModel.BASE_PATH, CarsModel.newCarsNode(CarsModel.newCarsMapNode(CarsModel.newCarEntry("optima", - BigInteger.valueOf(20000L)),CarsModel.newCarEntry("sportage", - BigInteger.valueOf(30000L)))))), + Uint64.valueOf(20000)),CarsModel.newCarEntry("sportage", Uint64.valueOf(30000)))))), new DatastoreSnapshot.ShardSnapshot("config-two", newSnapshot(PeopleModel.BASE_PATH, PeopleModel.emptyContainer())))); @@ -94,11 +91,18 @@ public class DatastoreSnapshotRestoreTest { assertNull("Expected null DatastoreSnapshot", instance.getAndRemove("oper")); } - private static void assertDatastoreSnapshotEquals(DatastoreSnapshot expected, DatastoreSnapshot actual) { + private static void assertDatastoreSnapshotEquals(final DatastoreSnapshot expected, + final DatastoreSnapshot actual) { assertNotNull("DatastoreSnapshot is null", actual); assertEquals("getType", expected.getType(), actual.getType()); - assertTrue("ShardManager snapshots don't match", Objects.deepEquals(expected.getShardManagerSnapshot(), - actual.getShardManagerSnapshot())); + + if (expected.getShardManagerSnapshot() == null) { + assertNull("Expected null ShardManagerSnapshot", actual.getShardManagerSnapshot()); + } else { + assertEquals("ShardManagerSnapshot", expected.getShardManagerSnapshot().getShardList(), + actual.getShardManagerSnapshot().getShardList()); + } + assertEquals("ShardSnapshots size", expected.getShardSnapshots().size(), actual.getShardSnapshots().size()); for (int i = 0; i < expected.getShardSnapshots().size(); i++) { assertEquals("ShardSnapshot " + (i + 1) + " name", expected.getShardSnapshots().get(i).getName(), @@ -108,7 +112,7 @@ public class DatastoreSnapshotRestoreTest { } } - private static void assertSnapshotEquals(String prefix, Snapshot expected, Snapshot actual) { + private static void assertSnapshotEquals(final String prefix, final Snapshot expected, final Snapshot actual) { assertEquals(prefix + " lastIndex", expected.getLastIndex(), actual.getLastIndex()); assertEquals(prefix + " lastTerm", expected.getLastTerm(), actual.getLastTerm()); assertEquals(prefix + " lastAppliedIndex", expected.getLastAppliedIndex(), actual.getLastAppliedIndex()); @@ -120,16 +124,16 @@ public class DatastoreSnapshotRestoreTest { ((ShardSnapshotState)actual.getState()).getSnapshot().getRootNode()); } - private static ShardManagerSnapshot newShardManagerSnapshot(String... shards) { - return ShardManagerSnapshot.forShardList(Arrays.asList(shards)); + private static ShardManagerSnapshot newShardManagerSnapshot(final String... shards) { + return new ShardManagerSnapshot(Arrays.asList(shards), Collections.emptyMap()); } - private static Snapshot newSnapshot(YangInstanceIdentifier path, NormalizedNode node) + private static Snapshot newSnapshot(final YangInstanceIdentifier path, final NormalizedNode node) throws Exception { - DataTree dataTree = InMemoryDataTreeFactory.getInstance().create(TreeType.OPERATIONAL); - dataTree.setSchemaContext(SchemaContextHelper.full()); + DataTree dataTree = new InMemoryDataTreeFactory().create(DataTreeConfiguration.DEFAULT_OPERATIONAL, + SchemaContextHelper.full()); AbstractShardTest.writeToStore(dataTree, path, node); - NormalizedNode root = AbstractShardTest.readStore(dataTree, YangInstanceIdentifier.EMPTY); + NormalizedNode root = AbstractShardTest.readStore(dataTree, YangInstanceIdentifier.empty()); return Snapshot.create(new ShardSnapshotState(new MetadataShardDataTreeSnapshot(root)), Collections.emptyList(), 2, 1, 2, 1, 1, "member-1", null);