From e5977661e253fdeca74891ccf6b8fe63e1423c1f Mon Sep 17 00:00:00 2001 From: M Sazzadul Hoque <7600764+sazzad16@users.noreply.github.com> Date: Thu, 6 Jun 2024 20:39:03 +0600 Subject: [PATCH 1/4] Support Hash field expiration (#3826) * Support Hash field expiration (Strings) * Support Hash field expiration (byte[]s) * Test new hash commands in CommandObjects * Hash expiration is now supported with listpack * Address constant FIELDS argument in Hash field expiration commands * Fix FIELDS place * Back to using Redis unstable branch * Modify HFE tests due to changes in server --- .../redis/clients/jedis/CommandObjects.java | 138 +++++- src/main/java/redis/clients/jedis/Jedis.java | 156 +++++++ .../redis/clients/jedis/PipeliningBase.java | 130 ++++++ .../java/redis/clients/jedis/Protocol.java | 5 +- .../redis/clients/jedis/UnifiedJedis.java | 130 ++++++ .../jedis/commands/HashBinaryCommands.java | 134 ++++++ .../clients/jedis/commands/HashCommands.java | 135 ++++++ .../commands/HashPipelineBinaryCommands.java | 26 ++ .../jedis/commands/HashPipelineCommands.java | 27 ++ .../CommandObjectsHashCommandsTest.java | 170 +++++++ .../commands/jedis/HashesCommandsTest.java | 168 +++++++ .../unified/HashesCommandsTestBase.java | 168 +++++++ .../PipeliningBaseHashCommandsTest.java | 319 +++++++++++++ .../unified/UnifiedJedisHashCommandsTest.java | 423 ++++++++++++++++++ 14 files changed, 2123 insertions(+), 6 deletions(-) diff --git a/src/main/java/redis/clients/jedis/CommandObjects.java b/src/main/java/redis/clients/jedis/CommandObjects.java index 896ef38293..754c25cf35 100644 --- a/src/main/java/redis/clients/jedis/CommandObjects.java +++ b/src/main/java/redis/clients/jedis/CommandObjects.java @@ -1140,10 +1140,6 @@ public final CommandObject> hscanNoValues(String key, String return new CommandObject<>(commandArguments(HSCAN).key(key).add(cursor).addParams(params).add(NOVALUES), BuilderFactory.SCAN_RESPONSE); } - public final CommandObject hstrlen(String key, String field) { - return new CommandObject<>(commandArguments(HSTRLEN).key(key).add(field), BuilderFactory.LONG); - } - public final CommandObject>> hscan(byte[] key, byte[] cursor, ScanParams params) { return new CommandObject<>(commandArguments(HSCAN).key(key).add(cursor).addParams(params), BuilderFactory.HSCAN_BINARY_RESPONSE); } @@ -1152,9 +1148,143 @@ public final CommandObject> hscanNoValues(byte[] key, byte[] return new CommandObject<>(commandArguments(HSCAN).key(key).add(cursor).addParams(params).add(NOVALUES), BuilderFactory.SCAN_BINARY_RESPONSE); } + public final CommandObject hstrlen(String key, String field) { + return new CommandObject<>(commandArguments(HSTRLEN).key(key).add(field), BuilderFactory.LONG); + } + public final CommandObject hstrlen(byte[] key, byte[] field) { return new CommandObject<>(commandArguments(HSTRLEN).key(key).add(field), BuilderFactory.LONG); } + + public final CommandObject> hexpire(String key, long seconds, String... fields) { + return new CommandObject<>(commandArguments(HEXPIRE).key(key).add(seconds) + .add(FIELDS).add(fields.length).addObjects((Object[]) fields), BuilderFactory.LONG_LIST); + } + + public final CommandObject> hexpire(String key, long seconds, ExpiryOption condition, String... fields) { + return new CommandObject<>(commandArguments(HEXPIRE).key(key).add(seconds).add(condition) + .add(FIELDS).add(fields.length).addObjects((Object[]) fields), BuilderFactory.LONG_LIST); + } + + public final CommandObject> hpexpire(String key, long milliseconds, String... fields) { + return new CommandObject<>(commandArguments(HPEXPIRE).key(key).add(milliseconds) + .add(FIELDS).add(fields.length).addObjects((Object[]) fields), BuilderFactory.LONG_LIST); + } + + public final CommandObject> hpexpire(String key, long milliseconds, ExpiryOption condition, String... fields) { + return new CommandObject<>(commandArguments(HPEXPIRE).key(key).add(milliseconds).add(condition) + .add(FIELDS).add(fields.length).addObjects((Object[]) fields), BuilderFactory.LONG_LIST); + } + + public final CommandObject> hexpireAt(String key, long unixTimeSeconds, String... fields) { + return new CommandObject<>(commandArguments(HEXPIREAT).key(key).add(unixTimeSeconds) + .add(FIELDS).add(fields.length).addObjects((Object[]) fields), BuilderFactory.LONG_LIST); + } + + public final CommandObject> hexpireAt(String key, long unixTimeSeconds, ExpiryOption condition, String... fields) { + return new CommandObject<>(commandArguments(HEXPIREAT).key(key).add(unixTimeSeconds).add(condition) + .add(FIELDS).add(fields.length).addObjects((Object[]) fields), BuilderFactory.LONG_LIST); + } + + public final CommandObject> hpexpireAt(String key, long unixTimeMillis, String... fields) { + return new CommandObject<>(commandArguments(HPEXPIREAT).key(key).add(unixTimeMillis) + .add(FIELDS).add(fields.length).addObjects((Object[]) fields), BuilderFactory.LONG_LIST); + } + + public final CommandObject> hpexpireAt(String key, long unixTimeMillis, ExpiryOption condition, String... fields) { + return new CommandObject<>(commandArguments(HPEXPIREAT).key(key).add(unixTimeMillis).add(condition) + .add(FIELDS).add(fields.length).addObjects((Object[]) fields), BuilderFactory.LONG_LIST); + } + + public final CommandObject> hexpire(byte[] key, long seconds, byte[]... fields) { + return new CommandObject<>(commandArguments(HEXPIRE).key(key).add(seconds) + .add(FIELDS).add(fields.length).addObjects((Object[]) fields), BuilderFactory.LONG_LIST); + } + + public final CommandObject> hexpire(byte[] key, long seconds, ExpiryOption condition, byte[]... fields) { + return new CommandObject<>(commandArguments(HEXPIRE).key(key).add(seconds).add(condition) + .add(FIELDS).add(fields.length).addObjects((Object[]) fields), BuilderFactory.LONG_LIST); + } + + public final CommandObject> hpexpire(byte[] key, long milliseconds, byte[]... fields) { + return new CommandObject<>(commandArguments(HPEXPIRE).key(key).add(milliseconds) + .add(FIELDS).add(fields.length).addObjects((Object[]) fields), BuilderFactory.LONG_LIST); + } + + public final CommandObject> hpexpire(byte[] key, long milliseconds, ExpiryOption condition, byte[]... fields) { + return new CommandObject<>(commandArguments(HPEXPIRE).key(key).add(milliseconds).add(condition) + .add(FIELDS).add(fields.length).addObjects((Object[]) fields), BuilderFactory.LONG_LIST); + } + + public final CommandObject> hexpireAt(byte[] key, long unixTimeSeconds, byte[]... fields) { + return new CommandObject<>(commandArguments(HEXPIREAT).key(key).add(unixTimeSeconds) + .add(FIELDS).add(fields.length).addObjects((Object[]) fields), BuilderFactory.LONG_LIST); + } + + public final CommandObject> hexpireAt(byte[] key, long unixTimeSeconds, ExpiryOption condition, byte[]... fields) { + return new CommandObject<>(commandArguments(HEXPIREAT).key(key).add(unixTimeSeconds).add(condition) + .add(FIELDS).add(fields.length).addObjects((Object[]) fields), BuilderFactory.LONG_LIST); + } + + public final CommandObject> hpexpireAt(byte[] key, long unixTimeMillis, byte[]... fields) { + return new CommandObject<>(commandArguments(HPEXPIREAT).key(key).add(unixTimeMillis) + .add(FIELDS).add(fields.length).addObjects((Object[]) fields), BuilderFactory.LONG_LIST); + } + + public final CommandObject> hpexpireAt(byte[] key, long unixTimeMillis, ExpiryOption condition, byte[]... fields) { + return new CommandObject<>(commandArguments(HPEXPIREAT).key(key).add(unixTimeMillis).add(condition) + .add(FIELDS).add(fields.length).addObjects((Object[]) fields), BuilderFactory.LONG_LIST); + } + + public final CommandObject> hexpireTime(String key, String... fields) { + return new CommandObject<>(commandArguments(HEXPIRETIME).key(key) + .add(FIELDS).add(fields.length).addObjects((Object[]) fields), BuilderFactory.LONG_LIST); + } + + public final CommandObject> hpexpireTime(String key, String... fields) { + return new CommandObject<>(commandArguments(HPEXPIRETIME).key(key) + .add(FIELDS).add(fields.length).addObjects((Object[]) fields), BuilderFactory.LONG_LIST); + } + + public final CommandObject> httl(String key, String... fields) { + return new CommandObject<>(commandArguments(HTTL).key(key) + .add(FIELDS).add(fields.length).addObjects((Object[]) fields), BuilderFactory.LONG_LIST); + } + + public final CommandObject> hpttl(String key, String... fields) { + return new CommandObject<>(commandArguments(HPTTL).key(key) + .add(FIELDS).add(fields.length).addObjects((Object[]) fields), BuilderFactory.LONG_LIST); + } + + public final CommandObject> hexpireTime(byte[] key, byte[]... fields) { + return new CommandObject<>(commandArguments(HEXPIRETIME).key(key) + .add(FIELDS).add(fields.length).addObjects((Object[]) fields), BuilderFactory.LONG_LIST); + } + + public final CommandObject> hpexpireTime(byte[] key, byte[]... fields) { + return new CommandObject<>(commandArguments(HPEXPIRETIME).key(key) + .add(FIELDS).add(fields.length).addObjects((Object[]) fields), BuilderFactory.LONG_LIST); + } + + public final CommandObject> httl(byte[] key, byte[]... fields) { + return new CommandObject<>(commandArguments(HTTL).key(key) + .add(FIELDS).add(fields.length).addObjects((Object[]) fields), BuilderFactory.LONG_LIST); + } + + public final CommandObject> hpttl(byte[] key, byte[]... fields) { + return new CommandObject<>(commandArguments(HPTTL).key(key) + .add(FIELDS).add(fields.length).addObjects((Object[]) fields), BuilderFactory.LONG_LIST); + } + + public final CommandObject> hpersist(String key, String... fields) { + return new CommandObject<>(commandArguments(HPERSIST).key(key) + .add(FIELDS).add(fields.length).addObjects((Object[]) fields), BuilderFactory.LONG_LIST); + } + + public final CommandObject> hpersist(byte[] key, byte[]... fields) { + return new CommandObject<>(commandArguments(HPERSIST).key(key) + .add(FIELDS).add(fields.length).addObjects((Object[]) fields), BuilderFactory.LONG_LIST); + } // Hash commands // Set commands diff --git a/src/main/java/redis/clients/jedis/Jedis.java b/src/main/java/redis/clients/jedis/Jedis.java index 03a2bc1ed1..66d64fa6eb 100644 --- a/src/main/java/redis/clients/jedis/Jedis.java +++ b/src/main/java/redis/clients/jedis/Jedis.java @@ -4656,6 +4656,84 @@ public long hstrlen(final byte[] key, final byte[] field) { return connection.executeCommand(commandObjects.hstrlen(key, field)); } + @Override + public List hexpire(byte[] key, long seconds, byte[]... fields) { + checkIsInMultiOrPipeline(); + return connection.executeCommand(commandObjects.hexpire(key, seconds, fields)); + } + + @Override + public List hexpire(byte[] key, long seconds, ExpiryOption condition, byte[]... fields) { + checkIsInMultiOrPipeline(); + return connection.executeCommand(commandObjects.hexpire(key, seconds, condition, fields)); + } + + @Override + public List hpexpire(byte[] key, long milliseconds, byte[]... fields) { + checkIsInMultiOrPipeline(); + return connection.executeCommand(commandObjects.hpexpire(key, milliseconds, fields)); + } + + @Override + public List hpexpire(byte[] key, long milliseconds, ExpiryOption condition, byte[]... fields) { + checkIsInMultiOrPipeline(); + return connection.executeCommand(commandObjects.hpexpire(key, milliseconds, condition, fields)); + } + + @Override + public List hexpireAt(byte[] key, long unixTimeSeconds, byte[]... fields) { + checkIsInMultiOrPipeline(); + return connection.executeCommand(commandObjects.hexpireAt(key, unixTimeSeconds, fields)); + } + + @Override + public List hexpireAt(byte[] key, long unixTimeSeconds, ExpiryOption condition, byte[]... fields) { + checkIsInMultiOrPipeline(); + return connection.executeCommand(commandObjects.hexpireAt(key, unixTimeSeconds, condition, fields)); + } + + @Override + public List hpexpireAt(byte[] key, long unixTimeMillis, byte[]... fields) { + checkIsInMultiOrPipeline(); + return connection.executeCommand(commandObjects.hpexpireAt(key, unixTimeMillis, fields)); + } + + @Override + public List hpexpireAt(byte[] key, long unixTimeMillis, ExpiryOption condition, byte[]... fields) { + checkIsInMultiOrPipeline(); + return connection.executeCommand(commandObjects.hpexpireAt(key, unixTimeMillis, condition, fields)); + } + + @Override + public List hexpireTime(byte[] key, byte[]... fields) { + checkIsInMultiOrPipeline(); + return connection.executeCommand(commandObjects.hexpireTime(key, fields)); + } + + @Override + public List hpexpireTime(byte[] key, byte[]... fields) { + checkIsInMultiOrPipeline(); + return connection.executeCommand(commandObjects.hpexpireTime(key, fields)); + } + + @Override + public List httl(byte[] key, byte[]... fields) { + checkIsInMultiOrPipeline(); + return connection.executeCommand(commandObjects.httl(key, fields)); + } + + @Override + public List hpttl(byte[] key, byte[]... fields) { + checkIsInMultiOrPipeline(); + return connection.executeCommand(commandObjects.hpttl(key, fields)); + } + + @Override + public List hpersist(byte[] key, byte[]... fields) { + checkIsInMultiOrPipeline(); + return connection.executeCommand(commandObjects.hpersist(key, fields)); + } + @Override public List xread(XReadParams xReadParams, Entry... streams) { checkIsInMultiOrPipeline(); @@ -9237,6 +9315,84 @@ public long hstrlen(final String key, final String field) { return connection.executeCommand(commandObjects.hstrlen(key, field)); } + @Override + public List hexpire(String key, long seconds, String... fields) { + checkIsInMultiOrPipeline(); + return connection.executeCommand(commandObjects.hexpire(key, seconds, fields)); + } + + @Override + public List hexpire(String key, long seconds, ExpiryOption condition, String... fields) { + checkIsInMultiOrPipeline(); + return connection.executeCommand(commandObjects.hexpire(key, seconds, condition, fields)); + } + + @Override + public List hpexpire(String key, long milliseconds, String... fields) { + checkIsInMultiOrPipeline(); + return connection.executeCommand(commandObjects.hpexpire(key, milliseconds, fields)); + } + + @Override + public List hpexpire(String key, long milliseconds, ExpiryOption condition, String... fields) { + checkIsInMultiOrPipeline(); + return connection.executeCommand(commandObjects.hpexpire(key, milliseconds, condition, fields)); + } + + @Override + public List hexpireAt(String key, long unixTimeSeconds, String... fields) { + checkIsInMultiOrPipeline(); + return connection.executeCommand(commandObjects.hexpireAt(key, unixTimeSeconds, fields)); + } + + @Override + public List hexpireAt(String key, long unixTimeSeconds, ExpiryOption condition, String... fields) { + checkIsInMultiOrPipeline(); + return connection.executeCommand(commandObjects.hexpireAt(key, unixTimeSeconds, condition, fields)); + } + + @Override + public List hpexpireAt(String key, long unixTimeMillis, String... fields) { + checkIsInMultiOrPipeline(); + return connection.executeCommand(commandObjects.hpexpireAt(key, unixTimeMillis, fields)); + } + + @Override + public List hpexpireAt(String key, long unixTimeMillis, ExpiryOption condition, String... fields) { + checkIsInMultiOrPipeline(); + return connection.executeCommand(commandObjects.hpexpireAt(key, unixTimeMillis, condition, fields)); + } + + @Override + public List hexpireTime(String key, String... fields) { + checkIsInMultiOrPipeline(); + return connection.executeCommand(commandObjects.hexpireTime(key, fields)); + } + + @Override + public List hpexpireTime(String key, String... fields) { + checkIsInMultiOrPipeline(); + return connection.executeCommand(commandObjects.hpexpireTime(key, fields)); + } + + @Override + public List httl(String key, String... fields) { + checkIsInMultiOrPipeline(); + return connection.executeCommand(commandObjects.httl(key, fields)); + } + + @Override + public List hpttl(String key, String... fields) { + checkIsInMultiOrPipeline(); + return connection.executeCommand(commandObjects.hpttl(key, fields)); + } + + @Override + public List hpersist(String key, String... fields) { + checkIsInMultiOrPipeline(); + return connection.executeCommand(commandObjects.hpersist(key, fields)); + } + @Override public String memoryDoctor() { checkIsInMultiOrPipeline(); diff --git a/src/main/java/redis/clients/jedis/PipeliningBase.java b/src/main/java/redis/clients/jedis/PipeliningBase.java index 2dac5af712..928126a704 100644 --- a/src/main/java/redis/clients/jedis/PipeliningBase.java +++ b/src/main/java/redis/clients/jedis/PipeliningBase.java @@ -725,6 +725,71 @@ public Response hstrlen(String key, String field) { return appendCommand(commandObjects.hstrlen(key, field)); } + @Override + public Response> hexpire(String key, long seconds, String... fields) { + return appendCommand(commandObjects.hexpire(key, seconds, fields)); + } + + @Override + public Response> hexpire(String key, long seconds, ExpiryOption condition, String... fields) { + return appendCommand(commandObjects.hexpire(key, seconds, condition, fields)); + } + + @Override + public Response> hpexpire(String key, long milliseconds, String... fields) { + return appendCommand(commandObjects.hpexpire(key, milliseconds, fields)); + } + + @Override + public Response> hpexpire(String key, long milliseconds, ExpiryOption condition, String... fields) { + return appendCommand(commandObjects.hpexpire(key, milliseconds, condition, fields)); + } + + @Override + public Response> hexpireAt(String key, long unixTimeSeconds, String... fields) { + return appendCommand(commandObjects.hexpireAt(key, unixTimeSeconds, fields)); + } + + @Override + public Response> hexpireAt(String key, long unixTimeSeconds, ExpiryOption condition, String... fields) { + return appendCommand(commandObjects.hexpireAt(key, unixTimeSeconds, condition, fields)); + } + + @Override + public Response> hpexpireAt(String key, long unixTimeMillis, String... fields) { + return appendCommand(commandObjects.hpexpireAt(key, unixTimeMillis, fields)); + } + + @Override + public Response> hpexpireAt(String key, long unixTimeMillis, ExpiryOption condition, String... fields) { + return appendCommand(commandObjects.hpexpireAt(key, unixTimeMillis, condition, fields)); + } + + @Override + public Response> hexpireTime(String key, String... fields) { + return appendCommand(commandObjects.hexpireTime(key, fields)); + } + + @Override + public Response> hpexpireTime(String key, String... fields) { + return appendCommand(commandObjects.hpexpireTime(key, fields)); + } + + @Override + public Response> httl(String key, String... fields) { + return appendCommand(commandObjects.httl(key, fields)); + } + + @Override + public Response> hpttl(String key, String... fields) { + return appendCommand(commandObjects.hpttl(key, fields)); + } + + @Override + public Response> hpersist(String key, String... fields) { + return appendCommand(commandObjects.hpersist(key, fields)); + } + @Override public Response sadd(String key, String... members) { return appendCommand(commandObjects.sadd(key, members)); @@ -2006,6 +2071,71 @@ public Response hstrlen(byte[] key, byte[] field) { return appendCommand(commandObjects.hstrlen(key, field)); } + @Override + public Response> hexpire(byte[] key, long seconds, byte[]... fields) { + return appendCommand(commandObjects.hexpire(key, seconds, fields)); + } + + @Override + public Response> hexpire(byte[] key, long seconds, ExpiryOption condition, byte[]... fields) { + return appendCommand(commandObjects.hexpire(key, seconds, condition, fields)); + } + + @Override + public Response> hpexpire(byte[] key, long milliseconds, byte[]... fields) { + return appendCommand(commandObjects.hpexpire(key, milliseconds, fields)); + } + + @Override + public Response> hpexpire(byte[] key, long milliseconds, ExpiryOption condition, byte[]... fields) { + return appendCommand(commandObjects.hpexpire(key, milliseconds, condition, fields)); + } + + @Override + public Response> hexpireAt(byte[] key, long unixTimeSeconds, byte[]... fields) { + return appendCommand(commandObjects.hexpireAt(key, unixTimeSeconds, fields)); + } + + @Override + public Response> hexpireAt(byte[] key, long unixTimeSeconds, ExpiryOption condition, byte[]... fields) { + return appendCommand(commandObjects.hexpireAt(key, unixTimeSeconds, condition, fields)); + } + + @Override + public Response> hpexpireAt(byte[] key, long unixTimeMillis, byte[]... fields) { + return appendCommand(commandObjects.hpexpireAt(key, unixTimeMillis, fields)); + } + + @Override + public Response> hpexpireAt(byte[] key, long unixTimeMillis, ExpiryOption condition, byte[]... fields) { + return appendCommand(commandObjects.hpexpireAt(key, unixTimeMillis, condition, fields)); + } + + @Override + public Response> hexpireTime(byte[] key, byte[]... fields) { + return appendCommand(commandObjects.hexpireTime(key, fields)); + } + + @Override + public Response> hpexpireTime(byte[] key, byte[]... fields) { + return appendCommand(commandObjects.hpexpireTime(key, fields)); + } + + @Override + public Response> httl(byte[] key, byte[]... fields) { + return appendCommand(commandObjects.httl(key, fields)); + } + + @Override + public Response> hpttl(byte[] key, byte[]... fields) { + return appendCommand(commandObjects.hpttl(key, fields)); + } + + @Override + public Response> hpersist(byte[] key, byte[]... fields) { + return appendCommand(commandObjects.hpersist(key, fields)); + } + @Override public Response pfadd(byte[] key, byte[]... elements) { return appendCommand(commandObjects.pfadd(key, elements)); diff --git a/src/main/java/redis/clients/jedis/Protocol.java b/src/main/java/redis/clients/jedis/Protocol.java index 531ee768c9..448bd7ff12 100644 --- a/src/main/java/redis/clients/jedis/Protocol.java +++ b/src/main/java/redis/clients/jedis/Protocol.java @@ -254,6 +254,7 @@ public static enum Command implements ProtocolCommand { STRLEN, APPEND, SUBSTR, // <-- string SETBIT, GETBIT, BITPOS, SETRANGE, GETRANGE, BITCOUNT, BITOP, BITFIELD, BITFIELD_RO, // <-- bit (string) HSET, HGET, HSETNX, HMSET, HMGET, HINCRBY, HEXISTS, HDEL, HLEN, HKEYS, HVALS, HGETALL, HSTRLEN, + HEXPIRE, HPEXPIRE, HEXPIREAT, HPEXPIREAT, HTTL, HPTTL, HEXPIRETIME, HPEXPIRETIME, HPERSIST, HRANDFIELD, HINCRBYFLOAT, // <-- hash RPUSH, LPUSH, LLEN, LRANGE, LTRIM, LINDEX, LSET, LREM, LPOP, RPOP, BLPOP, BRPOP, LINSERT, LPOS, RPOPLPUSH, BRPOPLPUSH, BLMOVE, LMOVE, LMPOP, BLMPOP, LPUSHX, RPUSHX, // <-- list @@ -299,8 +300,8 @@ public static enum Keyword implements Rawable { REV, WITHCOORD, WITHDIST, WITHHASH, ANY, FROMMEMBER, FROMLONLAT, BYRADIUS, BYBOX, BYLEX, BYSCORE, STOREDIST, TO, FORCE, TIMEOUT, DB, UNLOAD, ABORT, IDX, MINMATCHLEN, WITHMATCHLEN, FULL, DELETE, LIBRARYNAME, WITHCODE, DESCRIPTION, GETKEYS, GETKEYSANDFLAGS, DOCS, FILTERBY, DUMP, - MODULE, ACLCAT, PATTERN, DOCTOR, LATEST, HISTORY, USAGE, SAMPLES, PURGE, STATS, LOADEX, CONFIG, ARGS, RANK, - NOW, VERSION, ADDR, SKIPME, USER, LADDR, + MODULE, ACLCAT, PATTERN, DOCTOR, LATEST, HISTORY, USAGE, SAMPLES, PURGE, STATS, LOADEX, CONFIG, + ARGS, RANK, NOW, VERSION, ADDR, SKIPME, USER, LADDR, FIELDS, CHANNELS, NUMPAT, NUMSUB, SHARDCHANNELS, SHARDNUMSUB, NOVALUES, MAXAGE; private final byte[] raw; diff --git a/src/main/java/redis/clients/jedis/UnifiedJedis.java b/src/main/java/redis/clients/jedis/UnifiedJedis.java index 452798d303..2d6e77fcf0 100644 --- a/src/main/java/redis/clients/jedis/UnifiedJedis.java +++ b/src/main/java/redis/clients/jedis/UnifiedJedis.java @@ -1600,6 +1600,136 @@ public ScanResult hscanNoValues(byte[] key, byte[] cursor, ScanParams pa public long hstrlen(byte[] key, byte[] field) { return executeCommand(commandObjects.hstrlen(key, field)); } + + @Override + public List hexpire(String key, long seconds, String... fields) { + return executeCommand(commandObjects.hexpire(key, seconds, fields)); + } + + @Override + public List hexpire(String key, long seconds, ExpiryOption condition, String... fields) { + return executeCommand(commandObjects.hexpire(key, seconds, condition, fields)); + } + + @Override + public List hpexpire(String key, long milliseconds, String... fields) { + return executeCommand(commandObjects.hpexpire(key, milliseconds, fields)); + } + + @Override + public List hpexpire(String key, long milliseconds, ExpiryOption condition, String... fields) { + return executeCommand(commandObjects.hpexpire(key, milliseconds, condition, fields)); + } + + @Override + public List hexpireAt(String key, long unixTimeSeconds, String... fields) { + return executeCommand(commandObjects.hexpireAt(key, unixTimeSeconds, fields)); + } + + @Override + public List hexpireAt(String key, long unixTimeSeconds, ExpiryOption condition, String... fields) { + return executeCommand(commandObjects.hexpireAt(key, unixTimeSeconds, condition, fields)); + } + + @Override + public List hpexpireAt(String key, long unixTimeMillis, String... fields) { + return executeCommand(commandObjects.hpexpireAt(key, unixTimeMillis, fields)); + } + + @Override + public List hpexpireAt(String key, long unixTimeMillis, ExpiryOption condition, String... fields) { + return executeCommand(commandObjects.hpexpireAt(key, unixTimeMillis, condition, fields)); + } + + @Override + public List hexpire(byte[] key, long seconds, byte[]... fields) { + return executeCommand(commandObjects.hexpire(key, seconds, fields)); + } + + @Override + public List hexpire(byte[] key, long seconds, ExpiryOption condition, byte[]... fields) { + return executeCommand(commandObjects.hexpire(key, seconds, condition, fields)); + } + + @Override + public List hpexpire(byte[] key, long milliseconds, byte[]... fields) { + return executeCommand(commandObjects.hpexpire(key, milliseconds, fields)); + } + + @Override + public List hpexpire(byte[] key, long milliseconds, ExpiryOption condition, byte[]... fields) { + return executeCommand(commandObjects.hpexpire(key, milliseconds, condition, fields)); + } + + @Override + public List hexpireAt(byte[] key, long unixTimeSeconds, byte[]... fields) { + return executeCommand(commandObjects.hexpireAt(key, unixTimeSeconds, fields)); + } + + @Override + public List hexpireAt(byte[] key, long unixTimeSeconds, ExpiryOption condition, byte[]... fields) { + return executeCommand(commandObjects.hexpireAt(key, unixTimeSeconds, condition, fields)); + } + + @Override + public List hpexpireAt(byte[] key, long unixTimeMillis, byte[]... fields) { + return executeCommand(commandObjects.hpexpireAt(key, unixTimeMillis, fields)); + } + + @Override + public List hpexpireAt(byte[] key, long unixTimeMillis, ExpiryOption condition, byte[]... fields) { + return executeCommand(commandObjects.hpexpireAt(key, unixTimeMillis, condition, fields)); + } + + @Override + public List hexpireTime(String key, String... fields) { + return executeCommand(commandObjects.hexpireTime(key, fields)); + } + + @Override + public List hpexpireTime(String key, String... fields) { + return executeCommand(commandObjects.hpexpireTime(key, fields)); + } + + @Override + public List httl(String key, String... fields) { + return executeCommand(commandObjects.httl(key, fields)); + } + + @Override + public List hpttl(String key, String... fields) { + return executeCommand(commandObjects.hpttl(key, fields)); + } + + @Override + public List hexpireTime(byte[] key, byte[]... fields) { + return executeCommand(commandObjects.hexpireTime(key, fields)); + } + + @Override + public List hpexpireTime(byte[] key, byte[]... fields) { + return executeCommand(commandObjects.hpexpireTime(key, fields)); + } + + @Override + public List httl(byte[] key, byte[]... fields) { + return executeCommand(commandObjects.httl(key, fields)); + } + + @Override + public List hpttl(byte[] key, byte[]... fields) { + return executeCommand(commandObjects.hpttl(key, fields)); + } + + @Override + public List hpersist(String key, String... fields) { + return executeCommand(commandObjects.hpersist(key, fields)); + } + + @Override + public List hpersist(byte[] key, byte[]... fields) { + return executeCommand(commandObjects.hpersist(key, fields)); + } // Hash commands // Set commands diff --git a/src/main/java/redis/clients/jedis/commands/HashBinaryCommands.java b/src/main/java/redis/clients/jedis/commands/HashBinaryCommands.java index 15a462c9b7..f32eca202e 100644 --- a/src/main/java/redis/clients/jedis/commands/HashBinaryCommands.java +++ b/src/main/java/redis/clients/jedis/commands/HashBinaryCommands.java @@ -4,6 +4,7 @@ import java.util.Map; import java.util.Set; +import redis.clients.jedis.args.ExpiryOption; import redis.clients.jedis.params.ScanParams; import redis.clients.jedis.resps.ScanResult; @@ -57,4 +58,137 @@ default ScanResult hscanNoValues(byte[] key, byte[] cursor) { long hstrlen(byte[] key, byte[] field); + /** + * Set expiry for hash field using relative time to expire (seconds). + * + * @param key hash + * @param seconds time to expire + * @param fields + * @return integer-reply: 1 if the timeout was set, 0 otherwise + */ + List hexpire(byte[] key, long seconds, byte[]... fields); + + /** + * Set expiry for hash field using relative time to expire (seconds). + * + * @param key hash + * @param seconds time to expire + * @param condition can be NX, XX, GT or LT + * @param fields + * @return integer-reply: 1 if the timeout was set, 0 otherwise + */ + List hexpire(byte[] key, long seconds, ExpiryOption condition, byte[]... fields); + + /** + * Set expiry for hash field using relative time to expire (milliseconds). + * + * @param key hash + * @param milliseconds time to expire + * @param fields + * @return integer-reply: 1 if the timeout was set, 0 otherwise + */ + List hpexpire(byte[] key, long milliseconds, byte[]... fields); + + /** + * Set expiry for hash field using relative time to expire (milliseconds). + * + * @param key hash + * @param milliseconds time to expire + * @param condition can be NX, XX, GT or LT + * @param fields + * @return integer-reply: 1 if the timeout was set, 0 otherwise + */ + List hpexpire(byte[] key, long milliseconds, ExpiryOption condition, byte[]... fields); + + /** + * Set expiry for hash field using an absolute Unix timestamp (seconds). + * + * @param key hash + * @param unixTimeSeconds time to expire + * @param fields + * @return integer-reply: 1 if the timeout was set, 0 otherwise + */ + List hexpireAt(byte[] key, long unixTimeSeconds, byte[]... fields); + + /** + * Set expiry for hash field using an absolute Unix timestamp (seconds). + * + * @param key hash + * @param unixTimeSeconds time to expire + * @param condition can be NX, XX, GT or LT + * @param fields + * @return integer-reply: 1 if the timeout was set, 0 otherwise + */ + List hexpireAt(byte[] key, long unixTimeSeconds, ExpiryOption condition, byte[]... fields); + + /** + * Set expiry for hash field using an absolute Unix timestamp (milliseconds). + * + * @param key hash + * @param unixTimeMillis time to expire + * @param fields + * @return integer-reply: 1 if the timeout was set, 0 otherwise + */ + List hpexpireAt(byte[] key, long unixTimeMillis, byte[]... fields); + + /** + * Set expiry for hash field using an absolute Unix timestamp (milliseconds). + * + * @param key hash + * @param unixTimeMillis time to expire + * @param condition can be NX, XX, GT or LT + * @param fields + * @return integer-reply: 1 if the timeout was set, 0 otherwise + */ + List hpexpireAt(byte[] key, long unixTimeMillis, ExpiryOption condition, byte[]... fields); + + /** + * Returns the expiration time of a hash field as a Unix timestamp, in seconds. + * + * @param key hash + * @param fields + * @return Expiration Unix timestamp in seconds; + * or -1 if the field exists but has no associated expire or -2 if the field does not exist. + */ + List hexpireTime(byte[] key, byte[]... fields); + + /** + * Returns the expiration time of a hash field as a Unix timestamp, in milliseconds. + * + * @param key hash + * @param fields + * @return Expiration Unix timestamp in milliseconds; + * or -1 if the field exists but has no associated expire or -2 if the field does not exist. + */ + List hpexpireTime(byte[] key, byte[]... fields); + + /** + * Returns the TTL in seconds of a hash field. + * + * @param key hash + * @param fields + * @return TTL in seconds; + * or -1 if the field exists but has no associated expire or -2 if the field does not exist. + */ + List httl(byte[] key, byte[]... fields); + + /** + * Returns the TTL in milliseconds of a hash field. + * + * @param key hash + * @param fields + * @return TTL in milliseconds; + * or -1 if the field exists but has no associated expire or -2 if the field does not exist. + */ + List hpttl(byte[] key, byte[]... fields); + + /** + * Removes the expiration time for each specified field. + * + * @param key hash + * @param fields + * @return integer-reply: 1 if the expiration time was removed, + * or -1 if the field exists but has no associated expire or -2 if the field does not exist. + */ + List hpersist(byte[] key, byte[]... fields); } diff --git a/src/main/java/redis/clients/jedis/commands/HashCommands.java b/src/main/java/redis/clients/jedis/commands/HashCommands.java index ef18e34aee..3be6ec1959 100644 --- a/src/main/java/redis/clients/jedis/commands/HashCommands.java +++ b/src/main/java/redis/clients/jedis/commands/HashCommands.java @@ -4,6 +4,7 @@ import java.util.Map; import java.util.Set; +import redis.clients.jedis.args.ExpiryOption; import redis.clients.jedis.params.ScanParams; import redis.clients.jedis.resps.ScanResult; @@ -56,4 +57,138 @@ default ScanResult hscanNoValues(String key, String cursor) { ScanResult hscanNoValues(String key, String cursor, ScanParams params); long hstrlen(String key, String field); + + /** + * Set expiry for hash field using relative time to expire (seconds). + * + * @param key hash + * @param seconds time to expire + * @param fields + * @return integer-reply: 1 if the timeout was set, 0 otherwise + */ + List hexpire(String key, long seconds, String... fields); + + /** + * Set expiry for hash field using relative time to expire (seconds). + * + * @param key hash + * @param seconds time to expire + * @param condition can be NX, XX, GT or LT + * @param fields + * @return integer-reply: 1 if the timeout was set, 0 otherwise + */ + List hexpire(String key, long seconds, ExpiryOption condition, String... fields); + + /** + * Set expiry for hash field using relative time to expire (milliseconds). + * + * @param key hash + * @param milliseconds time to expire + * @param fields + * @return integer-reply: 1 if the timeout was set, 0 otherwise + */ + List hpexpire(String key, long milliseconds, String... fields); + + /** + * Set expiry for hash field using relative time to expire (milliseconds). + * + * @param key hash + * @param milliseconds time to expire + * @param condition can be NX, XX, GT or LT + * @param fields + * @return integer-reply: 1 if the timeout was set, 0 otherwise + */ + List hpexpire(String key, long milliseconds, ExpiryOption condition, String... fields); + + /** + * Set expiry for hash field using an absolute Unix timestamp (seconds). + * + * @param key hash + * @param unixTimeSeconds time to expire + * @param fields + * @return integer-reply: 1 if the timeout was set, 0 otherwise + */ + List hexpireAt(String key, long unixTimeSeconds, String... fields); + + /** + * Set expiry for hash field using an absolute Unix timestamp (seconds). + * + * @param key hash + * @param unixTimeSeconds time to expire + * @param condition can be NX, XX, GT or LT + * @param fields + * @return integer-reply: 1 if the timeout was set, 0 otherwise + */ + List hexpireAt(String key, long unixTimeSeconds, ExpiryOption condition, String... fields); + + /** + * Set expiry for hash field using an absolute Unix timestamp (milliseconds). + * + * @param key hash + * @param unixTimeMillis time to expire + * @param fields + * @return integer-reply: 1 if the timeout was set, 0 otherwise + */ + List hpexpireAt(String key, long unixTimeMillis, String... fields); + + /** + * Set expiry for hash field using an absolute Unix timestamp (milliseconds). + * + * @param key hash + * @param unixTimeMillis time to expire + * @param condition can be NX, XX, GT or LT + * @param fields + * @return integer-reply: 1 if the timeout was set, 0 otherwise + */ + List hpexpireAt(String key, long unixTimeMillis, ExpiryOption condition, String... fields); + + /** + * Returns the expiration time of a hash field as a Unix timestamp, in seconds. + * + * @param key hash + * @param fields + * @return Expiration Unix timestamp in seconds; + * or -1 if the field exists but has no associated expire or -2 if the field does not exist. + */ + List hexpireTime(String key, String... fields); + + /** + * Returns the expiration time of a hash field as a Unix timestamp, in milliseconds. + * + * @param key hash + * @param fields + * @return Expiration Unix timestamp in milliseconds; + * or -1 if the field exists but has no associated expire or -2 if the field does not exist. + */ + List hpexpireTime(String key, String... fields); + + /** + * Returns the TTL in seconds of a hash field. + * + * @param key hash + * @param fields + * @return TTL in seconds; + * or -1 if the field exists but has no associated expire or -2 if the field does not exist. + */ + List httl(String key, String... fields); + + /** + * Returns the TTL in milliseconds of a hash field. + * + * @param key hash + * @param fields + * @return TTL in milliseconds; + * or -1 if the field exists but has no associated expire or -2 if the field does not exist. + */ + List hpttl(String key, String... fields); + + /** + * Removes the expiration time for each specified field. + * + * @param key hash + * @param fields + * @return integer-reply: 1 if the expiration time was removed, + * or -1 if the field exists but has no associated expire or -2 if the field does not exist. + */ + List hpersist(String key, String... fields); } diff --git a/src/main/java/redis/clients/jedis/commands/HashPipelineBinaryCommands.java b/src/main/java/redis/clients/jedis/commands/HashPipelineBinaryCommands.java index cf104f7a33..e428e72a63 100644 --- a/src/main/java/redis/clients/jedis/commands/HashPipelineBinaryCommands.java +++ b/src/main/java/redis/clients/jedis/commands/HashPipelineBinaryCommands.java @@ -5,6 +5,7 @@ import java.util.Set; import redis.clients.jedis.Response; +import redis.clients.jedis.args.ExpiryOption; import redis.clients.jedis.params.ScanParams; import redis.clients.jedis.resps.ScanResult; @@ -58,4 +59,29 @@ default Response> hscanNoValues(byte[] key, byte[] cursor) { Response hstrlen(byte[] key, byte[] field); + Response> hexpire(byte[] key, long seconds, byte[]... fields); + + Response> hexpire(byte[] key, long seconds, ExpiryOption condition, byte[]... fields); + + Response> hpexpire(byte[] key, long milliseconds, byte[]... fields); + + Response> hpexpire(byte[] key, long milliseconds, ExpiryOption condition, byte[]... fields); + + Response> hexpireAt(byte[] key, long unixTimeSeconds, byte[]... fields); + + Response> hexpireAt(byte[] key, long unixTimeSeconds, ExpiryOption condition, byte[]... fields); + + Response> hpexpireAt(byte[] key, long unixTimeMillis, byte[]... fields); + + Response> hpexpireAt(byte[] key, long unixTimeMillis, ExpiryOption condition, byte[]... fields); + + Response> hexpireTime(byte[] key, byte[]... fields); + + Response> hpexpireTime(byte[] key, byte[]... fields); + + Response> httl(byte[] key, byte[]... fields); + + Response> hpttl(byte[] key, byte[]... fields); + + Response> hpersist(byte[] key, byte[]... fields); } diff --git a/src/main/java/redis/clients/jedis/commands/HashPipelineCommands.java b/src/main/java/redis/clients/jedis/commands/HashPipelineCommands.java index dabcac4e90..4de4839a9d 100644 --- a/src/main/java/redis/clients/jedis/commands/HashPipelineCommands.java +++ b/src/main/java/redis/clients/jedis/commands/HashPipelineCommands.java @@ -5,6 +5,7 @@ import java.util.Set; import redis.clients.jedis.Response; +import redis.clients.jedis.args.ExpiryOption; import redis.clients.jedis.params.ScanParams; import redis.clients.jedis.resps.ScanResult; @@ -57,4 +58,30 @@ default Response> hscanNoValues(String key, String cursor) { Response> hscanNoValues(String key, String cursor, ScanParams params); Response hstrlen(String key, String field); + + Response> hexpire(String key, long seconds, String... fields); + + Response> hexpire(String key, long seconds, ExpiryOption condition, String... fields); + + Response> hpexpire(String key, long milliseconds, String... fields); + + Response> hpexpire(String key, long milliseconds, ExpiryOption condition, String... fields); + + Response> hexpireAt(String key, long unixTimeSeconds, String... fields); + + Response> hexpireAt(String key, long unixTimeSeconds, ExpiryOption condition, String... fields); + + Response> hpexpireAt(String key, long unixTimeMillis, String... fields); + + Response> hpexpireAt(String key, long unixTimeMillis, ExpiryOption condition, String... fields); + + Response> hexpireTime(String key, String... fields); + + Response> hpexpireTime(String key, String... fields); + + Response> httl(String key, String... fields); + + Response> hpttl(String key, String... fields); + + Response> hpersist(String key, String... fields); } diff --git a/src/test/java/redis/clients/jedis/commands/commandobjects/CommandObjectsHashCommandsTest.java b/src/test/java/redis/clients/jedis/commands/commandobjects/CommandObjectsHashCommandsTest.java index b025b85440..a8de3122ab 100644 --- a/src/test/java/redis/clients/jedis/commands/commandobjects/CommandObjectsHashCommandsTest.java +++ b/src/test/java/redis/clients/jedis/commands/commandobjects/CommandObjectsHashCommandsTest.java @@ -1,12 +1,16 @@ package redis.clients.jedis.commands.commandobjects; +import static java.util.Arrays.asList; import static org.hamcrest.MatcherAssert.assertThat; import static org.hamcrest.Matchers.allOf; import static org.hamcrest.Matchers.anyOf; +import static org.hamcrest.Matchers.both; import static org.hamcrest.Matchers.contains; import static org.hamcrest.Matchers.containsInAnyOrder; import static org.hamcrest.Matchers.equalTo; import static org.hamcrest.Matchers.everyItem; +import static org.hamcrest.Matchers.greaterThan; +import static org.hamcrest.Matchers.greaterThanOrEqualTo; import static org.hamcrest.Matchers.hasEntry; import static org.hamcrest.Matchers.hasSize; import static org.hamcrest.Matchers.lessThanOrEqualTo; @@ -19,6 +23,7 @@ import org.junit.Test; import redis.clients.jedis.RedisProtocol; +import redis.clients.jedis.args.ExpiryOption; import redis.clients.jedis.params.ScanParams; import redis.clients.jedis.resps.ScanResult; @@ -27,6 +32,13 @@ */ public class CommandObjectsHashCommandsTest extends CommandObjectsStandaloneTestBase { + private final byte[] bfoo = { 0x01, 0x02, 0x03, 0x04 }; + private final byte[] bcar = { 0x09, 0x0A, 0x0B, 0x0C }; + + private final byte[] bbar1 = { 0x05, 0x06, 0x07, 0x08, 0x0A }; + private final byte[] bbar2 = { 0x05, 0x06, 0x07, 0x08, 0x0B }; + private final byte[] bbar3 = { 0x05, 0x06, 0x07, 0x08, 0x0C }; + public CommandObjectsHashCommandsTest(RedisProtocol protocol) { super(protocol); } @@ -402,4 +414,162 @@ public void testHashStrlen() { Long strlenNonExistingFieldBinary = exec(commandObjects.hstrlen(bkey, "nonExistingField".getBytes())); assertThat(strlenNonExistingFieldBinary, equalTo(0L)); } + + @Test + public void hexpireAndHttl() { + long seconds1 = 20; + long seconds2 = 10; + + exec(commandObjects.hset("foo", "bar", "car")); + exec(commandObjects.hset("foo", "bare", "care")); + assertThat(exec(commandObjects.hexpire("foo", seconds1, "bar", "bared")), equalTo(asList(1L, -2L))); + + exec(commandObjects.hset("foo", "bared", "cared")); + assertThat(exec(commandObjects.hexpire("foo", seconds2, ExpiryOption.NX, "bar", "bared")), equalTo(asList(0L, 1L))); + + assertThat(exec(commandObjects.httl("foo", "bar", "bare", "bared")), + contains(greaterThanOrEqualTo(seconds1 - 1), equalTo(-1L), + both(lessThanOrEqualTo(seconds2)).and(greaterThanOrEqualTo(seconds2 - 1)))); + } + + @Test + public void hexpireAndHttlBinary() { + long seconds1 = 20; + long seconds2 = 10; + + exec(commandObjects.hset(bfoo, bbar1, bcar)); + exec(commandObjects.hset(bfoo, bbar2, bcar)); + assertThat(exec(commandObjects.hexpire(bfoo, seconds1, bbar1, bbar3)), equalTo(asList(1L, -2L))); + + exec(commandObjects.hset(bfoo, bbar3, bcar)); + assertThat(exec(commandObjects.hexpire(bfoo, seconds2, ExpiryOption.NX, bbar1, bbar3)), equalTo(asList(0L, 1L))); + + assertThat(exec(commandObjects.httl(bfoo, bbar1, bbar2, bbar3)), + contains(greaterThanOrEqualTo(seconds1 - 1), equalTo(-1L), + both(lessThanOrEqualTo(seconds2)).and(greaterThanOrEqualTo(seconds2 - 1)))); + } + + @Test + public void hpexpireAndHpttl() { + long millis1 = 20_000; + long millis2 = 10_000; + + exec(commandObjects.hset("foo", "bar", "car")); + assertThat(exec(commandObjects.hpexpire("foo", millis1, "bar", "bared")), equalTo(asList(1L, -2L))); + + exec(commandObjects.hset("foo", "bared", "cared")); + assertThat(exec(commandObjects.hpexpire("foo", millis2, ExpiryOption.XX, "bar", "bared")), equalTo(asList(1L, 0L))); + + assertThat(exec(commandObjects.hpttl("foo", "bar", "bare", "bared")), + contains(both(lessThanOrEqualTo(millis2)).and(greaterThan(millis2 - 10)), equalTo(-2L), equalTo(-1L))); + } + + @Test + public void hpexpireAndHpttlBinary() { + long millis1 = 20_000; + long millis2 = 10_000; + + exec(commandObjects.hset(bfoo, bbar1, bcar)); + assertThat(exec(commandObjects.hpexpire(bfoo, millis1, bbar1, bbar3)), equalTo(asList(1L, -2L))); + + exec(commandObjects.hset(bfoo, bbar3, bcar)); + assertThat(exec(commandObjects.hpexpire(bfoo, millis2, ExpiryOption.XX, bbar1, bbar3)), equalTo(asList(1L, 0L))); + + assertThat(exec(commandObjects.hpttl(bfoo, bbar1, bbar2, bbar3)), + contains(both(lessThanOrEqualTo(millis2)).and(greaterThan(millis2 - 10)), equalTo(-2L), equalTo(-1L))); + } + + @Test + public void hexpireAtAndExpireTime() { + long currSeconds = System.currentTimeMillis() / 1000; + long seconds1 = currSeconds + 20; + long seconds2 = currSeconds + 10; + + exec(commandObjects.hset("foo", "bar", "car")); + exec(commandObjects.hset("foo", "bare", "care")); + assertThat(exec(commandObjects.hexpireAt("foo", seconds1, "bar", "bared")), equalTo(asList(1L, -2L))); + + exec(commandObjects.hset("foo", "bared", "cared")); + assertThat(exec(commandObjects.hexpireAt("foo", seconds2, ExpiryOption.LT, "bar", "bared")), equalTo(asList(1L, 1L))); + + assertThat(exec(commandObjects.hexpireTime("foo", "bar", "bare", "bared")), + contains(both(lessThanOrEqualTo(seconds2)).and(greaterThanOrEqualTo(seconds2 - 1)), equalTo(-1L), + both(lessThanOrEqualTo(seconds2)).and(greaterThanOrEqualTo(seconds2 - 1)))); + } + + @Test + public void hexpireAtAndExpireTimeBinary() { + long currSeconds = System.currentTimeMillis() / 1000; + long seconds1 = currSeconds + 20; + long seconds2 = currSeconds + 10; + + exec(commandObjects.hset(bfoo, bbar1, bcar)); + exec(commandObjects.hset(bfoo, bbar2, bcar)); + assertThat(exec(commandObjects.hexpireAt(bfoo, seconds1, bbar1, bbar3)), equalTo(asList(1L, -2L))); + + exec(commandObjects.hset(bfoo, bbar3, bcar)); + assertThat(exec(commandObjects.hexpireAt(bfoo, seconds2, ExpiryOption.LT, bbar1, bbar3)), equalTo(asList(1L, 1L))); + + assertThat(exec(commandObjects.hexpireTime(bfoo, bbar1, bbar2, bbar3)), + contains(both(lessThanOrEqualTo(seconds2)).and(greaterThanOrEqualTo(seconds2 - 1)), equalTo(-1L), + both(lessThanOrEqualTo(seconds2)).and(greaterThanOrEqualTo(seconds2 - 1)))); + } + + @Test + public void hpexpireAtAndPexpireTime() { + long currMillis = System.currentTimeMillis(); + long unixMillis = currMillis + 20_000; + + exec(commandObjects.hset("foo", "bar", "car")); + assertThat(exec(commandObjects.hpexpireAt("foo", unixMillis - 100, "bar", "bared")), equalTo(asList(1L, -2L))); + + exec(commandObjects.hset("foo", "bared", "cared")); + assertThat(exec(commandObjects.hpexpireAt("foo", unixMillis, ExpiryOption.GT, "bar", "bared")), equalTo(asList(1L, 0L))); + + assertThat(exec(commandObjects.hpexpireTime("foo", "bar", "bare", "bared")), + contains(equalTo(unixMillis), equalTo(-2L), equalTo(-1L))); + } + + @Test + public void hpexpireAtAndPexpireTimeBinary() { + long currMillis = System.currentTimeMillis(); + long unixMillis = currMillis + 20_000; + + exec(commandObjects.hset(bfoo, bbar1, bcar)); + assertThat(exec(commandObjects.hpexpireAt(bfoo, unixMillis - 100, bbar1, bbar3)), equalTo(asList(1L, -2L))); + + exec(commandObjects.hset(bfoo, bbar3, bcar)); + assertThat(exec(commandObjects.hpexpireAt(bfoo, unixMillis, ExpiryOption.GT, bbar1, bbar3)), equalTo(asList(1L, 0L))); + + assertThat(exec(commandObjects.hpexpireTime(bfoo, bbar1, bbar2, bbar3)), + contains(equalTo(unixMillis), equalTo(-2L), equalTo(-1L))); + } + + @Test + public void hpersist() { + long seconds = 20; + + exec(commandObjects.hset("foo", "bar", "car")); + exec(commandObjects.hset("foo", "bare", "care")); + assertThat(exec(commandObjects.hexpire("foo", seconds, "bar", "bared")), equalTo(asList(1L, -2L))); + + assertThat(exec(commandObjects.hpersist("foo", "bar", "bare", "bared")), equalTo(asList(1L, -1L, -2L))); + + assertThat(exec(commandObjects.httl("foo", "bar", "bare", "bared")), + contains(equalTo(-1L), equalTo(-1L), equalTo(-2L))); + } + + @Test + public void hpersistBinary() { + long seconds = 20; + + exec(commandObjects.hset(bfoo, bbar1, bcar)); + exec(commandObjects.hset(bfoo, bbar2, bcar)); + assertThat(exec(commandObjects.hexpire(bfoo, seconds, bbar1, bbar3)), equalTo(asList(1L, -2L))); + + assertThat(exec(commandObjects.hpersist(bfoo, bbar1, bbar2, bbar3)), equalTo(asList(1L, -1L, -2L))); + + assertThat(exec(commandObjects.httl(bfoo, bbar1, bbar2, bbar3)), + contains(equalTo(-1L), equalTo(-1L), equalTo(-2L))); + } } diff --git a/src/test/java/redis/clients/jedis/commands/jedis/HashesCommandsTest.java b/src/test/java/redis/clients/jedis/commands/jedis/HashesCommandsTest.java index c07adc86b4..88ca543fc4 100644 --- a/src/test/java/redis/clients/jedis/commands/jedis/HashesCommandsTest.java +++ b/src/test/java/redis/clients/jedis/commands/jedis/HashesCommandsTest.java @@ -1,7 +1,16 @@ package redis.clients.jedis.commands.jedis; +import static java.util.Arrays.asList; + import static org.hamcrest.MatcherAssert.assertThat; +import static org.hamcrest.Matchers.both; +import static org.hamcrest.Matchers.contains; import static org.hamcrest.Matchers.containsInAnyOrder; +import static org.hamcrest.Matchers.equalTo; +import static org.hamcrest.Matchers.greaterThan; +import static org.hamcrest.Matchers.greaterThanOrEqualTo; +import static org.hamcrest.Matchers.lessThanOrEqualTo; + import static org.junit.Assert.assertArrayEquals; import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertFalse; @@ -29,6 +38,7 @@ import redis.clients.jedis.Pipeline; import redis.clients.jedis.RedisProtocol; import redis.clients.jedis.Response; +import redis.clients.jedis.args.ExpiryOption; import redis.clients.jedis.params.ScanParams; import redis.clients.jedis.resps.ScanResult; import redis.clients.jedis.util.AssertUtil; @@ -641,4 +651,162 @@ public void hrandfield() { assertEquals(5, bactual.size()); bactual.forEach(e -> assertArrayEquals(bhash.get(e.getKey()), e.getValue())); } + + @Test + public void hexpireAndHttl() { + long seconds1 = 20; + long seconds2 = 10; + + jedis.hset("foo", "bar", "car"); + jedis.hset("foo", "bare", "care"); + assertEquals(asList(1L, -2L), jedis.hexpire("foo", seconds1, "bar", "bared")); + + jedis.hset("foo", "bared", "cared"); + assertEquals(asList(0L, 1L), jedis.hexpire("foo", seconds2, ExpiryOption.NX, "bar", "bared")); + + assertThat(jedis.httl("foo", "bar", "bare", "bared"), + contains(greaterThanOrEqualTo(seconds1 - 1), equalTo(-1L), + both(lessThanOrEqualTo(seconds2)).and(greaterThanOrEqualTo(seconds2 - 1)))); + } + + @Test + public void hexpireAndHttlBinary() { + long seconds1 = 20; + long seconds2 = 10; + + jedis.hset(bfoo, bbar1, bcar); + jedis.hset(bfoo, bbar2, bcar); + assertEquals(asList(1L, -2L), jedis.hexpire(bfoo, seconds1, bbar1, bbar3)); + + jedis.hset(bfoo, bbar3, bcar); + assertEquals(asList(0L, 1L), jedis.hexpire(bfoo, seconds2, ExpiryOption.NX, bbar1, bbar3)); + + assertThat(jedis.httl(bfoo, bbar1, bbar2, bbar3), + contains(greaterThanOrEqualTo(seconds1 - 1), equalTo(-1L), + both(lessThanOrEqualTo(seconds2)).and(greaterThanOrEqualTo(seconds2 - 1)))); + } + + @Test + public void hpexpireAndHpttl() { + long millis1 = 20_000; + long millis2 = 10_000; + + jedis.hset("foo", "bar", "car"); + assertEquals(asList(1L, -2L), jedis.hpexpire("foo", millis1, "bar", "bared")); + + jedis.hset("foo", "bared", "cared"); + assertEquals(asList(1L, 0L), jedis.hpexpire("foo", millis2, ExpiryOption.XX, "bar", "bared")); + + assertThat(jedis.hpttl("foo", "bar", "bare", "bared"), + contains(both(lessThanOrEqualTo(millis2)).and(greaterThan(millis2 - 10)), equalTo(-2L), equalTo(-1L))); + } + + @Test + public void hpexpireAndHpttlBinary() { + long millis1 = 20_000; + long millis2 = 10_000; + + jedis.hset(bfoo, bbar1, bcar); + assertEquals(asList(1L, -2L), jedis.hpexpire(bfoo, millis1, bbar1, bbar3)); + + jedis.hset(bfoo, bbar3, bcar); + assertEquals(asList(1L, 0L), jedis.hpexpire(bfoo, millis2, ExpiryOption.XX, bbar1, bbar3)); + + assertThat(jedis.hpttl(bfoo, bbar1, bbar2, bbar3), + contains(both(lessThanOrEqualTo(millis2)).and(greaterThan(millis2 - 10)), equalTo(-2L), equalTo(-1L))); + } + + @Test + public void hexpireAtAndExpireTime() { + long currSeconds = System.currentTimeMillis() / 1000; + long seconds1 = currSeconds + 20; + long seconds2 = currSeconds + 10; + + jedis.hset("foo", "bar", "car"); + jedis.hset("foo", "bare", "care"); + assertEquals(asList(1L, -2L), jedis.hexpireAt("foo", seconds1, "bar", "bared")); + + jedis.hset("foo", "bared", "cared"); + assertEquals(asList(1L, 1L), jedis.hexpireAt("foo", seconds2, ExpiryOption.LT, "bar", "bared")); + + assertThat(jedis.hexpireTime("foo", "bar", "bare", "bared"), + contains(both(lessThanOrEqualTo(seconds2)).and(greaterThanOrEqualTo(seconds2 - 1)), equalTo(-1L), + both(lessThanOrEqualTo(seconds2)).and(greaterThanOrEqualTo(seconds2 - 1)))); + } + + @Test + public void hexpireAtAndExpireTimeBinary() { + long currSeconds = System.currentTimeMillis() / 1000; + long seconds1 = currSeconds + 20; + long seconds2 = currSeconds + 10; + + jedis.hset(bfoo, bbar1, bcar); + jedis.hset(bfoo, bbar2, bcar); + assertEquals(asList(1L, -2L), jedis.hexpireAt(bfoo, seconds1, bbar1, bbar3)); + + jedis.hset(bfoo, bbar3, bcar); + assertEquals(asList(1L, 1L), jedis.hexpireAt(bfoo, seconds2, ExpiryOption.LT, bbar1, bbar3)); + + assertThat(jedis.hexpireTime(bfoo, bbar1, bbar2, bbar3), + contains(both(lessThanOrEqualTo(seconds2)).and(greaterThanOrEqualTo(seconds2 - 1)), equalTo(-1L), + both(lessThanOrEqualTo(seconds2)).and(greaterThanOrEqualTo(seconds2 - 1)))); + } + + @Test + public void hpexpireAtAndPexpireTime() { + long currMillis = System.currentTimeMillis(); + long unixMillis = currMillis + 20_000; + + jedis.hset("foo", "bar", "car"); + assertEquals(asList(1L, -2L), jedis.hpexpireAt("foo", unixMillis - 100, "bar", "bared")); + + jedis.hset("foo", "bared", "cared"); + assertEquals(asList(1L, 0L), jedis.hpexpireAt("foo", unixMillis, ExpiryOption.GT, "bar", "bared")); + + assertThat(jedis.hpexpireTime("foo", "bar", "bare", "bared"), + contains(equalTo(unixMillis), equalTo(-2L), equalTo(-1L))); + } + + @Test + public void hpexpireAtAndPexpireTimeBinary() { + long currMillis = System.currentTimeMillis(); + long unixMillis = currMillis + 20_000; + + jedis.hset(bfoo, bbar1, bcar); + assertEquals(asList(1L, -2L), jedis.hpexpireAt(bfoo, unixMillis - 100, bbar1, bbar3)); + + jedis.hset(bfoo, bbar3, bcar); + assertEquals(asList(1L, 0L), jedis.hpexpireAt(bfoo, unixMillis, ExpiryOption.GT, bbar1, bbar3)); + + assertThat(jedis.hpexpireTime(bfoo, bbar1, bbar2, bbar3), + contains(equalTo(unixMillis), equalTo(-2L), equalTo(-1L))); + } + + @Test + public void hpersist() { + long seconds = 20; + + jedis.hset("foo", "bar", "car"); + jedis.hset("foo", "bare", "care"); + assertEquals(asList(1L, -2L), jedis.hexpire("foo", seconds, "bar", "bared")); + + assertEquals(asList(1L, -1L, -2L), jedis.hpersist("foo", "bar", "bare", "bared")); + + assertThat(jedis.httl("foo", "bar", "bare", "bared"), + contains(equalTo(-1L), equalTo(-1L), equalTo(-2L))); + } + + @Test + public void hpersistBinary() { + long seconds = 20; + + jedis.hset(bfoo, bbar1, bcar); + jedis.hset(bfoo, bbar2, bcar); + assertEquals(asList(1L, -2L), jedis.hexpire(bfoo, seconds, bbar1, bbar3)); + + assertEquals(asList(1L, -1L, -2L), jedis.hpersist(bfoo, bbar1, bbar2, bbar3)); + + assertThat(jedis.httl(bfoo, bbar1, bbar2, bbar3), + contains(equalTo(-1L), equalTo(-1L), equalTo(-2L))); + } } diff --git a/src/test/java/redis/clients/jedis/commands/unified/HashesCommandsTestBase.java b/src/test/java/redis/clients/jedis/commands/unified/HashesCommandsTestBase.java index 401f29dbe3..f84b0c2cc6 100644 --- a/src/test/java/redis/clients/jedis/commands/unified/HashesCommandsTestBase.java +++ b/src/test/java/redis/clients/jedis/commands/unified/HashesCommandsTestBase.java @@ -1,7 +1,16 @@ package redis.clients.jedis.commands.unified; +import static java.util.Arrays.asList; + import static org.hamcrest.MatcherAssert.assertThat; +import static org.hamcrest.Matchers.both; +import static org.hamcrest.Matchers.contains; import static org.hamcrest.Matchers.containsInAnyOrder; +import static org.hamcrest.Matchers.equalTo; +import static org.hamcrest.Matchers.greaterThan; +import static org.hamcrest.Matchers.greaterThanOrEqualTo; +import static org.hamcrest.Matchers.lessThanOrEqualTo; + import static org.junit.Assert.assertArrayEquals; import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertFalse; @@ -25,6 +34,7 @@ import org.junit.Test; import redis.clients.jedis.RedisProtocol; +import redis.clients.jedis.args.ExpiryOption; import redis.clients.jedis.params.ScanParams; import redis.clients.jedis.resps.ScanResult; import redis.clients.jedis.util.AssertUtil; @@ -613,4 +623,162 @@ public void hrandfield() { assertEquals(5, bactual.size()); bactual.forEach(e -> assertArrayEquals(bhash.get(e.getKey()), e.getValue())); } + + @Test + public void hexpireAndHttl() { + long seconds1 = 20; + long seconds2 = 10; + + jedis.hset("foo", "bar", "car"); + jedis.hset("foo", "bare", "care"); + assertEquals(asList(1L, -2L), jedis.hexpire("foo", seconds1, "bar", "bared")); + + jedis.hset("foo", "bared", "cared"); + assertEquals(asList(0L, 1L), jedis.hexpire("foo", seconds2, ExpiryOption.NX, "bar", "bared")); + + assertThat(jedis.httl("foo", "bar", "bare", "bared"), + contains(greaterThanOrEqualTo(seconds1 - 1), equalTo(-1L), + both(lessThanOrEqualTo(seconds2)).and(greaterThanOrEqualTo(seconds2 - 1)))); + } + + @Test + public void hexpireAndHttlBinary() { + long seconds1 = 20; + long seconds2 = 10; + + jedis.hset(bfoo, bbar1, bcar); + jedis.hset(bfoo, bbar2, bcar); + assertEquals(asList(1L, -2L), jedis.hexpire(bfoo, seconds1, bbar1, bbar3)); + + jedis.hset(bfoo, bbar3, bcar); + assertEquals(asList(0L, 1L), jedis.hexpire(bfoo, seconds2, ExpiryOption.NX, bbar1, bbar3)); + + assertThat(jedis.httl(bfoo, bbar1, bbar2, bbar3), + contains(greaterThanOrEqualTo(seconds1 - 1), equalTo(-1L), + both(lessThanOrEqualTo(seconds2)).and(greaterThanOrEqualTo(seconds2 - 1)))); + } + + @Test + public void hpexpireAndHpttl() { + long millis1 = 20_000; + long millis2 = 10_000; + + jedis.hset("foo", "bar", "car"); + assertEquals(asList(1L, -2L), jedis.hpexpire("foo", millis1, "bar", "bared")); + + jedis.hset("foo", "bared", "cared"); + assertEquals(asList(1L, 0L), jedis.hpexpire("foo", millis2, ExpiryOption.XX, "bar", "bared")); + + assertThat(jedis.hpttl("foo", "bar", "bare", "bared"), + contains(both(lessThanOrEqualTo(millis2)).and(greaterThan(millis2 - 10)), equalTo(-2L), equalTo(-1L))); + } + + @Test + public void hpexpireAndHpttlBinary() { + long millis1 = 20_000; + long millis2 = 10_000; + + jedis.hset(bfoo, bbar1, bcar); + assertEquals(asList(1L, -2L), jedis.hpexpire(bfoo, millis1, bbar1, bbar3)); + + jedis.hset(bfoo, bbar3, bcar); + assertEquals(asList(1L, 0L), jedis.hpexpire(bfoo, millis2, ExpiryOption.XX, bbar1, bbar3)); + + assertThat(jedis.hpttl(bfoo, bbar1, bbar2, bbar3), + contains(both(lessThanOrEqualTo(millis2)).and(greaterThan(millis2 - 10)), equalTo(-2L), equalTo(-1L))); + } + + @Test + public void hexpireAtAndExpireTime() { + long currSeconds = System.currentTimeMillis() / 1000; + long seconds1 = currSeconds + 20; + long seconds2 = currSeconds + 10; + + jedis.hset("foo", "bar", "car"); + jedis.hset("foo", "bare", "care"); + assertEquals(asList(1L, -2L), jedis.hexpireAt("foo", seconds1, "bar", "bared")); + + jedis.hset("foo", "bared", "cared"); + assertEquals(asList(1L, 1L), jedis.hexpireAt("foo", seconds2, ExpiryOption.LT, "bar", "bared")); + + assertThat(jedis.hexpireTime("foo", "bar", "bare", "bared"), + contains(both(lessThanOrEqualTo(seconds2)).and(greaterThanOrEqualTo(seconds2 - 1)), equalTo(-1L), + both(lessThanOrEqualTo(seconds2)).and(greaterThanOrEqualTo(seconds2 - 1)))); + } + + @Test + public void hexpireAtAndExpireTimeBinary() { + long currSeconds = System.currentTimeMillis() / 1000; + long seconds1 = currSeconds + 20; + long seconds2 = currSeconds + 10; + + jedis.hset(bfoo, bbar1, bcar); + jedis.hset(bfoo, bbar2, bcar); + assertEquals(asList(1L, -2L), jedis.hexpireAt(bfoo, seconds1, bbar1, bbar3)); + + jedis.hset(bfoo, bbar3, bcar); + assertEquals(asList(1L, 1L), jedis.hexpireAt(bfoo, seconds2, ExpiryOption.LT, bbar1, bbar3)); + + assertThat(jedis.hexpireTime(bfoo, bbar1, bbar2, bbar3), + contains(both(lessThanOrEqualTo(seconds2)).and(greaterThanOrEqualTo(seconds2 - 1)), equalTo(-1L), + both(lessThanOrEqualTo(seconds2)).and(greaterThanOrEqualTo(seconds2 - 1)))); + } + + @Test + public void hpexpireAtAndPexpireTime() { + long currMillis = System.currentTimeMillis(); + long unixMillis = currMillis + 20_000; + + jedis.hset("foo", "bar", "car"); + assertEquals(asList(1L, -2L), jedis.hpexpireAt("foo", unixMillis - 100, "bar", "bared")); + + jedis.hset("foo", "bared", "cared"); + assertEquals(asList(1L, 0L), jedis.hpexpireAt("foo", unixMillis, ExpiryOption.GT, "bar", "bared")); + + assertThat(jedis.hpexpireTime("foo", "bar", "bare", "bared"), + contains(equalTo(unixMillis), equalTo(-2L), equalTo(-1L))); + } + + @Test + public void hpexpireAtAndPexpireTimeBinary() { + long currMillis = System.currentTimeMillis(); + long unixMillis = currMillis + 20_000; + + jedis.hset(bfoo, bbar1, bcar); + assertEquals(asList(1L, -2L), jedis.hpexpireAt(bfoo, unixMillis - 100, bbar1, bbar3)); + + jedis.hset(bfoo, bbar3, bcar); + assertEquals(asList(1L, 0L), jedis.hpexpireAt(bfoo, unixMillis, ExpiryOption.GT, bbar1, bbar3)); + + assertThat(jedis.hpexpireTime(bfoo, bbar1, bbar2, bbar3), + contains(equalTo(unixMillis), equalTo(-2L), equalTo(-1L))); + } + + @Test + public void hpersist() { + long seconds = 20; + + jedis.hset("foo", "bar", "car"); + jedis.hset("foo", "bare", "care"); + assertEquals(asList(1L, -2L), jedis.hexpire("foo", seconds, "bar", "bared")); + + assertEquals(asList(1L, -1L, -2L), jedis.hpersist("foo", "bar", "bare", "bared")); + + assertThat(jedis.httl("foo", "bar", "bare", "bared"), + contains(equalTo(-1L), equalTo(-1L), equalTo(-2L))); + } + + @Test + public void hpersistBinary() { + long seconds = 20; + + jedis.hset(bfoo, bbar1, bcar); + jedis.hset(bfoo, bbar2, bcar); + assertEquals(asList(1L, -2L), jedis.hexpire(bfoo, seconds, bbar1, bbar3)); + + assertEquals(asList(1L, -1L, -2L), jedis.hpersist(bfoo, bbar1, bbar2, bbar3)); + + assertThat(jedis.httl(bfoo, bbar1, bbar2, bbar3), + contains(equalTo(-1L), equalTo(-1L), equalTo(-2L))); + } } diff --git a/src/test/java/redis/clients/jedis/mocked/pipeline/PipeliningBaseHashCommandsTest.java b/src/test/java/redis/clients/jedis/mocked/pipeline/PipeliningBaseHashCommandsTest.java index b23cee6da2..1ea0d0b3c2 100644 --- a/src/test/java/redis/clients/jedis/mocked/pipeline/PipeliningBaseHashCommandsTest.java +++ b/src/test/java/redis/clients/jedis/mocked/pipeline/PipeliningBaseHashCommandsTest.java @@ -2,7 +2,9 @@ import static org.hamcrest.MatcherAssert.assertThat; import static org.hamcrest.Matchers.contains; +import static org.hamcrest.Matchers.in; import static org.hamcrest.Matchers.is; +import static org.mockito.Mockito.mock; import static org.mockito.Mockito.when; import java.util.HashMap; @@ -12,11 +14,18 @@ import org.junit.Test; import redis.clients.jedis.Response; +import redis.clients.jedis.args.ExpiryOption; import redis.clients.jedis.params.ScanParams; import redis.clients.jedis.resps.ScanResult; public class PipeliningBaseHashCommandsTest extends PipeliningBaseMockedTestBase { + private final byte[] bfoo = { 0x01, 0x02, 0x03, 0x04 }; + + private final byte[] bbar1 = { 0x05, 0x06, 0x07, 0x08, 0x0A }; + private final byte[] bbar2 = { 0x05, 0x06, 0x07, 0x08, 0x0B }; + private final byte[] bbar3 = { 0x05, 0x06, 0x07, 0x08, 0x0C }; + @Test public void testHdel() { when(commandObjects.hdel("key", "field1", "field2")).thenReturn(longCommandObject); @@ -502,4 +511,314 @@ public void testHvalsBinary() { assertThat(response, is(predefinedResponse)); } + @Test + public void hexpire() { + String key = "hash"; + long seconds = 100; + String[] fields = { "one", "two", "three" }; + + when(commandObjects.hexpire(key, seconds, fields)).thenReturn(listLongCommandObject); + + assertThat(pipeliningBase.hexpire(key, seconds, fields), is(predefinedResponse)); + assertThat(listLongCommandObject, in(commands)); + } + + @Test + public void hexpireCondition() { + String key = "hash"; + long seconds = 100; + ExpiryOption condition = mock(ExpiryOption.class); + String[] fields = { "one", "two", "three" }; + + when(commandObjects.hexpire(key, seconds, condition, fields)).thenReturn(listLongCommandObject); + + assertThat(pipeliningBase.hexpire(key, seconds, condition, fields), is(predefinedResponse)); + assertThat(listLongCommandObject, in(commands)); + } + + @Test + public void hpexpire() { + String key = "hash"; + long milliseconds = 10000; + String[] fields = { "one", "two", "three" }; + + when(commandObjects.hpexpire(key, milliseconds, fields)).thenReturn(listLongCommandObject); + + assertThat(pipeliningBase.hpexpire(key, milliseconds, fields), is(predefinedResponse)); + assertThat(listLongCommandObject, in(commands)); + } + + @Test + public void hpexpireCondition() { + String key = "hash"; + long milliseconds = 10000; + ExpiryOption condition = mock(ExpiryOption.class); + String[] fields = { "one", "two", "three" }; + + when(commandObjects.hpexpire(key, milliseconds, condition, fields)).thenReturn(listLongCommandObject); + + assertThat(pipeliningBase.hpexpire(key, milliseconds, condition, fields), is(predefinedResponse)); + assertThat(listLongCommandObject, in(commands)); + } + + @Test + public void hexpireAt() { + String key = "hash"; + long seconds = 100; + String[] fields = { "one", "two", "three" }; + + when(commandObjects.hexpireAt(key, seconds, fields)).thenReturn(listLongCommandObject); + + assertThat(pipeliningBase.hexpireAt(key, seconds, fields), is(predefinedResponse)); + assertThat(listLongCommandObject, in(commands)); + } + + @Test + public void hexpireAtCondition() { + String key = "hash"; + long seconds = 100; + ExpiryOption condition = mock(ExpiryOption.class); + String[] fields = { "one", "two", "three" }; + + when(commandObjects.hexpireAt(key, seconds, condition, fields)).thenReturn(listLongCommandObject); + + assertThat(pipeliningBase.hexpireAt(key, seconds, condition, fields), is(predefinedResponse)); + assertThat(listLongCommandObject, in(commands)); + } + + @Test + public void hpexpireAt() { + String key = "hash"; + long milliseconds = 10000; + String[] fields = { "one", "two", "three" }; + + when(commandObjects.hpexpireAt(key, milliseconds, fields)).thenReturn(listLongCommandObject); + + assertThat(pipeliningBase.hpexpireAt(key, milliseconds, fields), is(predefinedResponse)); + assertThat(listLongCommandObject, in(commands)); + } + + @Test + public void hpexpireAtCondition() { + String key = "hash"; + long milliseconds = 10000; + ExpiryOption condition = mock(ExpiryOption.class); + String[] fields = { "one", "two", "three" }; + + when(commandObjects.hpexpireAt(key, milliseconds, condition, fields)).thenReturn(listLongCommandObject); + + assertThat(pipeliningBase.hpexpireAt(key, milliseconds, condition, fields), is(predefinedResponse)); + assertThat(listLongCommandObject, in(commands)); + } + + @Test + public void hexpireTime() { + String key = "hash"; + String[] fields = { "one", "two", "three" }; + + when(commandObjects.hexpireTime(key, fields)).thenReturn(listLongCommandObject); + + assertThat(pipeliningBase.hexpireTime(key, fields), is(predefinedResponse)); + assertThat(listLongCommandObject, in(commands)); + } + + @Test + public void hpexpireTime() { + String key = "hash"; + String[] fields = { "one", "two", "three" }; + + when(commandObjects.hpexpireTime(key, fields)).thenReturn(listLongCommandObject); + + assertThat(pipeliningBase.hpexpireTime(key, fields), is(predefinedResponse)); + assertThat(listLongCommandObject, in(commands)); + } + + @Test + public void httl() { + String key = "hash"; + String[] fields = { "one", "two", "three" }; + + when(commandObjects.httl(key, fields)).thenReturn(listLongCommandObject); + + assertThat(pipeliningBase.httl(key, fields), is(predefinedResponse)); + assertThat(listLongCommandObject, in(commands)); + } + + @Test + public void hpttl() { + String key = "hash"; + String[] fields = { "one", "two", "three" }; + + when(commandObjects.hpttl(key, fields)).thenReturn(listLongCommandObject); + + assertThat(pipeliningBase.hpttl(key, fields), is(predefinedResponse)); + assertThat(listLongCommandObject, in(commands)); + } + + @Test + public void hpersist() { + String key = "hash"; + String[] fields = { "one", "two", "three" }; + + when(commandObjects.hpersist(key, fields)).thenReturn(listLongCommandObject); + + assertThat(pipeliningBase.hpersist(key, fields), is(predefinedResponse)); + assertThat(listLongCommandObject, in(commands)); + } + + @Test + public void hexpireBinary() { + byte[] key = bfoo; + long seconds = 100; + byte[][] fields = { bbar1, bbar2, bbar3 }; + + when(commandObjects.hexpire(key, seconds, fields)).thenReturn(listLongCommandObject); + + assertThat(pipeliningBase.hexpire(key, seconds, fields), is(predefinedResponse)); + assertThat(listLongCommandObject, in(commands)); + } + + @Test + public void hexpireConditionBinary() { + byte[] key = bfoo; + long seconds = 100; + ExpiryOption condition = mock(ExpiryOption.class); + byte[][] fields = { bbar1, bbar2, bbar3 }; + + when(commandObjects.hexpire(key, seconds, condition, fields)).thenReturn(listLongCommandObject); + + assertThat(pipeliningBase.hexpire(key, seconds, condition, fields), is(predefinedResponse)); + assertThat(listLongCommandObject, in(commands)); + } + + @Test + public void hpexpireBinary() { + byte[] key = bfoo; + long milliseconds = 10000; + byte[][] fields = { bbar1, bbar2, bbar3 }; + + when(commandObjects.hpexpire(key, milliseconds, fields)).thenReturn(listLongCommandObject); + + assertThat(pipeliningBase.hpexpire(key, milliseconds, fields), is(predefinedResponse)); + assertThat(listLongCommandObject, in(commands)); + } + + @Test + public void hpexpireConditionBinary() { + byte[] key = bfoo; + long milliseconds = 10000; + ExpiryOption condition = mock(ExpiryOption.class); + byte[][] fields = { bbar1, bbar2, bbar3 }; + + when(commandObjects.hpexpire(key, milliseconds, condition, fields)).thenReturn(listLongCommandObject); + + assertThat(pipeliningBase.hpexpire(key, milliseconds, condition, fields), is(predefinedResponse)); + assertThat(listLongCommandObject, in(commands)); + } + + @Test + public void hexpireAtBinary() { + byte[] key = bfoo; + long seconds = 100; + byte[][] fields = { bbar1, bbar2, bbar3 }; + + when(commandObjects.hexpireAt(key, seconds, fields)).thenReturn(listLongCommandObject); + + assertThat(pipeliningBase.hexpireAt(key, seconds, fields), is(predefinedResponse)); + assertThat(listLongCommandObject, in(commands)); + } + + @Test + public void hexpireAtConditionBinary() { + byte[] key = bfoo; + long seconds = 100; + ExpiryOption condition = mock(ExpiryOption.class); + byte[][] fields = { bbar1, bbar2, bbar3 }; + + when(commandObjects.hexpireAt(key, seconds, condition, fields)).thenReturn(listLongCommandObject); + + assertThat(pipeliningBase.hexpireAt(key, seconds, condition, fields), is(predefinedResponse)); + assertThat(listLongCommandObject, in(commands)); + } + + @Test + public void hpexpireAtBinary() { + byte[] key = bfoo; + long milliseconds = 10000; + byte[][] fields = { bbar1, bbar2, bbar3 }; + + when(commandObjects.hpexpireAt(key, milliseconds, fields)).thenReturn(listLongCommandObject); + + assertThat(pipeliningBase.hpexpireAt(key, milliseconds, fields), is(predefinedResponse)); + assertThat(listLongCommandObject, in(commands)); + } + + @Test + public void hpexpireAtConditionBinary() { + byte[] key = bfoo; + long milliseconds = 10000; + ExpiryOption condition = mock(ExpiryOption.class); + byte[][] fields = { bbar1, bbar2, bbar3 }; + + when(commandObjects.hpexpireAt(key, milliseconds, condition, fields)).thenReturn(listLongCommandObject); + + assertThat(pipeliningBase.hpexpireAt(key, milliseconds, condition, fields), is(predefinedResponse)); + assertThat(listLongCommandObject, in(commands)); + } + + @Test + public void hexpireTimeBinary() { + byte[] key = bfoo; + byte[][] fields = { bbar1, bbar2, bbar3 }; + + when(commandObjects.hexpireTime(key, fields)).thenReturn(listLongCommandObject); + + assertThat(pipeliningBase.hexpireTime(key, fields), is(predefinedResponse)); + assertThat(listLongCommandObject, in(commands)); + } + + @Test + public void hpexpireTimeBinary() { + byte[] key = bfoo; + byte[][] fields = { bbar1, bbar2, bbar3 }; + + when(commandObjects.hpexpireTime(key, fields)).thenReturn(listLongCommandObject); + + assertThat(pipeliningBase.hpexpireTime(key, fields), is(predefinedResponse)); + assertThat(listLongCommandObject, in(commands)); + } + + @Test + public void httlBinary() { + byte[] key = bfoo; + byte[][] fields = { bbar1, bbar2, bbar3 }; + + when(commandObjects.httl(key, fields)).thenReturn(listLongCommandObject); + + assertThat(pipeliningBase.httl(key, fields), is(predefinedResponse)); + assertThat(listLongCommandObject, in(commands)); + } + + @Test + public void hpttlBinary() { + byte[] key = bfoo; + byte[][] fields = { bbar1, bbar2, bbar3 }; + + when(commandObjects.hpttl(key, fields)).thenReturn(listLongCommandObject); + + assertThat(pipeliningBase.hpttl(key, fields), is(predefinedResponse)); + assertThat(listLongCommandObject, in(commands)); + } + + @Test + public void hpersistBinary() { + byte[] key = bfoo; + byte[][] fields = { bbar1, bbar2, bbar3 }; + + when(commandObjects.hpersist(key, fields)).thenReturn(listLongCommandObject); + + assertThat(pipeliningBase.hpersist(key, fields), is(predefinedResponse)); + assertThat(listLongCommandObject, in(commands)); + } + } diff --git a/src/test/java/redis/clients/jedis/mocked/unified/UnifiedJedisHashCommandsTest.java b/src/test/java/redis/clients/jedis/mocked/unified/UnifiedJedisHashCommandsTest.java index c867e4d3e5..d2dc8d8892 100644 --- a/src/test/java/redis/clients/jedis/mocked/unified/UnifiedJedisHashCommandsTest.java +++ b/src/test/java/redis/clients/jedis/mocked/unified/UnifiedJedisHashCommandsTest.java @@ -1,7 +1,9 @@ package redis.clients.jedis.mocked.unified; +import static java.util.Arrays.asList; import static org.hamcrest.MatcherAssert.assertThat; import static org.hamcrest.Matchers.equalTo; +import static org.mockito.Mockito.mock; import static org.mockito.Mockito.verify; import static org.mockito.Mockito.when; @@ -15,11 +17,18 @@ import java.util.Set; import org.junit.Test; +import redis.clients.jedis.args.ExpiryOption; import redis.clients.jedis.params.ScanParams; import redis.clients.jedis.resps.ScanResult; public class UnifiedJedisHashCommandsTest extends UnifiedJedisMockedTestBase { + private final byte[] bfoo = { 0x01, 0x02, 0x03, 0x04 }; + + private final byte[] bbar1 = { 0x05, 0x06, 0x07, 0x08, 0x0A }; + private final byte[] bbar2 = { 0x05, 0x06, 0x07, 0x08, 0x0B }; + private final byte[] bbar3 = { 0x05, 0x06, 0x07, 0x08, 0x0C }; + @Test public void testHdel() { String key = "hashKey"; @@ -764,4 +773,418 @@ public void testHvalsBinary() { verify(commandObjects).hvals(key); } + @Test + public void hexpire() { + String key = "hash"; + long seconds = 100; + String[] fields = { "one", "two", "three" }; + List expected = asList( 1L, 2L, 3L ); + + when(commandObjects.hexpire(key, seconds, fields)).thenReturn(listLongCommandObject); + when(commandExecutor.executeCommand(listLongCommandObject)).thenReturn(expected); + + assertThat(jedis.hexpire(key, seconds, fields), equalTo(expected)); + + verify(commandExecutor).executeCommand(listLongCommandObject); + verify(commandObjects).hexpire(key, seconds, fields); + } + + @Test + public void hexpireCondition() { + String key = "hash"; + long seconds = 100; + ExpiryOption condition = mock(ExpiryOption.class); + String[] fields = { "one", "two", "three" }; + List expected = asList( 1L, 2L, 3L ); + + when(commandObjects.hexpire(key, seconds, condition, fields)).thenReturn(listLongCommandObject); + when(commandExecutor.executeCommand(listLongCommandObject)).thenReturn(expected); + + assertThat(jedis.hexpire(key, seconds, condition, fields), equalTo(expected)); + + verify(commandExecutor).executeCommand(listLongCommandObject); + verify(commandObjects).hexpire(key, seconds, condition, fields); + } + + @Test + public void hpexpire() { + String key = "hash"; + long milliseconds = 10000; + String[] fields = { "one", "two", "three" }; + List expected = asList( 100L, 200L, 300L ); + + when(commandObjects.hpexpire(key, milliseconds, fields)).thenReturn(listLongCommandObject); + when(commandExecutor.executeCommand(listLongCommandObject)).thenReturn(expected); + + assertThat(jedis.hpexpire(key, milliseconds, fields), equalTo(expected)); + + verify(commandExecutor).executeCommand(listLongCommandObject); + verify(commandObjects).hpexpire(key, milliseconds, fields); + } + + @Test + public void hpexpireCondition() { + String key = "hash"; + long milliseconds = 10000; + ExpiryOption condition = mock(ExpiryOption.class); + String[] fields = { "one", "two", "three" }; + List expected = asList( 100L, 200L, 300L ); + + when(commandObjects.hpexpire(key, milliseconds, condition, fields)).thenReturn(listLongCommandObject); + when(commandExecutor.executeCommand(listLongCommandObject)).thenReturn(expected); + + assertThat(jedis.hpexpire(key, milliseconds, condition, fields), equalTo(expected)); + + verify(commandExecutor).executeCommand(listLongCommandObject); + verify(commandObjects).hpexpire(key, milliseconds, condition, fields); + } + + @Test + public void hexpireAt() { + String key = "hash"; + long seconds = 100; + String[] fields = { "one", "two", "three" }; + List expected = asList( 1L, 2L, 3L ); + + when(commandObjects.hexpireAt(key, seconds, fields)).thenReturn(listLongCommandObject); + when(commandExecutor.executeCommand(listLongCommandObject)).thenReturn(expected); + + assertThat(jedis.hexpireAt(key, seconds, fields), equalTo(expected)); + + verify(commandExecutor).executeCommand(listLongCommandObject); + verify(commandObjects).hexpireAt(key, seconds, fields); + } + + @Test + public void hexpireAtCondition() { + String key = "hash"; + long seconds = 100; + ExpiryOption condition = mock(ExpiryOption.class); + String[] fields = { "one", "two", "three" }; + List expected = asList( 1L, 2L, 3L ); + + when(commandObjects.hexpireAt(key, seconds, condition, fields)).thenReturn(listLongCommandObject); + when(commandExecutor.executeCommand(listLongCommandObject)).thenReturn(expected); + + assertThat(jedis.hexpireAt(key, seconds, condition, fields), equalTo(expected)); + + verify(commandExecutor).executeCommand(listLongCommandObject); + verify(commandObjects).hexpireAt(key, seconds, condition, fields); + } + + @Test + public void hpexpireAt() { + String key = "hash"; + long milliseconds = 10000; + String[] fields = { "one", "two", "three" }; + List expected = asList( 1L, 2L, 3L ); + + when(commandObjects.hpexpireAt(key, milliseconds, fields)).thenReturn(listLongCommandObject); + when(commandExecutor.executeCommand(listLongCommandObject)).thenReturn(expected); + + assertThat(jedis.hpexpireAt(key, milliseconds, fields), equalTo(expected)); + + verify(commandExecutor).executeCommand(listLongCommandObject); + verify(commandObjects).hpexpireAt(key, milliseconds, fields); + } + + @Test + public void hpexpireAtCondition() { + String key = "hash"; + long milliseconds = 100; + ExpiryOption condition = mock(ExpiryOption.class); + String[] fields = { "one", "two", "three" }; + List expected = asList( 1L, 2L, 3L ); + + when(commandObjects.hpexpireAt(key, milliseconds, condition, fields)).thenReturn(listLongCommandObject); + when(commandExecutor.executeCommand(listLongCommandObject)).thenReturn(expected); + + assertThat(jedis.hpexpireAt(key, milliseconds, condition, fields), equalTo(expected)); + + verify(commandExecutor).executeCommand(listLongCommandObject); + verify(commandObjects).hpexpireAt(key, milliseconds, condition, fields); + } + + @Test + public void hexpireTime() { + String key = "hash"; + String[] fields = { "one", "two", "three" }; + List expected = asList( 10L, 20L, 30L ); + + when(commandObjects.hexpireTime(key, fields)).thenReturn(listLongCommandObject); + when(commandExecutor.executeCommand(listLongCommandObject)).thenReturn(expected); + + assertThat(jedis.hexpireTime(key, fields), equalTo(expected)); + + verify(commandExecutor).executeCommand(listLongCommandObject); + verify(commandObjects).hexpireTime(key, fields); + } + + @Test + public void hpexpireTime() { + String key = "hash"; + String[] fields = { "one", "two", "three" }; + List expected = asList( 1000L, 2000L, 3000L ); + + when(commandObjects.hpexpireTime(key, fields)).thenReturn(listLongCommandObject); + when(commandExecutor.executeCommand(listLongCommandObject)).thenReturn(expected); + + assertThat(jedis.hpexpireTime(key, fields), equalTo(expected)); + + verify(commandExecutor).executeCommand(listLongCommandObject); + verify(commandObjects).hpexpireTime(key, fields); + } + + @Test + public void httl() { + String key = "hash"; + String[] fields = { "one", "two", "three" }; + List expected = asList( 10L, 20L, 30L ); + + when(commandObjects.httl(key, fields)).thenReturn(listLongCommandObject); + when(commandExecutor.executeCommand(listLongCommandObject)).thenReturn(expected); + + assertThat(jedis.httl(key, fields), equalTo(expected)); + + verify(commandExecutor).executeCommand(listLongCommandObject); + verify(commandObjects).httl(key, fields); + } + + @Test + public void hpttl() { + String key = "hash"; + String[] fields = { "one", "two", "three" }; + List expected = asList( 1000L, 2000L, 3000L ); + + when(commandObjects.hpttl(key, fields)).thenReturn(listLongCommandObject); + when(commandExecutor.executeCommand(listLongCommandObject)).thenReturn(expected); + + assertThat(jedis.hpttl(key, fields), equalTo(expected)); + + verify(commandExecutor).executeCommand(listLongCommandObject); + verify(commandObjects).hpttl(key, fields); + } + + @Test + public void hpersist() { + String key = "hash"; + String[] fields = { "one", "two", "three" }; + List expected = asList( 1L, 2L, 3L ); + + when(commandObjects.hpersist(key, fields)).thenReturn(listLongCommandObject); + when(commandExecutor.executeCommand(listLongCommandObject)).thenReturn(expected); + + assertThat(jedis.hpersist(key, fields), equalTo(expected)); + + verify(commandExecutor).executeCommand(listLongCommandObject); + verify(commandObjects).hpersist(key, fields); + } + + @Test + public void hexpireBinary() { + byte[] key = bfoo; + long seconds = 100; + byte[][] fields = { bbar1, bbar2, bbar3 }; + List expected = asList( 1L, 2L, 3L ); + + when(commandObjects.hexpire(key, seconds, fields)).thenReturn(listLongCommandObject); + when(commandExecutor.executeCommand(listLongCommandObject)).thenReturn(expected); + + assertThat(jedis.hexpire(key, seconds, fields), equalTo(expected)); + + verify(commandExecutor).executeCommand(listLongCommandObject); + verify(commandObjects).hexpire(key, seconds, fields); + } + + @Test + public void hexpireConditionBinary() { + byte[] key = bfoo; + long seconds = 100; + ExpiryOption condition = mock(ExpiryOption.class); + byte[][] fields = { bbar1, bbar2, bbar3 }; + List expected = asList( 1L, 2L, 3L ); + + when(commandObjects.hexpire(key, seconds, condition, fields)).thenReturn(listLongCommandObject); + when(commandExecutor.executeCommand(listLongCommandObject)).thenReturn(expected); + + assertThat(jedis.hexpire(key, seconds, condition, fields), equalTo(expected)); + + verify(commandExecutor).executeCommand(listLongCommandObject); + verify(commandObjects).hexpire(key, seconds, condition, fields); + } + + @Test + public void hpexpireBinary() { + byte[] key = bfoo; + long milliseconds = 10000; + byte[][] fields = { bbar1, bbar2, bbar3 }; + List expected = asList( 100L, 200L, 300L ); + + when(commandObjects.hpexpire(key, milliseconds, fields)).thenReturn(listLongCommandObject); + when(commandExecutor.executeCommand(listLongCommandObject)).thenReturn(expected); + + assertThat(jedis.hpexpire(key, milliseconds, fields), equalTo(expected)); + + verify(commandExecutor).executeCommand(listLongCommandObject); + verify(commandObjects).hpexpire(key, milliseconds, fields); + } + + @Test + public void hpexpireConditionBinary() { + byte[] key = bfoo; + long milliseconds = 10000; + ExpiryOption condition = mock(ExpiryOption.class); + byte[][] fields = { bbar1, bbar2, bbar3 }; + List expected = asList( 100L, 200L, 300L ); + + when(commandObjects.hpexpire(key, milliseconds, condition, fields)).thenReturn(listLongCommandObject); + when(commandExecutor.executeCommand(listLongCommandObject)).thenReturn(expected); + + assertThat(jedis.hpexpire(key, milliseconds, condition, fields), equalTo(expected)); + + verify(commandExecutor).executeCommand(listLongCommandObject); + verify(commandObjects).hpexpire(key, milliseconds, condition, fields); + } + + @Test + public void hexpireAtBinary() { + byte[] key = bfoo; + long seconds = 100; + byte[][] fields = { bbar1, bbar2, bbar3 }; + List expected = asList( 1L, 2L, 3L ); + + when(commandObjects.hexpireAt(key, seconds, fields)).thenReturn(listLongCommandObject); + when(commandExecutor.executeCommand(listLongCommandObject)).thenReturn(expected); + + assertThat(jedis.hexpireAt(key, seconds, fields), equalTo(expected)); + + verify(commandExecutor).executeCommand(listLongCommandObject); + verify(commandObjects).hexpireAt(key, seconds, fields); + } + + @Test + public void hexpireAtConditionBinary() { + byte[] key = bfoo; + long seconds = 100; + ExpiryOption condition = mock(ExpiryOption.class); + byte[][] fields = { bbar1, bbar2, bbar3 }; + List expected = asList( 1L, 2L, 3L ); + + when(commandObjects.hexpireAt(key, seconds, condition, fields)).thenReturn(listLongCommandObject); + when(commandExecutor.executeCommand(listLongCommandObject)).thenReturn(expected); + + assertThat(jedis.hexpireAt(key, seconds, condition, fields), equalTo(expected)); + + verify(commandExecutor).executeCommand(listLongCommandObject); + verify(commandObjects).hexpireAt(key, seconds, condition, fields); + } + + @Test + public void hpexpireAtBinary() { + byte[] key = bfoo; + long milliseconds = 10000; + byte[][] fields = { bbar1, bbar2, bbar3 }; + List expected = asList( 1L, 2L, 3L ); + + when(commandObjects.hpexpireAt(key, milliseconds, fields)).thenReturn(listLongCommandObject); + when(commandExecutor.executeCommand(listLongCommandObject)).thenReturn(expected); + + assertThat(jedis.hpexpireAt(key, milliseconds, fields), equalTo(expected)); + + verify(commandExecutor).executeCommand(listLongCommandObject); + verify(commandObjects).hpexpireAt(key, milliseconds, fields); + } + + @Test + public void hpexpireAtConditionBinary() { + byte[] key = bfoo; + long milliseconds = 100; + ExpiryOption condition = mock(ExpiryOption.class); + byte[][] fields = { bbar1, bbar2, bbar3 }; + List expected = asList( 1L, 2L, 3L ); + + when(commandObjects.hpexpireAt(key, milliseconds, condition, fields)).thenReturn(listLongCommandObject); + when(commandExecutor.executeCommand(listLongCommandObject)).thenReturn(expected); + + assertThat(jedis.hpexpireAt(key, milliseconds, condition, fields), equalTo(expected)); + + verify(commandExecutor).executeCommand(listLongCommandObject); + verify(commandObjects).hpexpireAt(key, milliseconds, condition, fields); + } + + @Test + public void hexpireTimeBinary() { + byte[] key = bfoo; + byte[][] fields = { bbar1, bbar2, bbar3 }; + List expected = asList( 10L, 20L, 30L ); + + when(commandObjects.hexpireTime(key, fields)).thenReturn(listLongCommandObject); + when(commandExecutor.executeCommand(listLongCommandObject)).thenReturn(expected); + + assertThat(jedis.hexpireTime(key, fields), equalTo(expected)); + + verify(commandExecutor).executeCommand(listLongCommandObject); + verify(commandObjects).hexpireTime(key, fields); + } + + @Test + public void hpexpireTimeBinary() { + byte[] key = bfoo; + byte[][] fields = { bbar1, bbar2, bbar3 }; + List expected = asList( 1000L, 2000L, 3000L ); + + when(commandObjects.hpexpireTime(key, fields)).thenReturn(listLongCommandObject); + when(commandExecutor.executeCommand(listLongCommandObject)).thenReturn(expected); + + assertThat(jedis.hpexpireTime(key, fields), equalTo(expected)); + + verify(commandExecutor).executeCommand(listLongCommandObject); + verify(commandObjects).hpexpireTime(key, fields); + } + + @Test + public void httlBinary() { + byte[] key = bfoo; + byte[][] fields = { bbar1, bbar2, bbar3 }; + List expected = asList( 10L, 20L, 30L ); + + when(commandObjects.httl(key, fields)).thenReturn(listLongCommandObject); + when(commandExecutor.executeCommand(listLongCommandObject)).thenReturn(expected); + + assertThat(jedis.httl(key, fields), equalTo(expected)); + + verify(commandExecutor).executeCommand(listLongCommandObject); + verify(commandObjects).httl(key, fields); + } + + @Test + public void hpttlBinary() { + byte[] key = bfoo; + byte[][] fields = { bbar1, bbar2, bbar3 }; + List expected = asList( 1000L, 2000L, 3000L ); + + when(commandObjects.hpttl(key, fields)).thenReturn(listLongCommandObject); + when(commandExecutor.executeCommand(listLongCommandObject)).thenReturn(expected); + + assertThat(jedis.hpttl(key, fields), equalTo(expected)); + + verify(commandExecutor).executeCommand(listLongCommandObject); + verify(commandObjects).hpttl(key, fields); + } + + @Test + public void hpersistBinary() { + byte[] key = bfoo; + byte[][] fields = { bbar1, bbar2, bbar3 }; + List expected = asList( 1L, 2L, 3L ); + + when(commandObjects.hpersist(key, fields)).thenReturn(listLongCommandObject); + when(commandExecutor.executeCommand(listLongCommandObject)).thenReturn(expected); + + assertThat(jedis.hpersist(key, fields), equalTo(expected)); + + verify(commandExecutor).executeCommand(listLongCommandObject); + verify(commandObjects).hpersist(key, fields); + } + } From 32d69ad3bfe219988a177f0125026fa721d249b7 Mon Sep 17 00:00:00 2001 From: M Sazzadul Hoque <7600764+sazzad16@users.noreply.github.com> Date: Fri, 7 Jun 2024 14:57:21 +0600 Subject: [PATCH 2/4] Disable Redis Graph tests (#3856) We use redis-stack-server image to test all module commands. RedisGraph module has been removed from that image. --- .../java/redis/clients/jedis/modules/graph/GraphAPITest.java | 2 +- .../redis/clients/jedis/modules/graph/GraphPipelineTest.java | 1 + .../redis/clients/jedis/modules/graph/GraphTransactionTest.java | 1 + .../java/redis/clients/jedis/modules/graph/GraphValuesTest.java | 1 + 4 files changed, 4 insertions(+), 1 deletion(-) diff --git a/src/test/java/redis/clients/jedis/modules/graph/GraphAPITest.java b/src/test/java/redis/clients/jedis/modules/graph/GraphAPITest.java index 46b135070c..6b1011829b 100644 --- a/src/test/java/redis/clients/jedis/modules/graph/GraphAPITest.java +++ b/src/test/java/redis/clients/jedis/modules/graph/GraphAPITest.java @@ -22,9 +22,9 @@ import redis.clients.jedis.graph.ResultSet; import redis.clients.jedis.graph.Statistics; import redis.clients.jedis.graph.entities.*; - import redis.clients.jedis.modules.RedisModuleCommandsTestBase; +@org.junit.Ignore @RunWith(Parameterized.class) public class GraphAPITest extends RedisModuleCommandsTestBase { diff --git a/src/test/java/redis/clients/jedis/modules/graph/GraphPipelineTest.java b/src/test/java/redis/clients/jedis/modules/graph/GraphPipelineTest.java index f69dd06712..e021c0252c 100644 --- a/src/test/java/redis/clients/jedis/modules/graph/GraphPipelineTest.java +++ b/src/test/java/redis/clients/jedis/modules/graph/GraphPipelineTest.java @@ -26,6 +26,7 @@ import redis.clients.jedis.graph.entities.Property; import redis.clients.jedis.modules.RedisModuleCommandsTestBase; +@org.junit.Ignore @RunWith(Parameterized.class) public class GraphPipelineTest extends RedisModuleCommandsTestBase { diff --git a/src/test/java/redis/clients/jedis/modules/graph/GraphTransactionTest.java b/src/test/java/redis/clients/jedis/modules/graph/GraphTransactionTest.java index 9a7a8e502c..d33477dfcd 100644 --- a/src/test/java/redis/clients/jedis/modules/graph/GraphTransactionTest.java +++ b/src/test/java/redis/clients/jedis/modules/graph/GraphTransactionTest.java @@ -23,6 +23,7 @@ import redis.clients.jedis.graph.entities.Property; import redis.clients.jedis.modules.RedisModuleCommandsTestBase; +@org.junit.Ignore @RunWith(Parameterized.class) public class GraphTransactionTest extends RedisModuleCommandsTestBase { diff --git a/src/test/java/redis/clients/jedis/modules/graph/GraphValuesTest.java b/src/test/java/redis/clients/jedis/modules/graph/GraphValuesTest.java index ea9c6a7799..3a199a1464 100644 --- a/src/test/java/redis/clients/jedis/modules/graph/GraphValuesTest.java +++ b/src/test/java/redis/clients/jedis/modules/graph/GraphValuesTest.java @@ -12,6 +12,7 @@ import redis.clients.jedis.graph.ResultSet; import redis.clients.jedis.modules.RedisModuleCommandsTestBase; +@org.junit.Ignore @RunWith(Parameterized.class) public class GraphValuesTest extends RedisModuleCommandsTestBase { From 36668bcb0e746314bb94db9b133c878fbfbfa093 Mon Sep 17 00:00:00 2001 From: M Sazzadul Hoque <7600764+sazzad16@users.noreply.github.com> Date: Fri, 7 Jun 2024 16:07:53 +0600 Subject: [PATCH 3/4] Deprecate unused Set builders (#3857) --- src/main/java/redis/clients/jedis/BuilderFactory.java | 2 ++ src/main/java/redis/clients/jedis/CommandObjects.java | 4 ---- 2 files changed, 2 insertions(+), 4 deletions(-) diff --git a/src/main/java/redis/clients/jedis/BuilderFactory.java b/src/main/java/redis/clients/jedis/BuilderFactory.java index 26d5b5c384..18eeb64afd 100644 --- a/src/main/java/redis/clients/jedis/BuilderFactory.java +++ b/src/main/java/redis/clients/jedis/BuilderFactory.java @@ -661,6 +661,7 @@ public String toString() { } }; + @Deprecated public static final Builder> TUPLE_ZSET = new Builder>() { @Override @SuppressWarnings("unchecked") @@ -683,6 +684,7 @@ public String toString() { } }; + @Deprecated public static final Builder> TUPLE_ZSET_RESP3 = new Builder>() { @Override @SuppressWarnings("unchecked") diff --git a/src/main/java/redis/clients/jedis/CommandObjects.java b/src/main/java/redis/clients/jedis/CommandObjects.java index 754c25cf35..efaf19397c 100644 --- a/src/main/java/redis/clients/jedis/CommandObjects.java +++ b/src/main/java/redis/clients/jedis/CommandObjects.java @@ -2150,10 +2150,6 @@ public final CommandObject>> bzmpop(double timeout, private Builder> getTupleListBuilder() { return protocol == RedisProtocol.RESP3 ? BuilderFactory.TUPLE_LIST_RESP3 : BuilderFactory.TUPLE_LIST; } - - private Builder> getTupleSetBuilder() { - return protocol == RedisProtocol.RESP3 ? BuilderFactory.TUPLE_ZSET_RESP3 : BuilderFactory.TUPLE_ZSET; - } // Sorted Set commands // Geo commands From 4ca869e9c4c8a4f4706a8f8bae916f4e578253bc Mon Sep 17 00:00:00 2001 From: M Sazzadul Hoque <7600764+sazzad16@users.noreply.github.com> Date: Fri, 7 Jun 2024 16:32:07 +0600 Subject: [PATCH 4/4] Address change in JSON.GET command without path (#3858) --- .../redis/clients/jedis/CommandObjects.java | 3 +-- .../CommandObjectsJsonCommandsTest.java | 27 +------------------ .../jedis/modules/json/RedisJsonV2Test.java | 25 ----------------- 3 files changed, 2 insertions(+), 53 deletions(-) diff --git a/src/main/java/redis/clients/jedis/CommandObjects.java b/src/main/java/redis/clients/jedis/CommandObjects.java index efaf19397c..7226a014a7 100644 --- a/src/main/java/redis/clients/jedis/CommandObjects.java +++ b/src/main/java/redis/clients/jedis/CommandObjects.java @@ -3621,8 +3621,7 @@ public final CommandObject jsonMerge(String key, Path path, Object pojo) } public final CommandObject jsonGet(String key) { - return new CommandObject<>(commandArguments(JsonCommand.GET).key(key), - protocol != RedisProtocol.RESP3 ? JSON_GENERIC_OBJECT : JsonBuilderFactory.JSON_OBJECT); + return new CommandObject<>(commandArguments(JsonCommand.GET).key(key), JSON_GENERIC_OBJECT); } @Deprecated diff --git a/src/test/java/redis/clients/jedis/commands/commandobjects/CommandObjectsJsonCommandsTest.java b/src/test/java/redis/clients/jedis/commands/commandobjects/CommandObjectsJsonCommandsTest.java index a416be2103..6e24cdd322 100644 --- a/src/test/java/redis/clients/jedis/commands/commandobjects/CommandObjectsJsonCommandsTest.java +++ b/src/test/java/redis/clients/jedis/commands/commandobjects/CommandObjectsJsonCommandsTest.java @@ -235,9 +235,7 @@ public void testJsonMergeOldPath() { @Test @Deprecated - public void testJsonGenericObjectResp2() { - assumeThat(protocol, not(equalTo(RedisProtocol.RESP3))); - + public void testJsonGenericObject() { String key = "user:1000"; Person person = new Person(); @@ -256,29 +254,6 @@ public void testJsonGenericObjectResp2() { assertThat(resultMap, hasEntry("age", 30.0)); } - @Test - @Deprecated - public void testJsonGenericObjectResp3() { - assumeThat(protocol, equalTo(RedisProtocol.RESP3)); - - String key = "user:1000"; - - Person person = new Person("John Doe", 30); - - String setResult = exec(commandObjects.jsonSet(key, Path.ROOT_PATH, person)); - assertThat(setResult, equalTo("OK")); - - Object getRoot = exec(commandObjects.jsonGet(key)); - assertThat(getRoot, instanceOf(JSONArray.class)); - - JSONObject expectedPerson = new JSONObject(); - expectedPerson.put("name", "John Doe"); - expectedPerson.put("age", 30); - - JSONArray expected = new JSONArray().put(expectedPerson); - assertThat(getRoot, jsonEquals(expected)); - } - @Test @Deprecated public void testJsonGetWithClass() { diff --git a/src/test/java/redis/clients/jedis/modules/json/RedisJsonV2Test.java b/src/test/java/redis/clients/jedis/modules/json/RedisJsonV2Test.java index 6168c2e2de..688e64a12e 100644 --- a/src/test/java/redis/clients/jedis/modules/json/RedisJsonV2Test.java +++ b/src/test/java/redis/clients/jedis/modules/json/RedisJsonV2Test.java @@ -50,8 +50,6 @@ public void setUp() { @Test public void basicSetGetShouldSucceed() { - Assume.assumeFalse(protocol == RedisProtocol.RESP3); - // naive set with a path jsonV2.jsonSetWithEscape("null", ROOT_PATH, (Object) null); assertJsonArrayEquals(jsonArray((Object) null), jsonV2.jsonGet("null", ROOT_PATH)); @@ -72,29 +70,6 @@ public void basicSetGetShouldSucceed() { assertJsonArrayEquals(jsonArray("strung"), jsonV2.jsonGet("obj", p)); } - @Test - public void basicSetGetShouldSucceedResp3() { - Assume.assumeTrue(protocol == RedisProtocol.RESP3); - - // naive set with a path - jsonV2.jsonSetWithEscape("null", ROOT_PATH, (Object) null); - assertJsonArrayEquals(jsonArray((Object) null), jsonV2.jsonGet("null", ROOT_PATH)); - - // real scalar value and no path - jsonV2.jsonSetWithEscape("str", "strong"); - assertJsonArrayEquals(jsonArray("strong"), jsonV2.jsonGet("str")); - - // a slightly more complex object - IRLObject obj = new IRLObject(); - jsonV2.jsonSetWithEscape("obj", obj); - assertJsonArrayEquals(jsonArray(new JSONObject(gson.toJson(obj))), jsonV2.jsonGet("obj")); - - // check an update - Path2 p = Path2.of(".str"); - jsonV2.jsonSet("obj", p, gson.toJson("strung")); - assertJsonArrayEquals(jsonArray("strung"), jsonV2.jsonGet("obj", p)); - } - @Test public void setExistingPathOnlyIfExistsShouldSucceed() { jsonV2.jsonSetWithEscape("obj", new IRLObject());