-
Notifications
You must be signed in to change notification settings - Fork 93
71 lines (67 loc) · 2.16 KB
/
functional-tests.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
name: functional-tests
on:
# we use pull_request_target to run the CI also for forks
pull_request_target:
types: [opened, reopened, synchronize, labeled]
push:
branches: [main]
workflow_dispatch:
inputs:
checkout-ref:
description: "Use this if running on a feature branch"
type: string
default: "main"
checkout-repository:
description: "Use this if running against a fork"
type: string
default: "dbt-labs/dbt-athena"
jobs:
# workflow that is invoked when for PRs with labels 'enable-functional-tests'
functional-tests-pr:
name: Functional Tests - PR
if: github.event_name == 'pull_request'
uses: ./.github/workflows/functional-tests-workflow.yml
strategy:
matrix:
package: ['dbt-athena', 'dbt-athena-community']
secrets: inherit
permissions:
id-token: write
contents: read
with:
checkout-ref: ${{ github.event.pull_request.head.ref }}
# this makes the workflow run on a fork
checkout-repository: ${{ github.event.pull_request.head.repo.full_name }}
package: ${{ matrix.package }}
# workflow that is invoked when a push to main happens
functional-tests-main:
name: Functional Tests - main
if: github.event_name == 'push'
uses: ./.github/workflows/functional-tests-workflow.yml
strategy:
matrix:
package: ['dbt-athena', 'dbt-athena-community']
secrets: inherit
permissions:
id-token: write
contents: read
with:
checkout-ref: ${{ github.ref }}
checkout-repository: ${{ github.repository }}
package: ${{ matrix.package }}
# workflow that is invoked when run manually in GitHub
functional-tests-dispatch:
name: Functional Tests - dispatch
if: github.event_name == 'workflow_dispatch'
uses: ./.github/workflows/functional-tests-workflow.yml
strategy:
matrix:
package: ['dbt-athena', 'dbt-athena-community']
secrets: inherit
permissions:
id-token: write
contents: read
with:
checkout-ref: ${{ inputs.checkout-ref }}
checkout-repository: ${{ inputs.checkout-repository }}
package: ${{ matrix.package }}