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.
Java: Add IT framework (valkey-io#863)
* Add IT framework (#63) Signed-off-by: Yury-Fridlyand <[email protected]>
- Loading branch information
1 parent
96adb91
commit 7348be1
Showing
8 changed files
with
199 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,107 @@ | ||
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' | ||
} | ||
|
||
def standaloneRedisPorts = [] | ||
def clusterRedisPorts = [] | ||
|
||
ext { | ||
extractPortsFromClusterManagerOutput = { String output, ArrayList dest -> | ||
for (def line : output.split("\n")) { | ||
if (!line.startsWith("CLUSTER_NODES=")) | ||
continue | ||
|
||
def addresses = line.split("=")[1].split(",") | ||
for (def address : addresses) | ||
dest << address.split(":")[1] | ||
} | ||
} | ||
} | ||
|
||
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') { | ||
doLast { | ||
new ByteArrayOutputStream().withStream { os -> | ||
exec { | ||
workingDir "${project.rootDir}/../utils" | ||
commandLine 'python3', 'cluster_manager.py', 'start', '--cluster-mode' | ||
standardOutput = os | ||
} | ||
extractPortsFromClusterManagerOutput(os.toString(), clusterRedisPorts) | ||
} | ||
} | ||
} | ||
|
||
tasks.register('startStandalone') { | ||
doLast { | ||
new ByteArrayOutputStream().withStream { os -> | ||
exec { | ||
workingDir "${project.rootDir}/../utils" | ||
commandLine 'python3', 'cluster_manager.py', 'start', '-r', '0' | ||
standardOutput = os | ||
} | ||
extractPortsFromClusterManagerOutput(os.toString(), standaloneRedisPorts) | ||
} | ||
} | ||
} | ||
|
||
test.dependsOn 'stopAllBeforeTests' | ||
stopAllBeforeTests.finalizedBy 'clearDirs' | ||
clearDirs.finalizedBy 'startStandalone' | ||
clearDirs.finalizedBy 'startCluster' | ||
test.finalizedBy 'stopAllAfterTests' | ||
test.dependsOn ':client:buildRustRelease' | ||
|
||
tasks.withType(Test) { | ||
doFirst { | ||
println "Cluster ports = ${clusterRedisPorts}" | ||
println "Standalone ports = ${standaloneRedisPorts}" | ||
systemProperty 'test.redis.standalone.ports', standaloneRedisPorts.join(',') | ||
systemProperty 'test.redis.cluster.ports', clusterRedisPorts.join(',') | ||
} | ||
|
||
testLogging { | ||
exceptionFormat "full" | ||
events "started", "skipped", "passed", "failed" | ||
showStandardStreams true | ||
} | ||
jvmArgs "-Djava.library.path=${project.rootDir}/target/release" | ||
afterTest { desc, result -> | ||
logger.quiet "${desc.className}.${desc.name}: ${result.resultType} ${(result.getEndTime() - result.getStartTime())/1000}s" | ||
} | ||
} |
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,42 @@ | ||
package glide; | ||
|
||
import static org.junit.jupiter.api.Assertions.assertTrue; | ||
|
||
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_PORTS[0]).build()) | ||
.build()) | ||
.get(10, TimeUnit.SECONDS); | ||
} | ||
|
||
@AfterAll | ||
@SneakyThrows | ||
public static void deinit() { | ||
regularClient.close(); | ||
} | ||
|
||
@Test | ||
@SneakyThrows | ||
public void custom_command_info() { | ||
var data = regularClient.customCommand(new String[] {"info"}).get(10, TimeUnit.SECONDS); | ||
assertTrue(((String) data).contains("# Stats")); | ||
} | ||
} |
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,26 @@ | ||
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_PORTS[0]).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,15 @@ | ||
package glide; | ||
|
||
import java.util.Arrays; | ||
|
||
public final class TestConfiguration { | ||
// All redis servers are hosted on localhost | ||
public static final int[] STANDALONE_PORTS = getPortsFromProperty("test.redis.standalone.ports"); | ||
public static final int[] CLUSTER_PORTS = getPortsFromProperty("test.redis.cluster.ports"); | ||
|
||
private static int[] getPortsFromProperty(String propName) { | ||
return Arrays.stream(System.getProperty(propName).split(",")) | ||
.mapToInt(Integer::parseInt) | ||
.toArray(); | ||
} | ||
} |
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