mirror of
https://github.com/pocoproject/poco.git
synced 2025-10-26 18:42:41 +01:00
Work on pubsub sample
This commit is contained in:
@@ -10,11 +10,12 @@
|
||||
//
|
||||
#include <iostream>
|
||||
|
||||
#include "Poco/Net/NetException.h"
|
||||
#include "Poco/Exception.h"
|
||||
#include "Poco/Delegate.h"
|
||||
#include "Poco/Thread.h"
|
||||
|
||||
#include "RedisTest.h"
|
||||
#include "Poco/Redis/AsyncReader.h"
|
||||
|
||||
#include "CppUnit/TestCaller.h"
|
||||
#include "CppUnit/TestSuite.h"
|
||||
@@ -23,7 +24,7 @@ using namespace Poco::Redis;
|
||||
|
||||
|
||||
bool RedisTest::_connected = false;
|
||||
Poco::Redis::AsyncClient RedisTest::_redis;
|
||||
Poco::Redis::Client RedisTest::_redis;
|
||||
|
||||
|
||||
RedisTest::RedisTest(const std::string& name):
|
||||
@@ -35,14 +36,15 @@ RedisTest::RedisTest(const std::string& name):
|
||||
{
|
||||
try
|
||||
{
|
||||
Poco::Timespan t(30, 0); // 30 seconds
|
||||
Poco::Timespan t(10, 0); // Connect within 10 seconds
|
||||
_redis.connect(_host, _port, t);
|
||||
_redis.setReceiveTimeout(t); // Receive answers within 10 seconds
|
||||
_connected = true;
|
||||
std::cout << "Connected to [" << _host << ':' << _port << ']' << std::endl;
|
||||
}
|
||||
catch (Poco::Net::ConnectionRefusedException& e)
|
||||
catch (Poco::Exception& e)
|
||||
{
|
||||
std::cout << "Couldn't connect to " << e.message() << ". " << std::endl;
|
||||
std::cout << "Couldn't connect to [" << _host << ':' << _port << ']' << e.message() << ". " << std::endl;
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -728,26 +730,30 @@ public:
|
||||
|
||||
void RedisTest::testPubSub()
|
||||
{
|
||||
if (!_connected)
|
||||
{
|
||||
std::cout << "Not connected, test skipped." << std::endl;
|
||||
return;
|
||||
}
|
||||
|
||||
RedisSubscriber subscriber;
|
||||
|
||||
Array subscribe;
|
||||
subscribe.add("SUBSCRIBE")
|
||||
.add("test");
|
||||
|
||||
Array subscribeReply = _redis.execute<Array>(subscribe);
|
||||
_redis.execute<void>(subscribe);
|
||||
|
||||
_redis.redisResponse += Poco::delegate(&subscriber, &RedisSubscriber::onMessage);
|
||||
_redis.start();
|
||||
AsyncReader reader(_redis);
|
||||
reader.redisResponse += Poco::delegate(&subscriber, &RedisSubscriber::onMessage);
|
||||
reader.start();
|
||||
|
||||
Poco::Thread::sleep(30000);
|
||||
|
||||
Array unsubscribe;
|
||||
unsubscribe.add("UNSUBSCRIBE");
|
||||
|
||||
Array unsubscribeReply = _redis.execute<Array>(unsubscribe);
|
||||
std::cout << "SUBS: " << unsubscribeReply.toString() << std::endl;
|
||||
|
||||
_redis.stop();
|
||||
_redis.execute<void>(unsubscribe);
|
||||
}
|
||||
|
||||
CppUnit::Test* RedisTest::suite()
|
||||
|
||||
@@ -17,7 +17,7 @@
|
||||
|
||||
|
||||
#include "Poco/Redis/Redis.h"
|
||||
#include "Poco/Redis/AsyncClient.h"
|
||||
#include "Poco/Redis/Client.h"
|
||||
|
||||
#include "CppUnit/TestCase.h"
|
||||
|
||||
@@ -57,7 +57,7 @@ private:
|
||||
std::string _host;
|
||||
unsigned _port;
|
||||
static bool _connected;
|
||||
static Poco::Redis::AsyncClient _redis;
|
||||
static Poco::Redis::Client _redis;
|
||||
|
||||
};
|
||||
|
||||
|
||||
Reference in New Issue
Block a user