From 01ae1778078728e97b01022560775b5957bcc60f Mon Sep 17 00:00:00 2001 From: Ankit Kala Date: Mon, 5 Dec 2022 17:41:49 +0530 Subject: [PATCH 1/2] Update the CI workflow to run the integ tests on all platforms Signed-off-by: Ankit Kala --- .github/workflows/build-and-test.yml | 54 +++++++++++++++++++ .github/workflows/build.yml | 33 ++++-------- .../replication/MultiClusterRestTestCase.kt | 1 + .../integ/rest/StartReplicationIT.kt | 4 +- 4 files changed, 68 insertions(+), 24 deletions(-) create mode 100644 .github/workflows/build-and-test.yml diff --git a/.github/workflows/build-and-test.yml b/.github/workflows/build-and-test.yml new file mode 100644 index 00000000..e74f5946 --- /dev/null +++ b/.github/workflows/build-and-test.yml @@ -0,0 +1,54 @@ +name: CCR Test Workflow +# This workflow is triggered on pull requests to main branch +on: + pull_request: + branches: + - '*' + push: + branches: + - '*' + +# We build for all combinations but run tests only on all platforms on latest java) +jobs: + build: + continue-on-error: true + strategy: + matrix: + java: + - 14 + os: + - ubuntu-latest + - windows-latest + - macos-latest + # Job name + name: Run integration tests on ${{ matrix.os }} with Java ${{ matrix.java }} + runs-on: ${{ matrix.os }} + steps: + # This step uses the setup-java Github action: https://github.com/actions/setup-java + - name: Set Up JDK ${{ matrix.java }} + uses: actions/setup-java@v1 + with: + java-version: ${{ matrix.java }} + # This step uses the checkout Github action: https://github.com/actions/checkout + - name: Checkout Branch + uses: actions/checkout@v2 + - name: Build and run Replication tests + run: | + ./gradlew clean release -D"build.snapshot=true" + - name: Upload failed logs + uses: actions/upload-artifact@v2 + if: failure() + with: + name: logs + path: | + build/testclusters/integTest-*/logs/* + build/testclusters/leaderCluster-*/logs/* + build/testclusters/followCluster-*/logs/* + - name: Create Artifact Path + run: | + mkdir -p cross-cluster-replication-artifacts + cp ./build/distributions/*.zip cross-cluster-replication-artifacts + - name: Uploads coverage + with: + fetch-depth: 2 + uses: codecov/codecov-action@v1.2.1 diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index f3675e33..7d1f2ce4 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -1,4 +1,4 @@ -name: Test and Build Workflow +name: Build Replication plugin # This workflow is triggered on pull requests to main branch on: pull_request: @@ -8,17 +8,22 @@ on: branches: - '*' +# We build for other platforms except linux which is already covered in build-and-test. +# Also, We're not running tests here as those are already covered with linux build. jobs: build: + continue-on-error: true strategy: matrix: java: + - 14 - 8 - 11 - - 14 + os: + - ubuntu-latest # Job name - name: Build Replication plugin - runs-on: ubuntu-latest + name: Java ${{ matrix.java }} On ${{ matrix.os }} + runs-on: ${{ matrix.os }} steps: # This step uses the setup-java Github action: https://github.com/actions/setup-java - name: Set Up JDK ${{ matrix.java }} @@ -30,21 +35,5 @@ jobs: uses: actions/checkout@v2 - name: Build and run Replication tests run: | - ./gradlew clean release -Dbuild.snapshot=true -Dopensearch.version=1.3.7-SNAPSHOT - - name: Upload failed logs - uses: actions/upload-artifact@v2 - if: failure() - with: - name: logs - path: | - build/testclusters/integTest-*/logs/* - build/testclusters/leaderCluster-*/logs/* - build/testclusters/followCluster-*/logs/* - - name: Create Artifact Path - run: | - mkdir -p cross-cluster-replication-artifacts - cp ./build/distributions/*.zip cross-cluster-replication-artifacts - - name: Uploads coverage - with: - fetch-depth: 2 - uses: codecov/codecov-action@v1.2.1 + ./gradlew clean release -D"build.snapshot=true" -x test -x IntegTest + diff --git a/src/test/kotlin/org/opensearch/replication/MultiClusterRestTestCase.kt b/src/test/kotlin/org/opensearch/replication/MultiClusterRestTestCase.kt index 53582835..c3f84f60 100644 --- a/src/test/kotlin/org/opensearch/replication/MultiClusterRestTestCase.kt +++ b/src/test/kotlin/org/opensearch/replication/MultiClusterRestTestCase.kt @@ -274,6 +274,7 @@ abstract class MultiClusterRestTestCase : OpenSearchTestCase() { return } val repo = configuredRepositories[0] as String + repo.replace("""\""", """\\""").replace("""/""", """\/""") val repoConfig = """ { "type": "fs", diff --git a/src/test/kotlin/org/opensearch/replication/integ/rest/StartReplicationIT.kt b/src/test/kotlin/org/opensearch/replication/integ/rest/StartReplicationIT.kt index d1e007ad..2d4eecc7 100644 --- a/src/test/kotlin/org/opensearch/replication/integ/rest/StartReplicationIT.kt +++ b/src/test/kotlin/org/opensearch/replication/integ/rest/StartReplicationIT.kt @@ -951,8 +951,8 @@ class StartReplicationIT: MultiClusterRestTestCase() { val leaderClient = getClientForCluster(LEADER) createConnectionBetweenClusters(FOLLOWER, LEADER) - val repoPath = PathUtils.get(buildDir, repoPath) - + val repoPath = PathUtils.get(buildDir, repoPath).toString() + repoPath.replace("""\""", """\\""").replace("""/""", """\/""") val putRepositoryRequest = PutRepositoryRequest("my-repo") .type(FsRepository.TYPE) .settings("{\"location\": \"$repoPath\"}", XContentType.JSON) From bfa55b45fa553190e2a7ffa9b696af8fea49738d Mon Sep 17 00:00:00 2001 From: Ankit Kala Date: Tue, 6 Dec 2022 18:45:47 +0530 Subject: [PATCH 2/2] Skip FS snapshot repository registration on windows Signed-off-by: Ankit Kala --- .../opensearch/replication/MultiClusterRestTestCase.kt | 8 +++++++- .../replication/integ/rest/StartReplicationIT.kt | 4 ++-- .../replication/integ/rest/StopReplicationIT.kt | 1 + 3 files changed, 10 insertions(+), 3 deletions(-) diff --git a/src/test/kotlin/org/opensearch/replication/MultiClusterRestTestCase.kt b/src/test/kotlin/org/opensearch/replication/MultiClusterRestTestCase.kt index c3f84f60..83cf53eb 100644 --- a/src/test/kotlin/org/opensearch/replication/MultiClusterRestTestCase.kt +++ b/src/test/kotlin/org/opensearch/replication/MultiClusterRestTestCase.kt @@ -263,10 +263,17 @@ abstract class MultiClusterRestTestCase : OpenSearchTestCase() { } } + fun isWindowsPlatform(): Boolean { + return System.getProperty("os.name").contains("windows", true) + } + /** * Register snapshot repo - "fs" type on all the clusters */ private fun registerSnapshotRepository(testCluster: TestCluster) { + // TODO: Skipping FS based snapshot registration for windows. We'll revisit & fix this later. + if (isWindowsPlatform()) return + val getResponse: Map = OpenSearchRestTestCase.entityAsMap(testCluster.lowLevelClient.performRequest( Request("GET", "/_cluster/settings?include_defaults=true&flat_settings=true"))) val configuredRepositories = (getResponse["defaults"] as Map<*, *>)["path.repo"] as List<*> @@ -274,7 +281,6 @@ abstract class MultiClusterRestTestCase : OpenSearchTestCase() { return } val repo = configuredRepositories[0] as String - repo.replace("""\""", """\\""").replace("""/""", """\/""") val repoConfig = """ { "type": "fs", diff --git a/src/test/kotlin/org/opensearch/replication/integ/rest/StartReplicationIT.kt b/src/test/kotlin/org/opensearch/replication/integ/rest/StartReplicationIT.kt index 2d4eecc7..ed79a58c 100644 --- a/src/test/kotlin/org/opensearch/replication/integ/rest/StartReplicationIT.kt +++ b/src/test/kotlin/org/opensearch/replication/integ/rest/StartReplicationIT.kt @@ -942,6 +942,7 @@ class StartReplicationIT: MultiClusterRestTestCase() { } fun `test that snapshot on leader does not affect replication during bootstrap`() { + if(isWindowsPlatform()) return val settings = Settings.builder() .put(IndexMetadata.SETTING_NUMBER_OF_SHARDS, 20) .put(IndexMetadata.SETTING_NUMBER_OF_REPLICAS, 0) @@ -951,8 +952,7 @@ class StartReplicationIT: MultiClusterRestTestCase() { val leaderClient = getClientForCluster(LEADER) createConnectionBetweenClusters(FOLLOWER, LEADER) - val repoPath = PathUtils.get(buildDir, repoPath).toString() - repoPath.replace("""\""", """\\""").replace("""/""", """\/""") + val repoPath = PathUtils.get(buildDir, repoPath) val putRepositoryRequest = PutRepositoryRequest("my-repo") .type(FsRepository.TYPE) .settings("{\"location\": \"$repoPath\"}", XContentType.JSON) diff --git a/src/test/kotlin/org/opensearch/replication/integ/rest/StopReplicationIT.kt b/src/test/kotlin/org/opensearch/replication/integ/rest/StopReplicationIT.kt index 09b797ae..3e0acaf9 100644 --- a/src/test/kotlin/org/opensearch/replication/integ/rest/StopReplicationIT.kt +++ b/src/test/kotlin/org/opensearch/replication/integ/rest/StopReplicationIT.kt @@ -244,6 +244,7 @@ class StopReplicationIT: MultiClusterRestTestCase() { } fun `test stop replication with stale replication settings at leader cluster`() { + if(isWindowsPlatform()) return val followerClient = getClientForCluster(FOLLOWER) val leaderClient = getClientForCluster(LEADER) createConnectionBetweenClusters(FOLLOWER, LEADER, "source")