1 package org.opendaylight.controller.cluster.datastore.shardstrategy;
3 import org.junit.BeforeClass;
6 import org.junit.rules.ExpectedException;
7 import org.opendaylight.controller.cluster.datastore.Configuration;
8 import org.opendaylight.controller.cluster.datastore.ConfigurationImpl;
9 import org.opendaylight.controller.md.cluster.datastore.model.CarsModel;
10 import org.opendaylight.yangtools.yang.common.QName;
11 import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier;
13 import static junit.framework.Assert.assertEquals;
15 public class ModuleShardStrategyTest {
17 public ExpectedException expectedEx = ExpectedException.none();
19 private static Configuration configuration;
22 public static void setUpClass(){
23 configuration = new ConfigurationImpl("module-shards.conf", "modules.conf");
28 public void testFindShard() throws Exception {
29 ModuleShardStrategy moduleShardStrategy =
30 new ModuleShardStrategy("cars", configuration);
32 String shard = moduleShardStrategy.findShard(CarsModel.BASE_PATH);
34 assertEquals("cars-1", shard);
38 public void testFindShardWhenModuleConfigurationPresentInModulesButMissingInModuleShards() {
40 final QName BASE_QNAME = QName.create("urn:opendaylight:params:xml:ns:yang:controller:md:sal:dom:store:test:missing", "2014-03-13",
43 final YangInstanceIdentifier BASE_PATH = YangInstanceIdentifier.of(BASE_QNAME);
45 ModuleShardStrategy moduleShardStrategy =
46 new ModuleShardStrategy("missing", configuration);
48 String shard = moduleShardStrategy.findShard(BASE_PATH);
50 assertEquals(DefaultShardStrategy.DEFAULT_SHARD, shard);