From fd83fa99ed5a70689950ac4c8a3f85d741f5f90d Mon Sep 17 00:00:00 2001 From: Joshua Palis Date: Thu, 30 Nov 2023 21:49:27 +0000 Subject: [PATCH 1/3] Initial integ test framework modification, sets up integration test cluster and fixes ./gradlew run Signed-off-by: Joshua Palis --- build.gradle | 48 +++++++++++++++++++++++++++++++++++++++++++----- 1 file changed, 43 insertions(+), 5 deletions(-) diff --git a/build.gradle b/build.gradle index 9f8bc9429..72fa676b0 100644 --- a/build.gradle +++ b/build.gradle @@ -1,5 +1,6 @@ import java.nio.file.Files import org.opensearch.gradle.test.RestIntegTestTask +import java.util.concurrent.Callable apply plugin: 'java' apply plugin: 'idea' @@ -145,6 +146,9 @@ dependencies { implementation 'com.amazonaws:aws-encryption-sdk-java:2.4.1' implementation 'org.bouncycastle:bcprov-jdk18on:1.77' + // ZipArchive dependencies used for integration tests + zipArchive group: 'org.opensearch.plugin', name:'opensearch-ml-plugin', version: "${opensearch_build}" + configurations.all { resolutionStrategy { force("com.google.guava:guava:32.1.3-jre") // CVE for 31.1 @@ -154,6 +158,11 @@ dependencies { } } + +def opensearch_tmp_dir = rootProject.file('build/private/opensearch_tmp').absoluteFile +opensearch_tmp_dir.mkdirs() +def _numNodes = findProperty('numNodes') as Integer ?: 1 + test { include '**/*Tests.class' } @@ -166,6 +175,8 @@ jacocoTestReport { } tasks.named("check").configure { dependsOn(jacocoTestReport) } + +// Set up integration tests task integTest(type: RestIntegTestTask) { description = "Run tests against a cluster" testClassesDirs = sourceSets.test.output.classesDirs @@ -173,10 +184,18 @@ task integTest(type: RestIntegTestTask) { } tasks.named("check").configure { dependsOn(integTest) } -def _numNodes = findProperty('numNodes') as Integer ?: 1 - integTest { + dependsOn "bundlePlugin" + systemProperty 'tests.security.manager', 'false' + systemProperty 'java.io.tmpdir', opensearch_tmp_dir.absolutePath + systemProperty('project.root', project.rootDir.absolutePath) + systemProperty "https", System.getProperty("https") + systemProperty "user", System.getProperty("user") + systemProperty "password", System.getProperty("password") + + + // doFirst delays this block until execution time doFirst { // Tell the test JVM if the cluster JVM is running under a debugger so that tests can // use longer timeouts for requests. @@ -197,10 +216,31 @@ integTest { } } +// Set up integration test clusters, installs all zipArchive dependencies and Flow Framework testClusters.integTest { testDistribution = "ARCHIVE" + + // Installs all registered zipArchive dependencies on integTest cluster nodes + configurations.zipArchive.asFileTree.each { + plugin(provider(new Callable(){ + @Override + RegularFile call() throws Exception { + return new RegularFile() { + @Override + File getAsFile() { + return it + } + } + } + })) + } + + // Install Flow Framwork Plugin on integTest cluster nodes + plugin(project.tasks.bundlePlugin.archiveFile) + // Cluster shrink exception thrown if we try to set numberOfNodes to 1, so only apply if > 1 if (_numNodes > 1) numberOfNodes = _numNodes + // When running integration tests it doesn't forward the --debug-jvm to the cluster anymore // i.e. we have to use a custom property to flag when we want to debug OpenSearch JVM // since we also support multi node integration tests we increase debugPort per node @@ -211,11 +251,9 @@ testClusters.integTest { debugPort += 1 } } - - // This installs our plugin into the testClusters - plugin(project.tasks.bundlePlugin.archiveFile) } +// Automatically sets up the integration test cluster locally run { useCluster testClusters.integTest } From 23744ae09581ac6268cdef66df30e91d0231b46e Mon Sep 17 00:00:00 2001 From: Joshua Palis Date: Thu, 30 Nov 2023 21:59:11 +0000 Subject: [PATCH 2/3] spotless Signed-off-by: Joshua Palis --- build.gradle | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/build.gradle b/build.gradle index c3a776abc..8c19349a7 100644 --- a/build.gradle +++ b/build.gradle @@ -229,7 +229,7 @@ integTest { // Set up integration test clusters, installs all zipArchive dependencies and Flow Framework testClusters.integTest { testDistribution = "ARCHIVE" - + // Installs all registered zipArchive dependencies on integTest cluster nodes configurations.zipArchive.asFileTree.each { plugin(provider(new Callable(){ From f7448a9ab843cb79f04d6599386961863b0b5b64 Mon Sep 17 00:00:00 2001 From: Joshua Palis Date: Thu, 30 Nov 2023 22:47:59 +0000 Subject: [PATCH 3/3] Updating DEVELOPER_GUIDE Signed-off-by: Joshua Palis --- DEVELOPER_GUIDE.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/DEVELOPER_GUIDE.md b/DEVELOPER_GUIDE.md index 107386c3d..5e68587e2 100644 --- a/DEVELOPER_GUIDE.md +++ b/DEVELOPER_GUIDE.md @@ -36,7 +36,7 @@ This package uses the [Gradle](https://docs.gradle.org/current/userguide/usergui #### Building from the command line 1. `./gradlew check` builds and tests. -2. `./gradlew :run` runs the plugin. +2. `./gradlew :run` installs and runs ML-Commons and Flow Framework Plugins into a local cluster 3. `./gradlew spotlessApply` formats code. And/or import formatting rules in [formatterConfig.xml](formatter/formatterConfig.xml) with IDE. 4. `./gradlew test` to run the complete test suite.