Skip to content

Commit

Permalink
Added examples in documentation. Minor format RedisClientTest.
Browse files Browse the repository at this point in the history
  • Loading branch information
SanHalacogluImproving committed Feb 23, 2024
1 parent 81089cf commit 585f18c
Show file tree
Hide file tree
Showing 2 changed files with 73 additions and 0 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,11 @@ public interface GenericBaseCommands {
* @return <code>true</code> if the timeout was set. <code>false</code> if the timeout was not
* set. e.g. <code>key</code> doesn't exist, or operation skipped due to the provided
* arguments.
* @example
* <pre>
* Boolean isSet = client.expire("my_key", 60).get()
* assert isSet //Indicates that a timeout of 60 seconds has been set for "my_key."
* </pre>
*/
CompletableFuture<Boolean> expire(String key, long seconds);

Expand All @@ -41,6 +46,11 @@ public interface GenericBaseCommands {
* @return <code>true</code> if the timeout was set. <code>false</code> if the timeout was not
* set. e.g. <code>key</code> doesn't exist, or operation skipped due to the provided
* arguments.
* @example
* <pre>
* Boolean isSet = client.expire("my_key", 60, ExpireOptions.HAS_NO_EXPIRY).get()
* assert isSet //Indicates that a timeout of 60 seconds has been set for "my_key."
* </pre>
*/
CompletableFuture<Boolean> expire(String key, long seconds, ExpireOptions expireOptions);

Expand All @@ -58,6 +68,11 @@ public interface GenericBaseCommands {
* @return <code>true</code> if the timeout was set. <code>false</code> if the timeout was not
* set. e.g. <code>key</code> doesn't exist, or operation skipped due to the provided
* arguments.
* @example
* <pre>
* Boolean isSet = client.expireAt("my_key", 1672531200).get()
* assert isSet
* </pre>
*/
CompletableFuture<Boolean> expireAt(String key, long unixSeconds);

Expand All @@ -76,6 +91,11 @@ public interface GenericBaseCommands {
* @return <code>true</code> if the timeout was set. <code>false</code> if the timeout was not
* set. e.g. <code>key</code> doesn't exist, or operation skipped due to the provided
* arguments.
* @example
* <pre>
* Boolean isSet = client.expireAt("my_key", 1672531200, ExpireOptions.HasNoExpiry).get()
* assert isSet
* </pre>
*/
CompletableFuture<Boolean> expireAt(String key, long unixSeconds, ExpireOptions expireOptions);

Expand All @@ -92,6 +112,11 @@ public interface GenericBaseCommands {
* @return <code>true</code> if the timeout was set. <code>false</code> if the timeout was not
* set. e.g. <code>key</code> doesn't exist, or operation skipped due to the provided
* arguments.
* @example
* <pre>
* Boolean isSet = client.pexpire("my_key", 60000).get()
* assert isSet
* </pre>
*/
CompletableFuture<Boolean> pexpire(String key, long milliseconds);

Expand All @@ -109,6 +134,11 @@ public interface GenericBaseCommands {
* @return <code>true</code> if the timeout was set. <code>false</code> if the timeout was not
* set. e.g. <code>key</code> doesn't exist, or operation skipped due to the provided
* arguments.
* @example
* <pre>
* Boolean isSet = client.pexpire("my_key", 60000, ExpireOptions.HasNoExpiry).get()
* assert isSet
* </pre>
*/
CompletableFuture<Boolean> pexpire(String key, long milliseconds, ExpireOptions expireOptions);

Expand All @@ -126,6 +156,11 @@ public interface GenericBaseCommands {
* @return <code>true</code> if the timeout was set. <code>false</code> if the timeout was not
* set. e.g. <code>key</code> doesn't exist, or operation skipped due to the provided
* arguments.
* @example
* <pre>
* Boolean isSet = client.pexpireAt("my_key", 1672531200000).get()
* assert isSet
* </pre>
*/
CompletableFuture<Boolean> pexpireAt(String key, long unixMilliseconds);

Expand All @@ -144,6 +179,11 @@ public interface GenericBaseCommands {
* @return <code>true</code> if the timeout was set. <code>false</code> if the timeout was not
* set. e.g. <code>key</code> doesn't exist, or operation skipped due to the provided
* arguments.
* @example
* <pre>
* Boolean isSet = client.pexpireAt("my_key", 1672531200000, ExpireOptions.HasNoExpiry).get()
* assert isSet
* </pre>
*/
CompletableFuture<Boolean> pexpireAt(
String key, long unixMilliseconds, ExpireOptions expireOptions);
Expand All @@ -155,6 +195,13 @@ CompletableFuture<Boolean> pexpireAt(
* @param key The <code>key</code> to return its timeout.
* @return TTL in seconds, -2 if <code>key</code> does not exist, or -1 if <code>key</code> exists
* but has no associated expire.
* @example
* <pre>
* Long timeRemaining = client.ttl("my_key").get()
* assert timeRemaining == 3600L //Indicates that "my_key" has a remaining time to live of 3600 seconds.
* Long timeRemaining = client.ttl("nonexistent_key").get()
* assert timeRemaining == -2L //Returns -2 for a non-existing key.
* </pre>
*/
CompletableFuture<Long> ttl(String key);
}
26 changes: 26 additions & 0 deletions java/client/src/test/java/glide/api/RedisClientTest.java
Original file line number Diff line number Diff line change
Expand Up @@ -217,8 +217,11 @@ public void expire_returns_success() {
String key = "testKey";
long seconds = 10L;
String[] arguments = new String[] {key, Long.toString(seconds)};

CompletableFuture<Boolean> testResponse = mock(CompletableFuture.class);
when(testResponse.get()).thenReturn(true);

// match on protobuf request
when(commandManager.<Boolean>submitNewCommand(eq(Expire), eq(arguments), any()))
.thenReturn(testResponse);

Expand All @@ -237,8 +240,11 @@ public void expire_with_expireOptions_returns_success() {
String key = "testKey";
long seconds = 10L;
String[] arguments = new String[] {key, Long.toString(seconds), "NX"};

CompletableFuture<Boolean> testResponse = mock(CompletableFuture.class);
when(testResponse.get()).thenReturn(false);

// match on protobuf request
when(commandManager.<Boolean>submitNewCommand(eq(Expire), eq(arguments), any()))
.thenReturn(testResponse);

Expand All @@ -257,8 +263,11 @@ public void expireAt_returns_success() {
String key = "testKey";
long unixSeconds = 100000L;
String[] arguments = new String[] {key, Long.toString(unixSeconds)};

CompletableFuture<Boolean> testResponse = mock(CompletableFuture.class);
when(testResponse.get()).thenReturn(true);

// match on protobuf request
when(commandManager.<Boolean>submitNewCommand(eq(ExpireAt), eq(arguments), any()))
.thenReturn(testResponse);

Expand All @@ -277,8 +286,11 @@ public void expireAt_with_expireOptions_returns_success() {
String key = "testKey";
long unixSeconds = 100000L;
String[] arguments = new String[] {key, Long.toString(unixSeconds), "XX"};

CompletableFuture<Boolean> testResponse = mock(CompletableFuture.class);
when(testResponse.get()).thenReturn(false);

// match on protobuf request
when(commandManager.<Boolean>submitNewCommand(eq(ExpireAt), eq(arguments), any()))
.thenReturn(testResponse);

Expand All @@ -298,8 +310,11 @@ public void pexpire_returns_success() {
String key = "testKey";
long milliseconds = 5L;
String[] arguments = new String[] {key, Long.toString(milliseconds)};

CompletableFuture<Boolean> testResponse = mock(CompletableFuture.class);
when(testResponse.get()).thenReturn(true);

// match on protobuf request
when(commandManager.<Boolean>submitNewCommand(eq(PExpire), eq(arguments), any()))
.thenReturn(testResponse);

Expand All @@ -318,8 +333,11 @@ public void pexpire_with_expireOptions_returns_success() {
String key = "testKey";
long milliseconds = 5L;
String[] arguments = new String[] {key, Long.toString(milliseconds), "LT"};

CompletableFuture<Boolean> testResponse = mock(CompletableFuture.class);
when(testResponse.get()).thenReturn(false);

// match on protobuf request
when(commandManager.<Boolean>submitNewCommand(eq(PExpire), eq(arguments), any()))
.thenReturn(testResponse);

Expand All @@ -339,8 +357,11 @@ public void pexpireAt_returns_success() {
String key = "testKey";
long unixMilliseconds = 999999L;
String[] arguments = new String[] {key, Long.toString(unixMilliseconds)};

CompletableFuture<Boolean> testResponse = mock(CompletableFuture.class);
when(testResponse.get()).thenReturn(true);

// match on protobuf request
when(commandManager.<Boolean>submitNewCommand(eq(PExpireAt), eq(arguments), any()))
.thenReturn(testResponse);

Expand All @@ -359,8 +380,11 @@ public void pexpireAt_with_expireOptions_returns_success() {
String key = "testKey";
long unixMilliseconds = 999999L;
String[] arguments = new String[] {key, Long.toString(unixMilliseconds), "GT"};

CompletableFuture<Boolean> testResponse = mock(CompletableFuture.class);
when(testResponse.get()).thenReturn(false);

// match on protobuf request
when(commandManager.<Boolean>submitNewCommand(eq(PExpireAt), eq(arguments), any()))
.thenReturn(testResponse);

Expand All @@ -382,6 +406,8 @@ public void ttl_returns_success() {

CompletableFuture<Long> testResponse = mock(CompletableFuture.class);
when(testResponse.get()).thenReturn(ttl);

// match on protobuf request
when(commandManager.<Long>submitNewCommand(eq(TTL), eq(new String[] {key}), any()))
.thenReturn(testResponse);

Expand Down

0 comments on commit 585f18c

Please sign in to comment.