forked from valkey-io/valkey-glide
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
* Update CI Signed-off-by: Yury-Fridlyand <[email protected]> * Add a test for a command. Signed-off-by: Yury-Fridlyand <[email protected]> * clean up Signed-off-by: Yury-Fridlyand <[email protected]> * minor fix Signed-off-by: Yury-Fridlyand <[email protected]> * Address PR feedback. Signed-off-by: Yury-Fridlyand <[email protected]> * spotless Signed-off-by: Yury-Fridlyand <[email protected]> --------- Signed-off-by: Yury-Fridlyand <[email protected]>
- Loading branch information
1 parent
9345634
commit 242805d
Showing
8 changed files
with
149 additions
and
9 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,68 @@ | ||
plugins { | ||
id 'java-library' | ||
} | ||
|
||
repositories { | ||
mavenCentral() | ||
} | ||
|
||
dependencies { | ||
// client | ||
implementation project(':client') | ||
|
||
// lombok | ||
testCompileOnly 'org.projectlombok:lombok:1.18.30' | ||
testAnnotationProcessor 'org.projectlombok:lombok:1.18.30' | ||
|
||
// junit | ||
testImplementation 'org.junit.jupiter:junit-jupiter:5.6.2' | ||
testImplementation 'org.mockito:mockito-junit-jupiter:3.12.4' | ||
} | ||
|
||
tasks.register('stopAllAfterTests', Exec) { | ||
workingDir "${project.rootDir}/../utils" | ||
commandLine 'python3', 'cluster_manager.py', 'stop', '--prefix', 'redis-cluster', '--keep-folder' | ||
} | ||
|
||
// We need to call for stop before and after the test, but gradle doesn't support executing a task | ||
// twice. So there are two identical tasks with different names. | ||
// We need to call for stop in case if previous test run was interrupted/crashed and didn't stop. | ||
tasks.register('stopAllBeforeTests', Exec) { | ||
workingDir "${project.rootDir}/../utils" | ||
commandLine 'python3', 'cluster_manager.py', 'stop', '--prefix', 'redis-cluster' | ||
ignoreExitValue true // ignore fail if servers are stopped before | ||
} | ||
|
||
// delete dirs if stop failed due to https://github.com/aws/glide-for-redis/issues/849 | ||
tasks.register('clearDirs', Delete) { | ||
delete "${project.rootDir}/../utils/clusters" | ||
} | ||
|
||
tasks.register('startCluster', Exec) { | ||
workingDir "${project.rootDir}/../utils" | ||
commandLine 'python3', 'cluster_manager.py', 'start', '--cluster-mode', '-p', '7000', '7001', '7002', '7003', '7004', '7005' | ||
} | ||
|
||
tasks.register('startStandalone', Exec) { | ||
workingDir "${project.rootDir}/../utils" | ||
commandLine 'python3', 'cluster_manager.py', 'start', '-p', '6380', '-r', '0' | ||
} | ||
|
||
test.dependsOn 'stopAllBeforeTests' | ||
stopAllBeforeTests.finalizedBy 'clearDirs' | ||
clearDirs.finalizedBy 'startStandalone' | ||
clearDirs.finalizedBy 'startCluster' | ||
test.finalizedBy 'stopAllAfterTests' | ||
test.dependsOn ':client:buildRustRelease' | ||
|
||
tasks.withType(Test) { | ||
systemProperty 'test.redis.standalone.port', '6380' | ||
systemProperty 'test.redis.cluster.port', '7000' | ||
|
||
testLogging { | ||
exceptionFormat "full" | ||
events "started", "skipped", "passed", "failed" | ||
showStandardStreams true | ||
} | ||
jvmArgs "-Djava.library.path=${project.rootDir}/target/release" | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,38 @@ | ||
package glide; | ||
|
||
import glide.api.RedisClient; | ||
import glide.api.models.configuration.NodeAddress; | ||
import glide.api.models.configuration.RedisClientConfiguration; | ||
import java.util.concurrent.TimeUnit; | ||
import lombok.SneakyThrows; | ||
import org.junit.jupiter.api.AfterAll; | ||
import org.junit.jupiter.api.BeforeAll; | ||
import org.junit.jupiter.api.Test; | ||
|
||
public class CommandTests { | ||
|
||
private static RedisClient regularClient = null; | ||
|
||
@BeforeAll | ||
@SneakyThrows | ||
public static void init() { | ||
regularClient = | ||
RedisClient.CreateClient( | ||
RedisClientConfiguration.builder() | ||
.address(NodeAddress.builder().port(TestConfiguration.STANDALONE_PORT).build()) | ||
.build()) | ||
.get(10, TimeUnit.SECONDS); | ||
} | ||
|
||
@AfterAll | ||
@SneakyThrows | ||
public static void deinit() { | ||
regularClient.close(); | ||
} | ||
|
||
@Test | ||
@SneakyThrows | ||
public void custom_command_info() { | ||
regularClient.customCommand(new String[] {"info"}).get(10, TimeUnit.SECONDS); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,25 @@ | ||
package glide; | ||
|
||
import glide.api.RedisClient; | ||
import glide.api.models.configuration.NodeAddress; | ||
import glide.api.models.configuration.RedisClientConfiguration; | ||
import java.util.concurrent.TimeUnit; | ||
import lombok.SneakyThrows; | ||
import org.junit.jupiter.api.Test; | ||
|
||
public class ConnectionTests { | ||
|
||
@Test | ||
@SneakyThrows | ||
public void basic_client() { | ||
var regularClient = | ||
RedisClient.CreateClient( | ||
RedisClientConfiguration.builder() | ||
.address(NodeAddress.builder().port(TestConfiguration.STANDALONE_PORT).build()) | ||
.build()) | ||
.get(10, TimeUnit.SECONDS); | ||
regularClient.close(); | ||
} | ||
|
||
// TODO cluster client once implemented | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,9 @@ | ||
package glide; | ||
|
||
public class TestConfiguration { | ||
// All redis servers are hosted on localhost | ||
public static final int STANDALONE_PORT = | ||
Integer.parseInt(System.getProperty("test.redis.standalone.port")); | ||
public static final int CLUSTER_PORT = | ||
Integer.parseInt(System.getProperty("test.redis.cluster.port")); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
junit.jupiter.displayname.generator.default = \ | ||
org.junit.jupiter.api.DisplayNameGenerator$ReplaceUnderscores |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters