diff --git a/.github/actions/run-cypress-tests/action.yaml b/.github/actions/run-cypress-tests/action.yaml new file mode 100644 index 000000000..11a70f383 --- /dev/null +++ b/.github/actions/run-cypress-tests/action.yaml @@ -0,0 +1,152 @@ +name: 'Runs the cypress test suite' +description: 'Re-usable workflow to run cypress tests against a cluster with or without security' + +inputs: + with-security: + description: 'Whether security should be installed on the cluster the tests are run with' + required: true + +runs: + using: "composite" + steps: + - name: Set up JDK + uses: actions/setup-java@v1 + with: + # TODO: Parse this from index management plugin + java-version: 21 + - name: Checkout index management + uses: actions/checkout@v2 + with: + path: index-management + repository: opensearch-project/index-management + ref: 'main' + - name: Run opensearch with plugin + shell: bash + if: ${{ inputs.with-security == 'false' }} + run: | + cd index-management + ./gradlew run -Dopensearch.version=${{ env.OPENSEARCH_VERSION }} & + sleep 300 + # timeout 300 bash -c 'while [[ "$(curl -s -o /dev/null -w ''%{http_code}'' localhost:9200)" != "200" ]]; do sleep 5; done' + - name: Run opensearch with plugin + shell: bash + if: ${{ inputs.with-security == 'true' }} + run: | + cd index-management + ./gradlew run -Dopensearch.version=${{ env.OPENSEARCH_VERSION }} -Dsecurity=true -Dhttps=true & + sleep 300 + # timeout 300 bash -c 'while [[ "$(curl -s -o /dev/null -w ''%{http_code}'' localhost:9200)" != "200" ]]; do sleep 5; done' + - name: Checkout Index Management Dashboards plugin + uses: actions/checkout@v2 + with: + path: index-management-dashboards-plugin + - name: Checkout Security Dashboards plugin + uses: actions/checkout@v2 + with: + repository: opensearch-project/security-dashboards-plugin + path: security-dashboards-plugin + ref: ${{ env.OPENSEARCH_DASHBOARDS_VERSION }} + - name: Checkout OpenSearch-Dashboards + uses: actions/checkout@v2 + with: + repository: opensearch-project/OpenSearch-Dashboards + path: OpenSearch-Dashboards + ref: ${{ env.OPENSEARCH_DASHBOARDS_VERSION }} + - name: Setup Node + uses: actions/setup-node@v3 + with: + node-version-file: './OpenSearch-Dashboards/.nvmrc' + registry-url: 'https://registry.npmjs.org' + - name: Install Yarn + # Need to use bash to avoid having a windows/linux specific step + shell: bash + run: | + YARN_VERSION=$(node -p "require('./OpenSearch-Dashboards/package.json').engines.yarn") + echo "Installing yarn@$YARN_VERSION" + npm i -g yarn@$YARN_VERSION + - run: node -v + shell: bash + - run: yarn -v + shell: bash + - name: Configure OpenSearch Dashboards for cypress + shell: bash + if: ${{ inputs.with-security == 'true' }} + run: | + cat << 'EOT' > ./OpenSearch-Dashboards/config/opensearch_dashboards.yml + server.host: "0.0.0.0" + opensearch.hosts: ["https://localhost:9200"] + opensearch.ssl.verificationMode: none + opensearch.username: "kibanaserver" + opensearch.password: "kibanaserver" + opensearch.requestHeadersWhitelist: [ authorization,securitytenant ] + opensearch_security.multitenancy.enabled: true + opensearch_security.multitenancy.tenants.preferred: ["Private", "Global"] + opensearch_security.readonly_mode.roles: ["kibana_read_only"] + opensearch_security.cookie.secure: false + EOT + - name: Print Dashboards Config + shell: bash + if: ${{ inputs.with-security == 'true' }} + run: | + cat ./OpenSearch-Dashboards/config/opensearch_dashboards.yml + - name: Bootstrap plugin/OpenSearch-Dashboards + shell: bash + if: ${{ inputs.with-security == 'false' }} + run: | + mkdir -p OpenSearch-Dashboards/plugins + mv index-management-dashboards-plugin OpenSearch-Dashboards/plugins + - name: Bootstrap plugin/OpenSearch-Dashboards + shell: bash + if: ${{ inputs.with-security == 'true' }} + run: | + mkdir -p OpenSearch-Dashboards/plugins + mv index-management-dashboards-plugin OpenSearch-Dashboards/plugins + mv security-dashboards-plugin OpenSearch-Dashboards/plugins + - name: Bootstrap the OpenSearch Dashboard + uses: nick-fields/retry@v2 + with: + timeout_minutes: 20 + max_attempts: 2 + command: yarn --cwd OpenSearch-Dashboards osd bootstrap --oss --single-version=loose + - name: Compile OpenSearch Dashboards + shell: bash + run: | + cd OpenSearch-Dashboards + node scripts/build_opensearch_dashboards_platform_plugins --no-examples --workers=10 --verbose + - name: Run OpenSearch-Dashboards server + shell: bash + run: | + cd OpenSearch-Dashboards + yarn start --no-base-path --no-watch --server.host="0.0.0.0" & + sleep 30 + # in main branch, OSD server requires more time to bundle and bootstrap + # timeout 300 bash -c 'while [[ "$(curl -s localhost:5601/api/status | jq -r '.status.overall.state')" != "green" ]]; do sleep 5; done' + # for now just chrome, use matrix to do all browsers later + - name: Cypress tests + uses: cypress-io/github-action@v2 + if: ${{ inputs.with-security == 'false' }} + with: + working-directory: OpenSearch-Dashboards/plugins/index-management-dashboards-plugin + command: yarn run cypress run + wait-on: 'http://localhost:5601' + browser: chrome + - name: Cypress tests + uses: cypress-io/github-action@v2 + if: ${{ inputs.with-security == 'true' }} + with: + working-directory: OpenSearch-Dashboards/plugins/index-management-dashboards-plugin + command: yarn run cypress run --env SECURITY_ENABLED=true,openSearchUrl=https://localhost:9200,WAIT_FOR_LOADER_BUFFER_MS=500 + wait-on: 'http://localhost:5601' + browser: chrome + # Screenshots are only captured on failure, will change this once we do visual regression tests + - uses: actions/upload-artifact@v3 + if: failure() + with: + name: cypress-screenshots + path: OpenSearch-Dashboards/plugins/index-management-dashboards-plugin/cypress/screenshots + # Test run video was always captured, so this action uses "always()" condition + - uses: actions/upload-artifact@v3 + if: always() + with: + name: cypress-videos + path: OpenSearch-Dashboards/plugins/index-management-dashboards-plugin/cypress/videos diff --git a/.github/workflows/cypress-with-security-workflow.yml b/.github/workflows/cypress-with-security-workflow.yml new file mode 100644 index 000000000..eed092a81 --- /dev/null +++ b/.github/workflows/cypress-with-security-workflow.yml @@ -0,0 +1,27 @@ +name: E2E tests workflow +on: + pull_request: + branches: + - "*" + push: + branches: + - "*" +env: + OPENSEARCH_DASHBOARDS_VERSION: 'main' + OPENSEARCH_VERSION: '3.0.0-SNAPSHOT' +jobs: + tests: + name: Run Cypress E2E tests with security + runs-on: ubuntu-latest + env: + # prevents extra Cypress installation progress messages + CI: 1 + # avoid warnings like "tput: No value for $TERM and no -T specified" + TERM: xterm + steps: + - name: Checkout Branch + uses: actions/checkout@v3 + - id: run-cypress-tests + uses: ./.github/actions/run-cypress-tests + with: + with-security: true diff --git a/.github/workflows/cypress-workflow.yml b/.github/workflows/cypress-workflow.yml index c7fdeffcc..32dc5ccf1 100644 --- a/.github/workflows/cypress-workflow.yml +++ b/.github/workflows/cypress-workflow.yml @@ -19,77 +19,9 @@ jobs: # avoid warnings like "tput: No value for $TERM and no -T specified" TERM: xterm steps: - - name: Set up JDK - uses: actions/setup-java@v1 + - name: Checkout Branch + uses: actions/checkout@v3 + - id: run-cypress-tests + uses: ./.github/actions/run-cypress-tests with: - # TODO: Parse this from index management plugin - java-version: 21 - - name: Checkout index management - uses: actions/checkout@v2 - with: - path: index-management - repository: opensearch-project/index-management - ref: 'main' - - name: Run opensearch with plugin - run: | - cd index-management - ./gradlew run -Dopensearch.version=${{ env.OPENSEARCH_VERSION }} & - sleep 300 - # timeout 300 bash -c 'while [[ "$(curl -s -o /dev/null -w ''%{http_code}'' localhost:9200)" != "200" ]]; do sleep 5; done' - - name: Checkout Index Management Dashboards plugin - uses: actions/checkout@v2 - with: - path: index-management-dashboards-plugin - - name: Checkout OpenSearch-Dashboards - uses: actions/checkout@v2 - with: - repository: opensearch-project/OpenSearch-Dashboards - path: OpenSearch-Dashboards - ref: ${{ env.OPENSEARCH_DASHBOARDS_VERSION }} - - name: Setup Node - uses: actions/setup-node@v3 - with: - node-version-file: './OpenSearch-Dashboards/.nvmrc' - registry-url: 'https://registry.npmjs.org' - - name: Install Yarn - # Need to use bash to avoid having a windows/linux specific step - shell: bash - run: | - YARN_VERSION=$(node -p "require('./OpenSearch-Dashboards/package.json').engines.yarn") - echo "Installing yarn@$YARN_VERSION" - npm i -g yarn@$YARN_VERSION - - run: node -v - - run: yarn -v - - name: Bootstrap plugin/OpenSearch-Dashboards - run: | - mkdir -p OpenSearch-Dashboards/plugins - mv index-management-dashboards-plugin OpenSearch-Dashboards/plugins - cd OpenSearch-Dashboards/plugins/index-management-dashboards-plugin - yarn osd bootstrap - - name: Run OpenSearch-Dashboards server - run: | - cd OpenSearch-Dashboards - yarn start --no-base-path --no-watch --server.host="0.0.0.0" & - sleep 420 - # in main branch, OSD server requires more time to bundle and bootstrap - # timeout 300 bash -c 'while [[ "$(curl -s localhost:5601/api/status | jq -r '.status.overall.state')" != "green" ]]; do sleep 5; done' - # for now just chrome, use matrix to do all browsers later - - name: Cypress tests - uses: cypress-io/github-action@v2 - with: - working-directory: OpenSearch-Dashboards/plugins/index-management-dashboards-plugin - command: yarn run cypress run - wait-on: 'http://localhost:5601' - browser: chrome - # Screenshots are only captured on failure, will change this once we do visual regression tests - - uses: actions/upload-artifact@v3 - if: failure() - with: - name: cypress-screenshots - path: OpenSearch-Dashboards/plugins/index-management-dashboards-plugin/cypress/screenshots - # Test run video was always captured, so this action uses "always()" condition - - uses: actions/upload-artifact@v3 - if: always() - with: - name: cypress-videos - path: OpenSearch-Dashboards/plugins/index-management-dashboards-plugin/cypress/videos + with-security: false diff --git a/cypress.json b/cypress.json index 1ccf74bb5..8fa8462ca 100644 --- a/cypress.json +++ b/cypress.json @@ -1,14 +1,48 @@ { - "defaultCommandTimeout": 60000, - "requestTimeout": 60000, - "responseTimeout": 60000, - "baseUrl": "http://localhost:5601", - "viewportWidth": 2000, - "viewportHeight": 1320, - "env": { - "openSearchUrl": "http://localhost:9200", - "SECURITY_ENABLED": false, - "username": "admin", - "password": "admin" - } -} + "defaultCommandTimeout": 60000, + "requestTimeout": 60000, + "responseTimeout": 60000, + "baseUrl": "http://localhost:5601", + "viewportWidth": 2000, + "viewportHeight": 1320, + "env": + { + "openSearchUrl": "http://localhost:9200", + "SECURITY_ENABLED": false, + "username": "admin", + "password": "admin" + }, + "clientCertificates": + [ + { + "url": "https://localhost:9200/.opendistro-ism*", + "ca": + [ + "cypress/resources/root-ca.pem" + ], + "certs": + [ + { + "cert": "cypress/resources/kirk.pem", + "key": "cypress/resources/kirk-key.pem", + "passphrase": "" + } + ] + }, + { + "url": "https://localhost:9200/.opendistro-ism-config/_update_by_query/", + "ca": + [ + "cypress/resources/root-ca.pem" + ], + "certs": + [ + { + "cert": "cypress/resources/kirk.pem", + "key": "cypress/resources/kirk-key.pem", + "passphrase": "" + } + ] + } + ] +} \ No newline at end of file diff --git a/cypress/plugins/index.js b/cypress/plugins/index.js index 0c9a39de6..eee870220 100644 --- a/cypress/plugins/index.js +++ b/cypress/plugins/index.js @@ -23,10 +23,6 @@ /** * @type {Cypress.PluginConfig} */ - -const fs = require("fs"); -const path = require("path"); - module.exports = (on) => { // const options = { // webpackOptions: { @@ -46,12 +42,4 @@ module.exports = (on) => { // }; // // on("file:preprocessor", wp(options)); - on("task", { - readCertAndKey() { - const cert = fs.readFileSync(path.resolve(__dirname, "../resources/kirk.pem")); - const key = fs.readFileSync(path.resolve(__dirname, "../resources/kirk-key.pem")); - - return { cert, key }; - }, - }); }; diff --git a/cypress/resources/kirk-key.pem b/cypress/resources/kirk-key.pem index fd1728cda..1949c2613 100644 --- a/cypress/resources/kirk-key.pem +++ b/cypress/resources/kirk-key.pem @@ -25,4 +25,4 @@ nBY2S57MSM11/MVslrEgGmYNnI4r1K25xlaqV6K6ztEJv6n69327MS4NG8L/gCU5 mQGwy8vIqMjAdHGLrCS35sVYBXG13knS52LJHvbVee39AbD5/LlWvjJGlQMzCLrw F7oILW5kXxhb8S73GWcuMbuQMFVHFONbZAZgn+C9FW4l7XyRdkrbR1MRZ2km8YMs /AHmo368d4PSNRMMzLHw8Q== ------END PRIVATE KEY----- +-----END PRIVATE KEY----- \ No newline at end of file diff --git a/cypress/resources/root-ca.pem b/cypress/resources/root-ca.pem new file mode 100644 index 000000000..d33f5f721 --- /dev/null +++ b/cypress/resources/root-ca.pem @@ -0,0 +1,28 @@ +-----BEGIN CERTIFICATE----- +MIIExjCCA66gAwIBAgIUDWQJmWZ9xBTsQUeOt9F5YSPpqOIwDQYJKoZIhvcNAQEL +BQAwgY8xEzARBgoJkiaJk/IsZAEZFgNjb20xFzAVBgoJkiaJk/IsZAEZFgdleGFt +cGxlMRkwFwYDVQQKDBBFeGFtcGxlIENvbSBJbmMuMSEwHwYDVQQLDBhFeGFtcGxl +IENvbSBJbmMuIFJvb3QgQ0ExITAfBgNVBAMMGEV4YW1wbGUgQ29tIEluYy4gUm9v +dCBDQTAeFw0yNDAyMjAxNzAwMzZaFw0zNDAyMTcxNzAwMzZaMIGPMRMwEQYKCZIm +iZPyLGQBGRYDY29tMRcwFQYKCZImiZPyLGQBGRYHZXhhbXBsZTEZMBcGA1UECgwQ +RXhhbXBsZSBDb20gSW5jLjEhMB8GA1UECwwYRXhhbXBsZSBDb20gSW5jLiBSb290 +IENBMSEwHwYDVQQDDBhFeGFtcGxlIENvbSBJbmMuIFJvb3QgQ0EwggEiMA0GCSqG +SIb3DQEBAQUAA4IBDwAwggEKAoIBAQDEPyN7J9VGPyJcQmCBl5TGwfSzvVdWwoQU +j9aEsdfFJ6pBCDQSsj8Lv4RqL0dZra7h7SpZLLX/YZcnjikrYC+rP5OwsI9xEE/4 +U98CsTBPhIMgqFK6SzNE5494BsAk4cL72dOOc8tX19oDS/PvBULbNkthQ0aAF1dg +vbrHvu7hq7LisB5ZRGHVE1k/AbCs2PaaKkn2jCw/b+U0Ml9qPuuEgz2mAqJDGYoA +WSR4YXrOcrmPuRqbws464YZbJW898/0Pn/U300ed+4YHiNYLLJp51AMkR4YEw969 +VRPbWIvLrd0PQBooC/eLrL6rvud/GpYhdQEUx8qcNCKd4bz3OaQ5AgMBAAGjggEW +MIIBEjAPBgNVHRMBAf8EBTADAQH/MA4GA1UdDwEB/wQEAwIBhjAdBgNVHQ4EFgQU +F4ffoFrrZhKn1dD4uhJFPLcrAJwwgc8GA1UdIwSBxzCBxIAUF4ffoFrrZhKn1dD4 +uhJFPLcrAJyhgZWkgZIwgY8xEzARBgoJkiaJk/IsZAEZFgNjb20xFzAVBgoJkiaJ +k/IsZAEZFgdleGFtcGxlMRkwFwYDVQQKDBBFeGFtcGxlIENvbSBJbmMuMSEwHwYD +VQQLDBhFeGFtcGxlIENvbSBJbmMuIFJvb3QgQ0ExITAfBgNVBAMMGEV4YW1wbGUg +Q29tIEluYy4gUm9vdCBDQYIUDWQJmWZ9xBTsQUeOt9F5YSPpqOIwDQYJKoZIhvcN +AQELBQADggEBAL3Q3AHUhMiLUy6OlLSt8wX9I2oNGDKbBu0atpUNDztk/0s3YLQC +YuXgN4KrIcMXQIuAXCx407c+pIlT/T1FNn+VQXwi56PYzxQKtlpoKUL3oPQE1d0V +6EoiNk+6UodvyZqpdQu7fXVentRMk1QX7D9otmiiNuX+GSxJhJC2Lyzw65O9EUgG +1yVJon6RkUGtqBqKIuLksKwEr//ELnjmXit4LQKSnqKr0FTCB7seIrKJNyb35Qnq +qy9a/Unhokrmdda1tr6MbqU8l7HmxLuSd/Ky+L0eDNtYv6YfMewtjg0TtAnFyQov +rdXmeq1dy9HLo3Ds4AFz3Gx9076TxcRS/iI= +-----END CERTIFICATE----- \ No newline at end of file diff --git a/cypress/utils/commands.js b/cypress/utils/commands.js index 619fc8704..4dd68a224 100644 --- a/cypress/utils/commands.js +++ b/cypress/utils/commands.js @@ -99,17 +99,7 @@ Cypress.Commands.add("login", () => { Cypress.Commands.add("deleteAllIndices", () => { cy.log("Deleting all indexes"); cy.request("DELETE", `${Cypress.env("openSearchUrl")}/index*,sample*,opensearch_dashboards*`); - cy.task("readCertAndKey").then(({ cert, key }) => { - cy.request({ - method: "DELETE", - url: `${Cypress.env("openSearchUrl")}/.opendistro-ism*?expand_wildcards=all`, - headers: {}, - agentOptions: { - cert, - key, - }, - }); - }); + cy.request("DELETE", `${Cypress.env("openSearchUrl")}/.opendistro-ism*?expand_wildcards=all`); }); Cypress.Commands.add("deleteADSystemIndices", () => { diff --git a/cypress/utils/plugins/index-management-dashboards-plugin/commands.js b/cypress/utils/plugins/index-management-dashboards-plugin/commands.js index 3dba766f2..428236904 100644 --- a/cypress/utils/plugins/index-management-dashboards-plugin/commands.js +++ b/cypress/utils/plugins/index-management-dashboards-plugin/commands.js @@ -44,7 +44,7 @@ Cypress.Commands.add("updateManagedIndexConfigStartTime", (index) => { source: `ctx._source['managed_index']['schedule']['interval']['start_time'] = ${startTime}L`, }, }; - cy.request("POST", `${Cypress.env("openSearchUrl")}/${IM_CONFIG_INDEX.OPENDISTRO_ISM_CONFIG}/_update_by_query`, body); + cy.request("POST", `${Cypress.env("openSearchUrl")}/${IM_CONFIG_INDEX.OPENDISTRO_ISM_CONFIG}/_update_by_query/`, body); }); }); diff --git a/public/JobHandler/callbacks/force_merge.test.tsx b/public/JobHandler/callbacks/force_merge.test.tsx index 049a971e9..71e76f456 100644 --- a/public/JobHandler/callbacks/force_merge.test.tsx +++ b/public/JobHandler/callbacks/force_merge.test.tsx @@ -41,10 +41,7 @@ describe("callbackForForceMerge spec", () => { it("callback when not complete", async () => { httpClientMock.fetch = getMockFn({ - found: true, - _source: { - completed: false, - }, + completed: false, }); const result = await callbackForForceMerge(forceMergeMetaData, { core, @@ -54,10 +51,7 @@ describe("callbackForForceMerge spec", () => { it("callback when complete", async () => { httpClientMock.fetch = getMockFn({ - found: true, - _source: { - completed: true, - }, + completed: true, }); const result = await callbackForForceMerge(forceMergeMetaData, { core, @@ -69,14 +63,11 @@ describe("callbackForForceMerge spec", () => { it("callback when some complete", async () => { httpClientMock.fetch = getMockFn({ - found: true, - _source: { - completed: true, - response: { - _shards: { - successful: 9, - total: 10, - }, + completed: true, + response: { + _shards: { + successful: 9, + total: 10, }, }, }); @@ -90,12 +81,9 @@ describe("callbackForForceMerge spec", () => { it("callback when failed", async () => { httpClientMock.fetch = getMockFn({ - found: true, - _source: { - completed: true, - error: { - reason: "reason", - }, + completed: true, + error: { + reason: "reason", }, }); const result = await callbackForForceMerge(forceMergeMetaData, { diff --git a/public/JobHandler/callbacks/force_merge.tsx b/public/JobHandler/callbacks/force_merge.tsx index b1685ec5e..656cea771 100644 --- a/public/JobHandler/callbacks/force_merge.tsx +++ b/public/JobHandler/callbacks/force_merge.tsx @@ -30,14 +30,14 @@ export const callbackForForceMerge: CallbackType = async (job: ForceMergeJobMeta const tasksResult = await commonService.apiCaller({ endpoint: "transport.request", data: { - path: `/.tasks/_doc/${extras.taskId}`, + path: `/_tasks/${extras.taskId}`, method: "GET", }, }); if (tasksResult.ok) { - const { _source, found } = tasksResult.response; - const { completed, error } = (_source || {}) as ForceMergeTaskResult["_source"]; - if (completed && found) { + const _source = tasksResult.response; + const { completed, error } = (_source || {}) as ForceMergeTaskResult; + if (completed) { if (extras.toastId) { core.notifications.toasts.remove(extras.toastId); } diff --git a/public/JobHandler/callbacks/open.test.tsx b/public/JobHandler/callbacks/open.test.tsx index e6e265d8f..a37394a04 100644 --- a/public/JobHandler/callbacks/open.test.tsx +++ b/public/JobHandler/callbacks/open.test.tsx @@ -40,10 +40,7 @@ describe("callbackForOpen spec", () => { it("callback when not complete", async () => { httpClientMock.fetch = getMockFn({ - found: true, - _source: { - completed: false, - }, + completed: false, }); const result = await callbackForOpen(openMetaData, { core, @@ -53,13 +50,10 @@ describe("callbackForOpen spec", () => { it("callback when successfully complete", async () => { httpClientMock.fetch = getMockFn({ - found: true, - _source: { - completed: true, - response: { - acknowledged: true, - shards_acknowledged: true, - }, + completed: true, + response: { + acknowledged: true, + shards_acknowledged: true, }, }); const result = await callbackForOpen(openMetaData, { @@ -72,12 +66,9 @@ describe("callbackForOpen spec", () => { it("callback when failed", async () => { httpClientMock.fetch = getMockFn({ - found: true, - _source: { - completed: true, - error: { - reason: "reason", - }, + completed: true, + error: { + reason: "reason", }, }); const result = await callbackForOpen(openMetaData, { diff --git a/public/JobHandler/callbacks/open.tsx b/public/JobHandler/callbacks/open.tsx index 28056345c..4b9c25136 100644 --- a/public/JobHandler/callbacks/open.tsx +++ b/public/JobHandler/callbacks/open.tsx @@ -22,13 +22,13 @@ export const callbackForOpen: CallbackType = async (job: OpenJobMetaData, { core const tasksResult = await commonService.apiCaller({ endpoint: "transport.request", data: { - path: `/.tasks/_doc/${extras.taskId}`, + path: `/_tasks/${extras.taskId}`, method: "GET", }, }); if (tasksResult.ok) { - const { _source } = tasksResult.response; - const { completed, error } = (_source || {}) as OpenTaskResult["_source"]; + const _source = tasksResult.response; + const { completed, error } = (_source || {}) as OpenTaskResult; if (completed) { const { acknowledged, shards_acknowledged } = _source.response || {}; if (acknowledged && shards_acknowledged) { diff --git a/public/JobHandler/callbacks/reindex.test.tsx b/public/JobHandler/callbacks/reindex.test.tsx index aae3276f1..b77f4f494 100644 --- a/public/JobHandler/callbacks/reindex.test.tsx +++ b/public/JobHandler/callbacks/reindex.test.tsx @@ -43,10 +43,7 @@ describe("callbackForOpen spec", () => { it("callback when not complete", async () => { httpClientMock.fetch = getMockFn({ - found: true, - _source: { - completed: false, - }, + completed: false, }); const result = await callbackForReindex(reindexMetaData, { core, @@ -56,10 +53,7 @@ describe("callbackForOpen spec", () => { it("callback when successfully complete", async () => { httpClientMock.fetch = getMockFn({ - found: true, - _source: { - completed: true, - }, + completed: true, }); const result = await callbackForReindex(reindexMetaData, { core, @@ -71,20 +65,17 @@ describe("callbackForOpen spec", () => { it("callback when failed", async () => { httpClientMock.fetch = getMockFn({ - found: true, - _source: { - completed: true, - error: { - reason: "reason", - }, - failures: [ - { - cause: { - reason: "cause", - }, - }, - ], + completed: true, + error: { + reason: "reason", }, + failures: [ + { + cause: { + reason: "cause", + }, + }, + ], }); const result = await callbackForReindex(reindexMetaData, { core, diff --git a/public/JobHandler/callbacks/reindex.tsx b/public/JobHandler/callbacks/reindex.tsx index 16cf3f9a9..6e89cc6b9 100644 --- a/public/JobHandler/callbacks/reindex.tsx +++ b/public/JobHandler/callbacks/reindex.tsx @@ -27,15 +27,15 @@ export const callbackForReindex: CallbackType = async (job: ReindexJobMetaData, const tasksResult = await commonService.apiCaller({ endpoint: "transport.request", data: { - path: `/.tasks/_doc/${extras.taskId}`, + path: `/_tasks/${extras.taskId}`, method: "GET", }, }); if (tasksResult.ok) { - const { _source, found } = tasksResult.response; - const { completed, response, error } = (_source || {}) as ReindexTaskResult["_source"]; + const _source = tasksResult.response; + const { completed, response, error } = (_source || {}) as ReindexTaskResult; const { failures, canceled } = response || {}; - if (completed && found) { + if (completed) { if (extras.toastId) { core.notifications.toasts.remove(extras.toastId); } diff --git a/public/JobHandler/callbacks/shrink.test.tsx b/public/JobHandler/callbacks/shrink.test.tsx index 293461a3f..32ec79d54 100644 --- a/public/JobHandler/callbacks/shrink.test.tsx +++ b/public/JobHandler/callbacks/shrink.test.tsx @@ -41,10 +41,7 @@ describe("callbackForOpen spec", () => { it("callback when not complete", async () => { httpClientMock.fetch = getMockFn({ - found: true, - _source: { - completed: false, - }, + completed: false, }); const result = await callbackForShrink(shrinkMetaData, { core, @@ -54,10 +51,7 @@ describe("callbackForOpen spec", () => { it("callback when successfully complete", async () => { httpClientMock.fetch = getMockFn({ - found: true, - _source: { - completed: true, - }, + completed: true, }); const result = await callbackForShrink(shrinkMetaData, { core, @@ -69,20 +63,17 @@ describe("callbackForOpen spec", () => { it("callback when failed", async () => { httpClientMock.fetch = getMockFn({ - found: true, - _source: { - completed: true, - error: { - reason: "reason", - }, - failures: [ - { - cause: { - reason: "cause", - }, - }, - ], + completed: true, + error: { + reason: "reason", }, + failures: [ + { + cause: { + reason: "cause", + }, + }, + ], }); const result = await callbackForShrink(shrinkMetaData, { core, diff --git a/public/JobHandler/callbacks/shrink.tsx b/public/JobHandler/callbacks/shrink.tsx index 34e90b699..bb3db2a5b 100644 --- a/public/JobHandler/callbacks/shrink.tsx +++ b/public/JobHandler/callbacks/shrink.tsx @@ -17,15 +17,15 @@ export const callbackForShrink: CallbackType = async (job: RecoveryJobMetaData, const tasksResult = await commonService.apiCaller({ endpoint: "transport.request", data: { - path: `/.tasks/_doc/${extras.taskId}`, + path: `/_tasks/${extras.taskId}`, method: "GET", }, }); if (tasksResult.ok) { - const { _source, found } = tasksResult.response; - const { completed, error } = (_source || {}) as TaskResult["_source"]; - if (completed && found) { + const _source = tasksResult.response; + const { completed, error } = (_source || {}) as TaskResult; + if (completed) { if (extras.toastId) { core.notifications.toasts.remove(extras.toastId); } diff --git a/public/JobHandler/callbacks/split.test.tsx b/public/JobHandler/callbacks/split.test.tsx index 04f920c2c..df9d9a223 100644 --- a/public/JobHandler/callbacks/split.test.tsx +++ b/public/JobHandler/callbacks/split.test.tsx @@ -41,10 +41,7 @@ describe("callbackForOpen spec", () => { it("callback when not complete", async () => { httpClientMock.fetch = getMockFn({ - found: true, - _source: { - completed: false, - }, + completed: false, }); const result = await callbackForSplit(splitMetaData, { core, @@ -54,10 +51,7 @@ describe("callbackForOpen spec", () => { it("callback when successfully complete", async () => { httpClientMock.fetch = getMockFn({ - found: true, - _source: { - completed: true, - }, + completed: true, }); const result = await callbackForSplit(splitMetaData, { core, @@ -69,20 +63,17 @@ describe("callbackForOpen spec", () => { it("callback when failed", async () => { httpClientMock.fetch = getMockFn({ - found: true, - _source: { - completed: true, - error: { - reason: "reason", - }, - failures: [ - { - cause: { - reason: "cause", - }, - }, - ], + completed: true, + error: { + reason: "reason", }, + failures: [ + { + cause: { + reason: "cause", + }, + }, + ], }); const result = await callbackForSplit(splitMetaData, { core, diff --git a/public/JobHandler/callbacks/split.tsx b/public/JobHandler/callbacks/split.tsx index 260a578e0..ff39d60d7 100644 --- a/public/JobHandler/callbacks/split.tsx +++ b/public/JobHandler/callbacks/split.tsx @@ -17,14 +17,14 @@ export const callbackForSplit: CallbackType = async (job: RecoveryJobMetaData, { const tasksResult = await commonService.apiCaller({ endpoint: "transport.request", data: { - path: `/.tasks/_doc/${extras.taskId}`, + path: `/_tasks/${extras.taskId}`, method: "GET", }, }); if (tasksResult.ok) { - const { _source, found } = tasksResult.response; - const { completed, error } = (_source || {}) as TaskResult["_source"]; - if (completed && found) { + const _source = tasksResult.response; + const { completed, error } = (_source || {}) as TaskResult; + if (completed) { if (extras.toastId) { core.notifications.toasts.remove(extras.toastId); } diff --git a/public/JobHandler/interface.ts b/public/JobHandler/interface.ts index 08d42638a..88f015397 100644 --- a/public/JobHandler/interface.ts +++ b/public/JobHandler/interface.ts @@ -13,14 +13,11 @@ export type CallbackType = ( ) => Promise; export type TaskResult = { - found: boolean; - _source: { - completed: boolean; - response: T; - error?: { - type: string; - reason: string; - }; + completed: boolean; + response: T; + error?: { + type: string; + reason: string; }; };