mirror of
				https://github.com/pocoproject/poco.git
				synced 2025-10-25 10:09:36 +02:00 
			
		
		
		
	Add hgetall / hincrby
This commit is contained in:
		| @@ -81,9 +81,18 @@ public: | |||||||
| 	static Command hget(const std::string& hash, const std::string& field); | 	static Command hget(const std::string& hash, const std::string& field); | ||||||
| 		/// Returns an HGET command | 		/// Returns an HGET command | ||||||
|  |  | ||||||
|  | 	static Command hgetall(const std::string& hash); | ||||||
|  | 		/// Returns an HGETALL command | ||||||
|  |  | ||||||
|  | 	static Command hincrby(const std::string& hash, const std::string& field, Int64 by = 1); | ||||||
|  | 		/// Returns an HINCRBY command | ||||||
|  |  | ||||||
| 	static Command hset(const std::string& hash, const std::string& field, const std::string& value, bool create = true); | 	static Command hset(const std::string& hash, const std::string& field, const std::string& value, bool create = true); | ||||||
| 		/// Returns an HSET or HSETNX (when create is false) command | 		/// Returns an HSET or HSETNX (when create is false) command | ||||||
|  |  | ||||||
|  | 	static Command hset(const std::string& hash, const std::string& field, Int64 value, bool create = true); | ||||||
|  | 		/// Returns an HSET or HSETNX (when create is false) command | ||||||
|  |  | ||||||
| 	static Command incr(const std::string& key, Int64 by = 0); | 	static Command incr(const std::string& key, Int64 by = 0); | ||||||
| 		/// Returns an INCR or INCRBY command. Calls INCR when by is omitted or zero. | 		/// Returns an INCR or INCRBY command. Calls INCR when by is omitted or zero. | ||||||
|  |  | ||||||
|   | |||||||
| @@ -158,6 +158,24 @@ Command Command::hget(const std::string& hash, const std::string& field) | |||||||
| 	return cmd; | 	return cmd; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | Command Command::hgetall(const std::string& hash) | ||||||
|  | { | ||||||
|  | 	Command cmd("HGETALL"); | ||||||
|  |  | ||||||
|  | 	cmd << hash; | ||||||
|  |  | ||||||
|  | 	return cmd; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | Command Command::hincrby(const std::string& hash, const std::string& field, Int64 by) | ||||||
|  | { | ||||||
|  | 	Command cmd("HINCRBY"); | ||||||
|  |  | ||||||
|  | 	cmd << hash << field << NumberFormatter::format(by); | ||||||
|  |  | ||||||
|  | 	return cmd; | ||||||
|  | } | ||||||
|  |  | ||||||
| Command Command::hset(const std::string& hash, const std::string& field, const std::string& value, bool create) | Command Command::hset(const std::string& hash, const std::string& field, const std::string& value, bool create) | ||||||
| { | { | ||||||
| 	Command cmd(create ? "HSET" : "HSETNX"); | 	Command cmd(create ? "HSET" : "HSETNX"); | ||||||
| @@ -167,6 +185,11 @@ Command Command::hset(const std::string& hash, const std::string& field, const s | |||||||
| 	return cmd; | 	return cmd; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | Command Command::hset(const std::string& hash, const std::string& field, Int64 value, bool create) | ||||||
|  | { | ||||||
|  | 	return hset(hash, field, NumberFormatter::format(value), create); | ||||||
|  | } | ||||||
|  |  | ||||||
| Command Command::incr(const std::string& key, Int64 by) | Command Command::incr(const std::string& key, Int64 by) | ||||||
| { | { | ||||||
| 	Command cmd(by == 0 ? "INCR" : "INCRBY"); | 	Command cmd(by == 0 ? "INCR" : "INCRBY"); | ||||||
|   | |||||||
| @@ -462,6 +462,105 @@ void RedisTest::testHEXISTS() | |||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
|  | void RedisTest::testHGETALL() | ||||||
|  | { | ||||||
|  | 	if (!_connected) | ||||||
|  | 	{ | ||||||
|  | 		std::cout << "Not connected, test skipped." << std::endl; | ||||||
|  | 		return; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	delKey("myhash"); | ||||||
|  |  | ||||||
|  | 	Command hset = Command::hset("myhash", "field1", "Hello"); | ||||||
|  | 	try | ||||||
|  | 	{ | ||||||
|  | 		Poco::Int64 value = _redis.execute<Poco::Int64>(hset); | ||||||
|  | 		assert(value == 1); | ||||||
|  | 	} | ||||||
|  | 	catch(RedisException &e) | ||||||
|  | 	{ | ||||||
|  | 		fail(e.message()); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	hset = Command::hset("myhash", "field2", "World"); | ||||||
|  | 	try | ||||||
|  | 	{ | ||||||
|  | 		Poco::Int64 value = _redis.execute<Poco::Int64>(hset); | ||||||
|  | 		assert(value == 1); | ||||||
|  | 	} | ||||||
|  | 	catch(RedisException &e) | ||||||
|  | 	{ | ||||||
|  | 		fail(e.message()); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	Command hgetall = Command::hgetall("myhash"); | ||||||
|  | 	try | ||||||
|  | 	{ | ||||||
|  | 		Array result = _redis.execute<Array>(hgetall); | ||||||
|  | 		assert(result.size() == 4); | ||||||
|  | 	} | ||||||
|  | 	catch(RedisException &e) | ||||||
|  | 	{ | ||||||
|  | 		fail(e.message()); | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  |  | ||||||
|  | void RedisTest::testHINCRBY() | ||||||
|  | { | ||||||
|  | 	if (!_connected) | ||||||
|  | 	{ | ||||||
|  | 		std::cout << "Not connected, test skipped." << std::endl; | ||||||
|  | 		return; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	delKey("myhash"); | ||||||
|  |  | ||||||
|  | 	Command hset = Command::hset("myhash", "field", 5); | ||||||
|  | 	try | ||||||
|  | 	{ | ||||||
|  | 		Poco::Int64 value = _redis.execute<Poco::Int64>(hset); | ||||||
|  | 		assert(value == 1); | ||||||
|  | 	} | ||||||
|  | 	catch(RedisException &e) | ||||||
|  | 	{ | ||||||
|  | 		fail(e.message()); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	Command hincrby = Command::hincrby("myhash", "field"); | ||||||
|  | 	try | ||||||
|  | 	{ | ||||||
|  | 		Poco::Int64 n = _redis.execute<Poco::Int64>(hincrby); | ||||||
|  | 		assert(n == 6); | ||||||
|  | 	} | ||||||
|  | 	catch(RedisException &e) | ||||||
|  | 	{ | ||||||
|  | 		fail(e.message()); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	hincrby = Command::hincrby("myhash", "field", -1); | ||||||
|  | 	try | ||||||
|  | 	{ | ||||||
|  | 		Poco::Int64 n = _redis.execute<Poco::Int64>(hincrby); | ||||||
|  | 		assert(n == 5); | ||||||
|  | 	} | ||||||
|  | 	catch(RedisException &e) | ||||||
|  | 	{ | ||||||
|  | 		fail(e.message()); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	hincrby = Command::hincrby("myhash", "field", -10); | ||||||
|  | 	try | ||||||
|  | 	{ | ||||||
|  | 		Poco::Int64 n = _redis.execute<Poco::Int64>(hincrby); | ||||||
|  | 		assert(n == -5); | ||||||
|  | 	} | ||||||
|  | 	catch(RedisException &e) | ||||||
|  | 	{ | ||||||
|  | 		fail(e.message()); | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  |  | ||||||
| void RedisTest::testHSET() | void RedisTest::testHSET() | ||||||
| { | { | ||||||
| 	if (!_connected) | 	if (!_connected) | ||||||
| @@ -2528,6 +2627,8 @@ CppUnit::Test* RedisTest::suite() | |||||||
| 	CppUnit_addTest(pSuite, RedisTest, testEVAL); | 	CppUnit_addTest(pSuite, RedisTest, testEVAL); | ||||||
| 	CppUnit_addTest(pSuite, RedisTest, testHDEL); | 	CppUnit_addTest(pSuite, RedisTest, testHDEL); | ||||||
| 	CppUnit_addTest(pSuite, RedisTest, testHEXISTS); | 	CppUnit_addTest(pSuite, RedisTest, testHEXISTS); | ||||||
|  | 	CppUnit_addTest(pSuite, RedisTest, testHGETALL); | ||||||
|  | 	CppUnit_addTest(pSuite, RedisTest, testHINCRBY); | ||||||
| 	CppUnit_addTest(pSuite, RedisTest, testHSET); | 	CppUnit_addTest(pSuite, RedisTest, testHSET); | ||||||
| 	CppUnit_addTest(pSuite, RedisTest, testINCR); | 	CppUnit_addTest(pSuite, RedisTest, testINCR); | ||||||
| 	CppUnit_addTest(pSuite, RedisTest, testINCRBY); | 	CppUnit_addTest(pSuite, RedisTest, testINCRBY); | ||||||
|   | |||||||
| @@ -39,6 +39,8 @@ public: | |||||||
| 	void testEVAL(); | 	void testEVAL(); | ||||||
| 	void testHDEL(); | 	void testHDEL(); | ||||||
| 	void testHEXISTS(); | 	void testHEXISTS(); | ||||||
|  | 	void testHGETALL(); | ||||||
|  | 	void testHINCRBY(); | ||||||
| 	void testHSET(); | 	void testHSET(); | ||||||
| 	void testINCR(); | 	void testINCR(); | ||||||
| 	void testINCRBY(); | 	void testINCRBY(); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 fbraem
					fbraem