mirror of
https://github.com/pocoproject/poco.git
synced 2024-12-18 04:10:33 +01:00
Add more commands
This commit is contained in:
parent
93afd2637c
commit
ee19720231
@ -21,6 +21,8 @@
|
||||
#include "Poco/Redis/Redis.h"
|
||||
#include "Poco/Redis/Array.h"
|
||||
|
||||
#include <vector>
|
||||
|
||||
namespace Poco {
|
||||
namespace Redis {
|
||||
|
||||
@ -38,8 +40,50 @@ public:
|
||||
virtual ~Command();
|
||||
/// Destructor
|
||||
|
||||
static Command append(const std::string& key, const std::string& value);
|
||||
/// Returns an APPEND command
|
||||
|
||||
static Command del(const std::string& key);
|
||||
/// Returns an DEL command
|
||||
|
||||
static Command del(const std::vector<std::string>& keys);
|
||||
/// Returns an DEL command
|
||||
|
||||
static Command get(const std::string& key);
|
||||
/// Returns an GET command
|
||||
|
||||
static Command incr(const std::string& key, Int64 by = 0);
|
||||
/// Returns an INCR or INCRBY command. Calls INCR when by is omitted or zero.
|
||||
|
||||
static Command lindex(const std::string& list, Int64 index = 0);
|
||||
/// Returns a LINDEX command
|
||||
|
||||
static Command linsert(const std::string& list, bool before, const std::string& reference, const std::string& value);
|
||||
/// Returns a LINSERT command
|
||||
|
||||
static Command llen(const std::string& list);
|
||||
/// Returns a LINDEX command
|
||||
|
||||
static Command lpush(const std::string& list, const std::string& value, bool create = true);
|
||||
/// Returns a LPUSH or LPUSHX (when create is false) command
|
||||
|
||||
static Command lpush(const std::string& list, const std::vector<std::string>& value, bool create = true);
|
||||
/// Returns a LPUSH or LPUSHX (when create is false) command
|
||||
|
||||
static Command lrange(const std::string& list, Int64 start = 0, Int64 stop = 0);
|
||||
/// Returns a LRANGE command
|
||||
|
||||
static Command set(const std::string& key, const std::string& value, bool overwrite = true, const Poco::Timespan& expireTime = 0, bool create = true);
|
||||
/// Returns a SET command to set the key with a value
|
||||
|
||||
static Command set(const std::string& key, Int64 value, bool overwrite = true, const Poco::Timespan& expireTime = 0, bool create = true);
|
||||
/// Returns a SET command to set the key with a value
|
||||
|
||||
static Command rpush(const std::string& list, const std::string& value, bool create = true);
|
||||
/// Returns a RPUSH or RPUSHX (when create is false) command
|
||||
|
||||
static Command rpush(const std::string& list, const std::vector<std::string>& value, bool create = true);
|
||||
/// Returns a RPUSH or RPUSHX (when create is false) command
|
||||
};
|
||||
|
||||
}} // namespace Poco::Redis
|
||||
|
@ -16,6 +16,7 @@
|
||||
//
|
||||
|
||||
#include "Poco/Redis/Command.h"
|
||||
#include "Poco/NumberFormatter.h"
|
||||
|
||||
namespace Poco {
|
||||
namespace Redis {
|
||||
@ -33,18 +34,131 @@ Command::~Command()
|
||||
{
|
||||
}
|
||||
|
||||
Command Command::append(const std::string& key, const std::string& value)
|
||||
{
|
||||
Command cmd("APPEND");
|
||||
cmd.add(key).add(value);
|
||||
return cmd;
|
||||
}
|
||||
|
||||
Command Command::del(const std::string& key)
|
||||
{
|
||||
Command cmd("DEL");
|
||||
cmd.add(key);
|
||||
return cmd;
|
||||
}
|
||||
|
||||
Command Command::del(const std::vector<std::string>& keys)
|
||||
{
|
||||
Command cmd("DEL");
|
||||
for(std::vector<std::string>::const_iterator it = keys.begin(); it != keys.end(); ++it)
|
||||
{
|
||||
cmd.add(*it);
|
||||
}
|
||||
return cmd;
|
||||
}
|
||||
|
||||
Command Command::get(const std::string& key)
|
||||
{
|
||||
Command cmd("GET");
|
||||
cmd.add(key);
|
||||
return cmd;
|
||||
}
|
||||
|
||||
Command Command::incr(const std::string& key, Int64 by)
|
||||
{
|
||||
Command cmd(by == 0 ? "INCR" : "INCRBY");
|
||||
cmd.add(key);
|
||||
if ( by > 0 ) cmd.add(NumberFormatter::format(by));
|
||||
return cmd;
|
||||
}
|
||||
|
||||
Command Command::lindex(const std::string& list, Int64 index)
|
||||
{
|
||||
Command cmd("LINDEX");
|
||||
cmd.add(list).add(NumberFormatter::format(index));
|
||||
return cmd;
|
||||
}
|
||||
|
||||
Command Command::linsert(const std::string& list, bool before, const std::string& reference, const std::string& value)
|
||||
{
|
||||
Command cmd("LINSERT");
|
||||
cmd.add(list).add(before ? "BEFORE" : "AFTER").add(reference).add(value);
|
||||
return cmd;
|
||||
}
|
||||
|
||||
Command Command::llen(const std::string& list)
|
||||
{
|
||||
Command cmd("LLEN");
|
||||
cmd.add(list);
|
||||
return cmd;
|
||||
}
|
||||
|
||||
Command Command::lpush(const std::string& list, const std::string& value, bool create)
|
||||
{
|
||||
Command cmd(create ? "LPUSH" : "LPUSHX");
|
||||
cmd.add(list).add(value);
|
||||
|
||||
return cmd;
|
||||
}
|
||||
|
||||
Command Command::lpush(const std::string& list, const std::vector<std::string>& values, bool create)
|
||||
{
|
||||
Command cmd(create ? "LPUSH" : "LPUSHX");
|
||||
cmd.add(list);
|
||||
|
||||
for(std::vector<std::string>::const_iterator it = values.begin(); it != values.end(); ++it)
|
||||
{
|
||||
cmd.add(*it);
|
||||
}
|
||||
|
||||
return cmd;
|
||||
}
|
||||
|
||||
Command Command::lrange(const std::string& list, Int64 start, Int64 stop)
|
||||
{
|
||||
Command cmd("LRANGE");
|
||||
cmd.add(list).add(NumberFormatter::format(start)).add(NumberFormatter::format(stop));
|
||||
return cmd;
|
||||
}
|
||||
|
||||
|
||||
Command Command::set(const std::string& key, const std::string& value, bool overwrite, const Poco::Timespan& expireTime, bool create)
|
||||
{
|
||||
Command cmd("SET");
|
||||
cmd.add(key);
|
||||
cmd.add(value);
|
||||
cmd.add(key).add(value);
|
||||
if ( ! overwrite ) cmd.add("NX");
|
||||
if ( ! create ) cmd.add("XX");
|
||||
|
||||
if ( expireTime.totalMicroseconds() > 0 )
|
||||
{
|
||||
cmd.add("PX");
|
||||
cmd.add(expireTime.totalMilliseconds());
|
||||
cmd.add("PX").add(expireTime.totalMilliseconds());
|
||||
}
|
||||
|
||||
return cmd;
|
||||
}
|
||||
|
||||
Command Command::set(const std::string& key, Int64 value, bool overwrite, const Poco::Timespan& expireTime, bool create)
|
||||
{
|
||||
return set(key, NumberFormatter::format(value), overwrite, expireTime, create);
|
||||
}
|
||||
|
||||
Command Command::rpush(const std::string& list, const std::string& value, bool create)
|
||||
{
|
||||
Command cmd(create ? "RPUSH" : "RPUSHX");
|
||||
cmd.add(list).add(value);
|
||||
|
||||
return cmd;
|
||||
}
|
||||
|
||||
Command Command::rpush(const std::string& list, const std::vector<std::string>& values, bool create)
|
||||
{
|
||||
Command cmd(create ? "RPUSH" : "RPUSHX");
|
||||
cmd.add(list);
|
||||
|
||||
for(std::vector<std::string>::const_iterator it = values.begin(); it != values.end(); ++it)
|
||||
{
|
||||
cmd.add(*it);
|
||||
}
|
||||
|
||||
return cmd;
|
||||
|
@ -80,9 +80,7 @@ void RedisTest::testAppend()
|
||||
return;
|
||||
}
|
||||
|
||||
Array delCommand;
|
||||
delCommand.add("DEL")
|
||||
.add("mykey");
|
||||
Command delCommand = Command::del("mykey");
|
||||
try
|
||||
{
|
||||
_redis.execute<Poco::Int64>(delCommand);
|
||||
@ -111,10 +109,7 @@ void RedisTest::testAppend()
|
||||
fail(e.message());
|
||||
}
|
||||
|
||||
Array appendCommand;
|
||||
appendCommand.add("APPEND")
|
||||
.add("mykey")
|
||||
.add(" World");
|
||||
Command appendCommand = Command::append("mykey", " World");
|
||||
try
|
||||
{
|
||||
Poco::Int64 result = _redis.execute<Poco::Int64>(appendCommand);
|
||||
@ -129,9 +124,7 @@ void RedisTest::testAppend()
|
||||
fail(e.message());
|
||||
}
|
||||
|
||||
Array getCommand;
|
||||
getCommand.add("GET")
|
||||
.add("mykey");
|
||||
Command getCommand = Command::get("mykey");
|
||||
try
|
||||
{
|
||||
BulkString result = _redis.execute<BulkString>(getCommand);
|
||||
@ -179,11 +172,7 @@ void RedisTest::testIncr()
|
||||
return;
|
||||
}
|
||||
|
||||
Array command;
|
||||
command.add("SET")
|
||||
.add("mykey")
|
||||
.add("10");
|
||||
|
||||
Command command = Command::set("mykey", "10");
|
||||
// A set responds with a simple OK string
|
||||
try
|
||||
{
|
||||
@ -195,10 +184,7 @@ void RedisTest::testIncr()
|
||||
fail(e.message());
|
||||
}
|
||||
|
||||
command.clear();
|
||||
command.add("INCR")
|
||||
.add("mykey");
|
||||
|
||||
command = Command::incr("mykey");
|
||||
try
|
||||
{
|
||||
Poco::Int64 value = _redis.execute<Poco::Int64>(command);
|
||||
@ -218,11 +204,7 @@ void RedisTest::testIncrBy()
|
||||
return;
|
||||
}
|
||||
|
||||
Array command;
|
||||
command.add("SET")
|
||||
.add("mykey")
|
||||
.add("10");
|
||||
|
||||
Command command = Command::set("mykey", "10");
|
||||
// A set responds with a simple OK string
|
||||
try
|
||||
{
|
||||
@ -234,11 +216,7 @@ void RedisTest::testIncrBy()
|
||||
fail(e.message());
|
||||
}
|
||||
|
||||
command.clear();
|
||||
command.add("INCRBY")
|
||||
.add("mykey")
|
||||
.add("5");
|
||||
|
||||
command = Command::incr("mykey", 5);
|
||||
try
|
||||
{
|
||||
Poco::Int64 value = _redis.execute<Poco::Int64>(command);
|
||||
@ -429,9 +407,7 @@ void RedisTest::testRPush()
|
||||
}
|
||||
|
||||
// Make sure the list is not there yet ...
|
||||
Array delCommand;
|
||||
delCommand.add("DEL")
|
||||
.add("mylist");
|
||||
Command delCommand = Command::del("mylist");
|
||||
try
|
||||
{
|
||||
_redis.execute<Poco::Int64>(delCommand);
|
||||
@ -445,48 +421,53 @@ void RedisTest::testRPush()
|
||||
fail(e.message());
|
||||
}
|
||||
|
||||
for(int i = 0; i < 2; ++i)
|
||||
{
|
||||
Array command;
|
||||
command.add("RPUSH")
|
||||
.add("mylist");
|
||||
|
||||
if ( i == 0 ) command.add("Hello");
|
||||
else command.add("World");
|
||||
|
||||
// A RPUSH responds with an integer
|
||||
try
|
||||
{
|
||||
Poco::Int64 result = _redis.execute<Poco::Int64>(command);
|
||||
assert(result == (i + 1));
|
||||
Command rpush = Command::rpush("mylist", "World");
|
||||
Poco::Int64 result = _redis.execute<Poco::Int64>(rpush);
|
||||
assert(result == 1);
|
||||
|
||||
rpush = Command::rpush("mylist", "Hello");
|
||||
result = _redis.execute<Poco::Int64>(rpush);
|
||||
assert(result == 2);
|
||||
}
|
||||
catch(RedisException &e)
|
||||
{
|
||||
fail(e.message());
|
||||
}
|
||||
}
|
||||
|
||||
Array command;
|
||||
command.add("LRANGE")
|
||||
.add("mylist")
|
||||
.add("0")
|
||||
.add("-1");
|
||||
|
||||
Command llen = Command::llen("mylist");
|
||||
try
|
||||
{
|
||||
Array result = _redis.execute<Array>(command);
|
||||
|
||||
assert(result.size() == 2);
|
||||
BulkString value = result.get<BulkString>(0);
|
||||
assert(value.value().compare("Hello") == 0);
|
||||
|
||||
value = result.get<BulkString>(1);
|
||||
assert(value.value().compare("World") == 0);
|
||||
Poco::Int64 n = _redis.execute<Poco::Int64>(llen);
|
||||
assert(n == 2);
|
||||
}
|
||||
catch(RedisException &e)
|
||||
{
|
||||
fail(e.message());
|
||||
}
|
||||
catch(Poco::BadCastException& e)
|
||||
{
|
||||
fail(e.message());
|
||||
}
|
||||
|
||||
Command lrange = Command::lrange("mylist", 0, -1);
|
||||
try
|
||||
{
|
||||
Array result = _redis.execute<Array>(lrange);
|
||||
|
||||
assert(result.size() == 2);
|
||||
assert(result.get<BulkString>(0).value().compare("World") == 0);
|
||||
assert(result.get<BulkString>(1).value().compare("Hello") == 0);
|
||||
}
|
||||
catch(RedisException &e)
|
||||
{
|
||||
fail(e.message());
|
||||
}
|
||||
catch(Poco::NullValueException &e)
|
||||
{
|
||||
fail(e.message());
|
||||
}
|
||||
}
|
||||
|
||||
void RedisTest::testLIndex()
|
||||
@ -498,9 +479,7 @@ void RedisTest::testLIndex()
|
||||
}
|
||||
|
||||
// Make sure the list is not there yet ...
|
||||
Array delCommand;
|
||||
delCommand.add("DEL")
|
||||
.add("mylist");
|
||||
Command delCommand = Command::del("mylist");
|
||||
try
|
||||
{
|
||||
_redis.execute<Poco::Int64>(delCommand);
|
||||
@ -514,20 +493,26 @@ void RedisTest::testLIndex()
|
||||
fail(e.message());
|
||||
}
|
||||
|
||||
for(int i = 0; i < 2; ++i)
|
||||
{
|
||||
Array command;
|
||||
command.add("LPUSH")
|
||||
.add("mylist");
|
||||
|
||||
if ( i == 0 ) command.add("World");
|
||||
else command.add("Hello");
|
||||
|
||||
// A RPUSH responds with an integer
|
||||
try
|
||||
{
|
||||
Poco::Int64 result = _redis.execute<Poco::Int64>(command);
|
||||
assert(result == (i + 1));
|
||||
Command lpush = Command::lpush("mylist", "World");
|
||||
Poco::Int64 result = _redis.execute<Poco::Int64>(lpush);
|
||||
assert(result == 1);
|
||||
|
||||
lpush = Command::lpush("mylist", "Hello");
|
||||
result = _redis.execute<Poco::Int64>(lpush);
|
||||
assert(result == 2);
|
||||
}
|
||||
catch(RedisException &e)
|
||||
{
|
||||
fail(e.message());
|
||||
}
|
||||
|
||||
Command lindex = Command::lindex("mylist", 0);
|
||||
try
|
||||
{
|
||||
BulkString result = _redis.execute<BulkString>(lindex);
|
||||
assert(result.value().compare("Hello") == 0);
|
||||
}
|
||||
catch(RedisException &e)
|
||||
{
|
||||
@ -535,20 +520,65 @@ void RedisTest::testLIndex()
|
||||
}
|
||||
}
|
||||
|
||||
Array command;
|
||||
command.add("LINDEX")
|
||||
.add("mylist")
|
||||
.add("0");
|
||||
void RedisTest::testLInsert()
|
||||
{
|
||||
if (!_connected)
|
||||
{
|
||||
std::cout << "Not connected, test skipped." << std::endl;
|
||||
return;
|
||||
}
|
||||
|
||||
// Make sure the list is not there yet ...
|
||||
Command delCommand = Command::del("mylist");
|
||||
try
|
||||
{
|
||||
_redis.execute<Poco::Int64>(delCommand);
|
||||
}
|
||||
catch(RedisException& e)
|
||||
{
|
||||
fail(e.message());
|
||||
}
|
||||
catch(Poco::BadCastException& e)
|
||||
{
|
||||
fail(e.message());
|
||||
}
|
||||
|
||||
try
|
||||
{
|
||||
BulkString result = _redis.execute<BulkString>(command);
|
||||
assert(result.value().compare("Hello") == 0);
|
||||
Command rpush = Command::rpush("mylist", "Hello");
|
||||
Poco::Int64 result = _redis.execute<Poco::Int64>(rpush);
|
||||
assert(result == 1);
|
||||
|
||||
rpush = Command::rpush("mylist", "World");
|
||||
result = _redis.execute<Poco::Int64>(rpush);
|
||||
assert(result == 2);
|
||||
|
||||
Command linsert = Command::linsert("mylist", true, "World", "There");
|
||||
result = _redis.execute<Poco::Int64>(linsert);
|
||||
assert(result == 3);
|
||||
|
||||
Command lrange = Command::lrange("mylist", 0, -1);
|
||||
Array range = _redis.execute<Array>(lrange);
|
||||
assert(range.size() == 3);
|
||||
|
||||
std::cout << range.toString() << std::endl;
|
||||
|
||||
assert(range.get<BulkString>(0).value().compare("Hello") == 0);
|
||||
assert(range.get<BulkString>(1).value().compare("There") == 0);
|
||||
assert(range.get<BulkString>(2).value().compare("World") == 0);
|
||||
}
|
||||
catch(RedisException &e)
|
||||
{
|
||||
fail(e.message());
|
||||
}
|
||||
catch(Poco::BadCastException &e)
|
||||
{
|
||||
fail(e.message());
|
||||
}
|
||||
catch(Poco::NullValueException &e)
|
||||
{
|
||||
fail(e.message());
|
||||
}
|
||||
}
|
||||
|
||||
void RedisTest::testMulti()
|
||||
@ -806,6 +836,7 @@ CppUnit::Test* RedisTest::suite()
|
||||
CppUnit_addTest(pSuite, RedisTest, testStrlen);
|
||||
CppUnit_addTest(pSuite, RedisTest, testRPush);
|
||||
CppUnit_addTest(pSuite, RedisTest, testLIndex);
|
||||
CppUnit_addTest(pSuite, RedisTest, testLInsert);
|
||||
CppUnit_addTest(pSuite, RedisTest, testMulti);
|
||||
|
||||
CppUnit_addTest(pSuite, RedisTest, testPubSub);
|
||||
|
@ -40,6 +40,7 @@ public:
|
||||
void testStrlen();
|
||||
void testRPush();
|
||||
void testLIndex();
|
||||
void testLInsert();
|
||||
void testMulti();
|
||||
|
||||
void testPubSub();
|
||||
|
Loading…
Reference in New Issue
Block a user