/*
* (C) Copyright 2015 Nuxeo SA (http://nuxeo.com/) and others.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
* Contributors:
* bdelbosc
*/
package org.nuxeo.ecm.core.redis;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertNotNull;
import javax.inject.Inject;
import org.junit.Assume;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.nuxeo.ecm.core.redis.RedisFeature.Mode;
import org.nuxeo.ecm.core.redis.contribs.RedisDBSClusterInvalidator;
import org.nuxeo.ecm.core.storage.dbs.DBSInvalidations;
import org.nuxeo.ecm.core.test.CoreFeature;
import org.nuxeo.runtime.api.Framework;
import org.nuxeo.runtime.test.runner.Features;
import org.nuxeo.runtime.test.runner.FeaturesRunner;
/**
* @since 8.10
*/
@RunWith(FeaturesRunner.class)
@Features({ CoreFeature.class, RedisFeature.class })
public class TestRedisDBSClusterInvalidator {
@Inject
protected RedisFeature redisFeature;
@Test
public void testInitializeAndClose() throws Exception {
RedisDBSClusterInvalidator rci = createRedisDBSClusterInvalidator("node1");
rci.close();
}
private RedisDBSClusterInvalidator createRedisDBSClusterInvalidator(String node) {
assumeTrueRedisServer();
RedisDBSClusterInvalidator rci = new RedisDBSClusterInvalidator();
rci.initialize(node, "test");
return rci;
}
private void assumeTrueRedisServer() {
Assume.assumeTrue("Require a true Redis server with pubsub support", Mode.server == redisFeature.getMode());
}
@Test
public void testSendReceiveInvalidations() throws Exception {
RedisExecutor redisExecutor = Framework.getLocalService(RedisExecutor.class);
redisExecutor.startMonitor();
int delayMs = 10000;
RedisDBSClusterInvalidator rci2 = createRedisDBSClusterInvalidator("node2");
RedisDBSClusterInvalidator rci1 = createRedisDBSClusterInvalidator("node1");
try {
DBSInvalidations invals = new DBSInvalidations();
invals.add("docid1");
invals.add("docid2");
rci1.sendInvalidations(invals);
DBSInvalidations invalsReceived = waitForInvalidation(rci2, delayMs);
assertNotNull("No invalidation received after " + delayMs + " ms", invalsReceived.isEmpty());
assertEquals(invals.toString(), invalsReceived.toString());
} finally {
rci1.close();
rci2.close();
redisExecutor.stopMonitor();
}
}
private DBSInvalidations waitForInvalidation(RedisDBSClusterInvalidator rci2, int countdown_ms)
throws InterruptedException {
DBSInvalidations ret;
do {
Thread.sleep(10);
countdown_ms -= 10;
ret = rci2.receiveInvalidations();
} while (ret.isEmpty() && countdown_ms > 0);
return ret;
}
@Test
public void testSendReceiveMultiInvalidations() throws Exception {
int delayMs = 10000;
RedisExecutor redisExecutor = Framework.getLocalService(RedisExecutor.class);
redisExecutor.startMonitor();
RedisDBSClusterInvalidator rci2 = createRedisDBSClusterInvalidator("node2");
RedisDBSClusterInvalidator rci1 = createRedisDBSClusterInvalidator("node1");
try {
DBSInvalidations invals = new DBSInvalidations();
invals.add("docid1");
rci1.sendInvalidations(invals);
invals = new DBSInvalidations();
invals.add("docid2");
rci1.sendInvalidations(invals);
DBSInvalidations invalsReceived = waitForInvalidation(rci2, delayMs);
assertNotNull(invals.ids);
assertNotNull("No invalidation received after " + delayMs + " ms", invalsReceived.ids);
assertEquals(2, invalsReceived.ids.size());
} finally {
rci1.close();
rci2.close();
redisExecutor.stopMonitor();
}
}
}