pubsub command check if we are connected
This commit is contained in:
@@ -2023,17 +2023,20 @@ public class Jedis extends BinaryJedis implements JedisCommands {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void subscribe(JedisPubSub jedisPubSub, String... channels) {
|
public void subscribe(JedisPubSub jedisPubSub, String... channels) {
|
||||||
|
runChecks();
|
||||||
client.setTimeoutInfinite();
|
client.setTimeoutInfinite();
|
||||||
jedisPubSub.proceed(client, channels);
|
jedisPubSub.proceed(client, channels);
|
||||||
client.rollbackTimeout();
|
client.rollbackTimeout();
|
||||||
}
|
}
|
||||||
|
|
||||||
public Long publish(String channel, String message) {
|
public Long publish(String channel, String message) {
|
||||||
|
runChecks();
|
||||||
client.publish(channel, message);
|
client.publish(channel, message);
|
||||||
return client.getIntegerReply();
|
return client.getIntegerReply();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void psubscribe(JedisPubSub jedisPubSub, String... patterns) {
|
public void psubscribe(JedisPubSub jedisPubSub, String... patterns) {
|
||||||
|
runChecks();
|
||||||
client.setTimeoutInfinite();
|
client.setTimeoutInfinite();
|
||||||
jedisPubSub.proceedWithPatterns(client, patterns);
|
jedisPubSub.proceedWithPatterns(client, patterns);
|
||||||
client.rollbackTimeout();
|
client.rollbackTimeout();
|
||||||
|
|||||||
@@ -6,6 +6,7 @@ import java.net.UnknownHostException;
|
|||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
import redis.clients.jedis.Jedis;
|
import redis.clients.jedis.Jedis;
|
||||||
|
import redis.clients.jedis.JedisException;
|
||||||
import redis.clients.jedis.JedisPubSub;
|
import redis.clients.jedis.JedisPubSub;
|
||||||
|
|
||||||
public class PublishSubscribeCommandsTest extends JedisCommandTestBase {
|
public class PublishSubscribeCommandsTest extends JedisCommandTestBase {
|
||||||
@@ -232,4 +233,30 @@ public class PublishSubscribeCommandsTest extends JedisCommandTestBase {
|
|||||||
jedis.subscribe(pubsub, "foo");
|
jedis.subscribe(pubsub, "foo");
|
||||||
t.join();
|
t.join();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void subscribeWithoutConnecting() {
|
||||||
|
try {
|
||||||
|
Jedis jedis = new Jedis(hnp.host, hnp.port);
|
||||||
|
jedis.subscribe(new JedisPubSub() {
|
||||||
|
public void onMessage(String channel, String message) {
|
||||||
|
}
|
||||||
|
public void onPMessage(String pattern, String channel,
|
||||||
|
String message) {
|
||||||
|
}
|
||||||
|
public void onSubscribe(String channel, int subscribedChannels) {
|
||||||
|
}
|
||||||
|
public void onUnsubscribe(String channel, int subscribedChannels) {
|
||||||
|
}
|
||||||
|
public void onPUnsubscribe(String pattern, int subscribedChannels) {
|
||||||
|
}
|
||||||
|
public void onPSubscribe(String pattern, int subscribedChannels) {
|
||||||
|
}
|
||||||
|
}, "foo");
|
||||||
|
} catch(NullPointerException ex) {
|
||||||
|
fail();
|
||||||
|
} catch(JedisException ex) {
|
||||||
|
// this is OK because we are not sending AUTH command
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
Reference in New Issue
Block a user