0c1fd28b9cdfbbfebd4ce363c282b51922b6d272
[puppet-modules/puppetlabs-apt.git] / .github / workflows / nightly.yml
1 name: "nightly"
2
3 on:
4   schedule:
5     - cron: '0 0 * * *'
6
7 env:
8   HONEYCOMB_WRITEKEY: 7f3c63a70eecc61d635917de46bea4e6
9   HONEYCOMB_DATASET: litmus tests
10
11 jobs:
12   setup_matrix:
13     name: "Setup Test Matrix"
14     runs-on: ubuntu-20.04
15     outputs:
16       matrix: ${{ steps.get-matrix.outputs.matrix }}
17
18     steps:
19     - name: "Honeycomb: Start recording"
20       uses: puppetlabs/kvrhdn-gha-buildevents@pdk-templates-v1
21       with:
22         apikey: ${{ env.HONEYCOMB_WRITEKEY }}
23         dataset: ${{ env.HONEYCOMB_DATASET }}
24         job-status: ${{ job.status }}
25
26     - name: "Honeycomb: Start first step"
27       run: |
28         echo STEP_ID=setup-environment >> $GITHUB_ENV
29         echo STEP_START=$(date +%s) >> $GITHUB_ENV
30
31     - name: Checkout Source
32       uses: actions/checkout@v2
33       if: ${{ github.repository_owner == 'puppetlabs' }}
34
35     - name: Activate Ruby 2.7
36       uses: ruby/setup-ruby@v1
37       if: ${{ github.repository_owner == 'puppetlabs' }}
38       with:
39         ruby-version: "2.7"
40         bundler-cache: true
41
42     - name: Print bundle environment
43       if: ${{ github.repository_owner == 'puppetlabs' }}
44       run: |
45         echo ::group::bundler environment
46         buildevents cmd $TRACE_ID $STEP_ID 'bundle env' -- bundle env
47         echo ::endgroup::
48
49     - name: "Honeycomb: Record Setup Environment time"
50       if: ${{ github.repository_owner == 'puppetlabs' }}
51       run: |
52         buildevents step $TRACE_ID $STEP_ID $STEP_START 'Setup Environment'
53         echo STEP_ID=Setup-Acceptance-Test-Matrix >> $GITHUB_ENV
54         echo STEP_START=$(date +%s) >> $GITHUB_ENV
55
56     - name: Setup Acceptance Test Matrix
57       id: get-matrix
58       if: ${{ github.repository_owner == 'puppetlabs' }}
59       run: |
60         if [ '${{ github.repository_owner }}' == 'puppetlabs' ]; then
61           buildevents cmd $TRACE_ID $STEP_ID matrix_from_metadata -- bundle exec matrix_from_metadata
62         else
63           echo  "::set-output name=matrix::{}"
64         fi
65
66     - name: "Honeycomb: Record Setup Test Matrix time"
67       if: ${{ always() }}
68       run: |
69         buildevents step $TRACE_ID $STEP_ID $STEP_START 'Setup Test Matrix'
70
71   Acceptance:
72     needs:
73       - setup_matrix
74
75     runs-on: ubuntu-20.04
76     strategy:
77       fail-fast: false
78       matrix: ${{fromJson(needs.setup_matrix.outputs.matrix)}}
79
80     env:
81       BUILDEVENT_FILE: '../buildevents.txt'
82
83     steps:
84     - run: |
85         echo 'platform=${{ matrix.platform }}' >> $BUILDEVENT_FILE
86         echo 'collection=${{ matrix.collection }}' >> $BUILDEVENT_FILE
87
88     - name: "Honeycomb: Start recording"
89       uses: puppetlabs/kvrhdn-gha-buildevents@pdk-templates-v1
90       with:
91         apikey: ${{ env.HONEYCOMB_WRITEKEY }}
92         dataset: ${{ env.HONEYCOMB_DATASET }}
93         job-status: ${{ job.status }}
94         matrix-key: ${{ matrix.platform }}-${{ matrix.collection }}
95
96     - name: "Honeycomb: start first step"
97       run: |
98         echo STEP_ID=${{ matrix.platform }}-${{ matrix.collection }}-1 >> $GITHUB_ENV
99         echo STEP_START=$(date +%s) >> $GITHUB_ENV
100
101     - name: Checkout Source
102       uses: actions/checkout@v2
103
104     - name: Activate Ruby 2.7
105       uses: ruby/setup-ruby@v1
106       with:
107         ruby-version: "2.7"
108         bundler-cache: true
109
110     - name: Print bundle environment
111       run: |
112         echo ::group::bundler environment
113         buildevents cmd $TRACE_ID $STEP_ID 'bundle env' -- bundle env
114         echo ::endgroup::
115
116     - name: "Honeycomb: Record Setup Environment time"
117       if: ${{ always() }}
118       run: |
119         buildevents step $TRACE_ID $STEP_ID $STEP_START 'Setup Environment'
120         echo STEP_ID=${{ matrix.platform }}-${{ matrix.collection }}-2 >> $GITHUB_ENV
121         echo STEP_START=$(date +%s) >> $GITHUB_ENV
122
123     - name: Provision test environment
124       run: |
125         buildevents cmd $TRACE_ID $STEP_ID 'rake litmus:provision ${{ matrix.platform }}' -- bundle exec rake 'litmus:provision[provision::provision_service,${{ matrix.platform }}]'
126         echo ::group::=== REQUEST ===
127         cat request.json || true
128         echo
129         echo ::endgroup::
130         echo ::group::=== INVENTORY ===
131         sed -e 's/password: .*/password: "[redacted]"/' < inventory.yaml || true
132         echo ::endgroup::
133
134     - name: Install agent
135       run: |
136         buildevents cmd $TRACE_ID $STEP_ID 'rake litmus:install_agent ${{ matrix.collection }}' -- bundle exec rake 'litmus:install_agent[${{ matrix.collection }}]'
137
138     - name: Install module
139       run: |
140         buildevents cmd $TRACE_ID $STEP_ID 'rake litmus:install_module' -- bundle exec rake 'litmus:install_module'
141
142     - name: "Honeycomb: Record deployment times"
143       if: ${{ always() }}
144       run: |
145         echo ::group::honeycomb step
146         buildevents step $TRACE_ID $STEP_ID $STEP_START 'Deploy test system'
147         echo STEP_ID=${{ matrix.platform }}-${{ matrix.collection }}-3 >> $GITHUB_ENV
148         echo STEP_START=$(date +%s) >> $GITHUB_ENV
149         echo ::endgroup::
150
151     - name: Run acceptance tests
152       run: |
153         buildevents cmd $TRACE_ID $STEP_ID 'rake litmus:acceptance:parallel' -- bundle exec rake 'litmus:acceptance:parallel'
154
155     - name: "Honeycomb: Record acceptance testing times"
156       if: ${{ always() }}
157       run: |
158         buildevents step $TRACE_ID $STEP_ID $STEP_START 'Run acceptance tests'
159         echo STEP_ID=${{ matrix.platform }}-${{ matrix.collection }}-4 >> $GITHUB_ENV
160         echo STEP_START=$(date +%s) >> $GITHUB_ENV
161
162     - name: Remove test environment
163       if: ${{ always() }}
164       continue-on-error: true
165       run: |
166         if [ -f inventory.yaml ]; then
167           buildevents cmd $TRACE_ID $STEP_ID 'rake litmus:tear_down' -- bundle exec rake 'litmus:tear_down'
168           echo ::group::=== REQUEST ===
169           cat request.json || true
170           echo
171           echo ::endgroup::
172         fi
173
174     - name: "Honeycomb: Record removal times"
175       if: ${{ always() }}
176       run: |
177         buildevents step $TRACE_ID $STEP_ID $STEP_START 'Remove test environment'
178
179   slack-workflow-status:
180     if: always()
181     name: Post Workflow Status To Slack
182     needs:
183       - Acceptance
184     runs-on: ubuntu-20.04
185     steps:
186       - name: Slack Workflow Notification
187         uses: puppetlabs/Gamesight-slack-workflow-status@pdk-templates-v1
188         with:
189           # Required Input
190           repo_token: ${{ secrets.GITHUB_TOKEN }}
191           slack_webhook_url: ${{ secrets.SLACK_WEBHOOK }}
192           # Optional Input
193           channel: '#team-ia-bots'
194           name: 'GABot'