From 357940170a5c9cf379b58b1704b5e0f2b574777b Mon Sep 17 00:00:00 2001 From: priyabhatnagar Date: Fri, 28 Jul 2023 21:04:49 +0530 Subject: [PATCH 1/3] BQMT e2e Tests Scenarios --- .github/workflows/e2e.yml | 31 ++- pom.xml | 8 + .../BiqQueryMultiTableSinkError.feature | 79 +++++++ ...ToBigQueryMultiTableSink_WithMacro.feature | 131 +++++++++++ ...abaseTableToBiqQueryMultiTableSink.feature | 104 +++++++++ .../runners/TestRunner.java | 38 +++ .../runners/TestRunnerRequired.java | 39 ++++ .../runners/package-info.java | 4 + .../stepdesign/BQMultiTableValidation.java | 220 ++++++++++++++++++ .../stepdesign/BigQueryMultiTable.java | 42 ++++ .../stepdesign/MultiTableClient.java | 67 ++++++ .../stepdesign/package-info.java | 20 ++ .../common/stepsdesign/TestSetupHooks.java | 22 ++ .../resources/errorMessage.properties | 5 + .../pluginDataCyAttributes.properties | 2 + .../resources/pluginParameters.properties | 16 ++ 16 files changed, 825 insertions(+), 3 deletions(-) create mode 100644 src/e2e-test/features/bigquerymultitable/BiqQueryMultiTableSinkError.feature create mode 100644 src/e2e-test/features/bigquerymultitable/MultipleDatabaseTableToBigQueryMultiTableSink_WithMacro.feature create mode 100644 src/e2e-test/features/bigquerymultitable/MultipleDatabaseTableToBiqQueryMultiTableSink.feature create mode 100644 src/e2e-test/java/io/cdap/plugin/bigquerymultitable/runners/TestRunner.java create mode 100644 src/e2e-test/java/io/cdap/plugin/bigquerymultitable/runners/TestRunnerRequired.java create mode 100644 src/e2e-test/java/io/cdap/plugin/bigquerymultitable/runners/package-info.java create mode 100644 src/e2e-test/java/io/cdap/plugin/bigquerymultitable/stepdesign/BQMultiTableValidation.java create mode 100644 src/e2e-test/java/io/cdap/plugin/bigquerymultitable/stepdesign/BigQueryMultiTable.java create mode 100644 src/e2e-test/java/io/cdap/plugin/bigquerymultitable/stepdesign/MultiTableClient.java create mode 100644 src/e2e-test/java/io/cdap/plugin/bigquerymultitable/stepdesign/package-info.java diff --git a/.github/workflows/e2e.yml b/.github/workflows/e2e.yml index e10d21f28f..60d4f7b66e 100644 --- a/.github/workflows/e2e.yml +++ b/.github/workflows/e2e.yml @@ -1,4 +1,4 @@ -# Copyright © 2021 Cask Data, Inc. +# Copyright © 2021-2023 Cask Data, Inc. # Licensed under the Apache License, Version 2.0 (the "License"); you may not # use this file except in compliance with the License. You may obtain a copy of # the License at @@ -40,7 +40,7 @@ jobs: ) strategy: matrix: - tests: [bigquery, common, gcs, pubsub, spanner, gcscreate, gcsdelete, gcsmove, bigqueryexecute, gcscopy] + tests: [bigquery, common, gcs, pubsub, spanner, gcscreate, gcsdelete, gcsmove, bigqueryexecute, gcscopy, bigquerymultitable] fail-fast: false steps: # Pinned 1.0.0 version @@ -68,13 +68,38 @@ jobs: key: ${{ runner.os }}-maven-${{ github.workflow }}-${{ hashFiles('**/pom.xml') }} restore-keys: | ${{ runner.os }}-maven-${{ github.workflow }} + + - name: Get Secrets from GCP Secret Manager + id: secrets + uses: 'google-github-actions/get-secretmanager-secrets@v0' + with: + secrets: |- + MYSQL_HOST:cdapio-github-builds/MYSQL_HOST + MYSQL_USERNAME:cdapio-github-builds/MYSQL_USERNAME + MYSQL_PASSWORD:cdapio-github-builds/MYSQL_PASSWORD + MYSQL_PORT:cdapio-github-builds/MYSQL_PORT + CONNECTION_STRING:cdapio-github-builds/CONNECTION_STRING + - name: Run required e2e tests if: github.event_name != 'workflow_dispatch' && github.event_name != 'push' && steps.filter.outputs.e2e-test == 'false' run: python3 e2e/src/main/scripts/run_e2e_test.py --testRunner **/${{ matrix.tests }}/**/TestRunnerRequired.java + env: + MYSQL_HOST: ${{ steps.secrets.outputs.MYSQL_HOST }} + MYSQL_USERNAME: ${{ steps.secrets.outputs.MYSQL_USERNAME }} + MYSQL_PASSWORD: ${{ steps.secrets.outputs.MYSQL_PASSWORD }} + MYSQL_PORT: ${{ steps.secrets.outputs.MYSQL_PORT }} + CONNECTION_STRING: ${{ steps.secrets.outputs.CONNECTION_STRING }} + - name: Run all e2e tests if: github.event_name == 'workflow_dispatch' || github.event_name == 'push' || steps.filter.outputs.e2e-test == 'true' run: python3 e2e/src/main/scripts/run_e2e_test.py --testRunner **/${{ matrix.tests }}/**/TestRunner.java - - name: Upload debug files + env: + MYSQL_HOST: ${{ steps.secrets.outputs.MYSQL_HOST }} + MYSQL_USERNAME: ${{ steps.secrets.outputs.MYSQL_USERNAME }} + MYSQL_PASSWORD: ${{ steps.secrets.outputs.MYSQL_PASSWORD }} + MYSQL_PORT: ${{ steps.secrets.outputs.MYSQL_PORT }} + CONNECTION_STRING: ${{ steps.secrets.outputs.CONNECTION_STRING }} + - name: Upload debug files uses: actions/upload-artifact@v3 if: always() with: diff --git a/pom.xml b/pom.xml index fc710f9c03..344b957b8d 100644 --- a/pom.xml +++ b/pom.xml @@ -1,4 +1,5 @@ +