|
19 | 19 | permissions: |
20 | 20 | contents: read |
21 | 21 |
|
22 | | -env: |
23 | | - PYTHON_VERSION: "3.11" |
24 | | - |
25 | 22 | jobs: |
26 | | - run-tests: |
27 | | - runs-on: ubuntu-latest |
28 | | - environment: ${{ (github.event_name == 'pull_request_target' && github.event.pull_request.head.repo.full_name != github.repository) && 'cloud-tests' || '' }} |
29 | | - strategy: |
30 | | - fail-fast: false |
31 | | - matrix: |
32 | | - adapter: [snowflake, bigquery, redshift, databricks] |
33 | | - |
34 | | - steps: |
35 | | - - name: "Checkout PR code" |
36 | | - uses: actions/checkout@v4 |
37 | | - with: |
38 | | - # For pull_request_target, we must explicitly checkout the PR head |
39 | | - ref: ${{ github.event.pull_request.head.sha || github.ref }} |
40 | | - |
41 | | - - name: "Set up Python ${{ env.PYTHON_VERSION }}" |
42 | | - uses: actions/setup-python@v5 |
43 | | - with: |
44 | | - python-version: ${{ env.PYTHON_VERSION }} |
45 | | - |
46 | | - - name: "Install dbt-${{ matrix.adapter }}" |
47 | | - run: | |
48 | | - python -m pip install --upgrade pip |
49 | | - pip install dbt-${{ matrix.adapter }} |
50 | | -
|
51 | | - - name: "Install tox" |
52 | | - run: | |
53 | | - pip install tox |
54 | | -
|
55 | | - - name: "Run integration tests on ${{ matrix.adapter }}" |
56 | | - run: | |
57 | | - tox -e dbt_integration_${{ matrix.adapter }} |
58 | | - env: |
59 | | - # snowflake |
60 | | - SNOWFLAKE_ACCOUNT: ${{ secrets.SNOWFLAKE_ACCOUNT }} |
61 | | - SNOWFLAKE_USER: ${{ vars.SNOWFLAKE_USER }} |
62 | | - DBT_ENV_SECRET_SNOWFLAKE_PASS: ${{ secrets.SNOWFLAKE_PASS }} |
63 | | - SNOWFLAKE_ROLE: ${{ vars.SNOWFLAKE_ROLE }} |
64 | | - SNOWFLAKE_DATABASE: ${{ vars.SNOWFLAKE_DATABASE }} |
65 | | - SNOWFLAKE_WAREHOUSE: ${{ vars.SNOWFLAKE_WAREHOUSE }} |
66 | | - SNOWFLAKE_SCHEMA: "dbt_project_evaluator_integration_tests_snowflake_${{ github.run_number }}" |
67 | | - # bigquery |
68 | | - BIGQUERY_PROJECT: ${{ vars.BIGQUERY_PROJECT }} |
69 | | - BIGQUERY_KEYFILE_JSON: ${{ secrets.BIGQUERY_KEYFILE_JSON }} |
70 | | - BIGQUERY_SCHEMA: "dpe_integration_tests_bigquery_${{ github.run_number }}" |
71 | | - # redshift |
72 | | - REDSHIFT_HOST: ${{ vars.REDSHIFT_HOST }} |
73 | | - REDSHIFT_USER: ${{ vars.REDSHIFT_USER }} |
74 | | - DBT_ENV_SECRET_REDSHIFT_PASS: ${{ secrets.REDSHIFT_PASS }} |
75 | | - REDSHIFT_DATABASE: ${{ vars.REDSHIFT_DATABASE }} |
76 | | - REDSHIFT_SCHEMA: "dpe_integration_tests_redshift_${{ github.run_number }}" |
77 | | - REDSHIFT_PORT: 5439 |
78 | | - # databricks |
79 | | - DATABRICKS_HOST: ${{ vars.DATABRICKS_HOST }} |
80 | | - DATABRICKS_HTTP_PATH: ${{ vars.DATABRICKS_HTTP_PATH }} |
81 | | - DBT_ENV_SECRET_DATABRICKS_TOKEN: ${{ secrets.DBT_ENV_SECRET_DATABRICKS_TOKEN }} |
82 | | - DATABRICKS_SCHEMA: "integration_tests_databricks_${{ github.run_number }}" |
| 23 | + core-tests: |
| 24 | + uses: dbt-labs/dbt-package-testing/.github/workflows/run_tox.yml@v2 |
| 25 | + with: |
| 26 | + # Adapters are read from supported_adapters.env if not specified here |
| 27 | + adapters: "snowflake,bigquery,redshift,databricks" |
| 28 | + # For pull_request_target: require environment approval for fork PRs |
| 29 | + environment: >- |
| 30 | + ${{ github.event_name == 'pull_request_target' |
| 31 | + && github.event.pull_request.head.repo.full_name != github.repository |
| 32 | + && 'cloud-tests' || '' }} |
| 33 | + # For pull_request_target: checkout the PR head, not the base branch |
| 34 | + ref: ${{ github.event.pull_request.head.sha || '' }} |
| 35 | + # snowflake |
| 36 | + SNOWFLAKE_USER: ${{ vars.SNOWFLAKE_USER }} |
| 37 | + SNOWFLAKE_ROLE: ${{ vars.SNOWFLAKE_ROLE }} |
| 38 | + SNOWFLAKE_DATABASE: ${{ vars.SNOWFLAKE_DATABASE }} |
| 39 | + SNOWFLAKE_WAREHOUSE: ${{ vars.SNOWFLAKE_WAREHOUSE }} |
| 40 | + SNOWFLAKE_SCHEMA: "dbt_project_evaluator_integration_tests_snowflake_${{ github.run_number }}" |
| 41 | + # bigquery |
| 42 | + BIGQUERY_PROJECT: ${{ vars.BIGQUERY_PROJECT }} |
| 43 | + BIGQUERY_SCHEMA: "dpe_integration_tests_bigquery_${{ github.run_number }}" |
| 44 | + # redshift |
| 45 | + REDSHIFT_HOST: ${{ vars.REDSHIFT_HOST }} |
| 46 | + REDSHIFT_USER: ${{ vars.REDSHIFT_USER }} |
| 47 | + REDSHIFT_DATABASE: ${{ vars.REDSHIFT_DATABASE }} |
| 48 | + REDSHIFT_SCHEMA: "dpe_integration_tests_redshift_${{ github.run_number }}" |
| 49 | + REDSHIFT_PORT: "5439" |
| 50 | + # databricks |
| 51 | + DATABRICKS_SCHEMA: "integration_tests_databricks_${{ github.run_number }}" |
| 52 | + DATABRICKS_HOST: ${{ vars.DATABRICKS_HOST }} |
| 53 | + DATABRICKS_HTTP_PATH: ${{ vars.DATABRICKS_HTTP_PATH }} |
| 54 | + secrets: |
| 55 | + SNOWFLAKE_ACCOUNT: ${{ secrets.SNOWFLAKE_ACCOUNT }} |
| 56 | + DBT_ENV_SECRET_SNOWFLAKE_PASS: ${{ secrets.SNOWFLAKE_PASS }} |
| 57 | + BIGQUERY_KEYFILE_JSON: ${{ secrets.BIGQUERY_KEYFILE_JSON }} |
| 58 | + DBT_ENV_SECRET_REDSHIFT_PASS: ${{ secrets.REDSHIFT_PASS }} |
| 59 | + DBT_ENV_SECRET_DATABRICKS_TOKEN: ${{ secrets.DBT_ENV_SECRET_DATABRICKS_TOKEN }} |
0 commit comments