Created
January 27, 2011 02:02
-
-
Save rsumbaly/797932 to your computer and use it in GitHub Desktop.
Issue 326 - in voldemort.store.routed.RoutedStoreTest
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| @Test | |
| public void testPutDeleteZoneRouting() throws Exception { | |
| cluster = VoldemortTestConstants.getEightNodeClusterWithZones(); | |
| HashMap<Integer, Integer> zoneReplicationFactor = Maps.newHashMap(); | |
| zoneReplicationFactor.put(0, 2); | |
| zoneReplicationFactor.put(1, 2); | |
| Versioned<byte[]> versioned = new Versioned<byte[]>(new byte[] { 1 }); | |
| Map<Integer, Store<ByteArray, byte[], byte[]>> subStores = Maps.newHashMap(); | |
| Set<Integer> sleepy = Sets.newHashSet(4, 5, 6, 7); | |
| int count = 0; | |
| for(Node n: cluster.getNodes()) { | |
| Store<ByteArray, byte[], byte[]> subStore = null; | |
| if(sleepy != null && sleepy.contains(n.getId())) | |
| subStore = new SleepyStore<ByteArray, byte[], byte[]>(81, | |
| new InMemoryStorageEngine<ByteArray, byte[], byte[]>("test")); | |
| else | |
| subStore = new InMemoryStorageEngine<ByteArray, byte[], byte[]>("test"); | |
| subStores.put(n.getId(), subStore); | |
| count += 1; | |
| } | |
| setFailureDetector(subStores); | |
| StoreDefinition storeDef = ServerTestUtils.getStoreDef("test", | |
| 1, | |
| 1, | |
| 1, | |
| 1, | |
| 0, | |
| 0, | |
| zoneReplicationFactor, | |
| HintedHandoffStrategyType.PROXIMITY_STRATEGY, | |
| RoutingStrategyType.ZONE_STRATEGY); | |
| routedStoreThreadPool = Executors.newFixedThreadPool(8); | |
| RoutedStoreFactory routedStoreFactory = new RoutedStoreFactory(true, | |
| routedStoreThreadPool, | |
| 60); | |
| Store<ByteArray, byte[], byte[]> s1 = routedStoreFactory.create(cluster, | |
| storeDef, | |
| subStores, | |
| true, | |
| failureDetector); | |
| RoutingStrategy routingStrategy = new RoutingStrategyFactory().updateRoutingStrategy(storeDef, | |
| cluster); | |
| List<Node> nodesRoutedTo = routingStrategy.routeRequest("test".getBytes()); | |
| long start = System.nanoTime(), elapsed; | |
| try { | |
| s1.put(new ByteArray("test".getBytes()), versioned, null); | |
| } finally { | |
| elapsed = (System.nanoTime() - start) / Time.NS_PER_MS; | |
| assertTrue(elapsed + " < " + 81, elapsed < 81); | |
| } | |
| Thread.sleep(81 - elapsed); | |
| for(Node node: nodesRoutedTo) { | |
| Assert.assertEquals(subStores.get(node.getId()).get(new ByteArray("test".getBytes()), | |
| null).get(0), versioned); | |
| } | |
| start = System.nanoTime(); | |
| try { | |
| s1.delete(new ByteArray("test".getBytes()), versioned.getVersion()); | |
| } finally { | |
| elapsed = (System.nanoTime() - start) / Time.NS_PER_MS; | |
| assertTrue(elapsed + " < " + 81, elapsed < 81); | |
| } | |
| Thread.sleep(81 - elapsed); | |
| for(Node node: nodesRoutedTo) { | |
| assertEquals(subStores.get(node.getId()) | |
| .get(new ByteArray("test".getBytes()), null) | |
| .size(), 0); | |
| } | |
| } |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment