8 HONEYCOMB_WRITEKEY: 7f3c63a70eecc61d635917de46bea4e6
9 HONEYCOMB_DATASET: litmus tests
13 name: "Setup Test Matrix"
16 matrix: ${{ steps.get-matrix.outputs.matrix }}
19 - name: "Honeycomb: Start recording"
20 uses: puppetlabs/kvrhdn-gha-buildevents@pdk-templates-v1
22 apikey: ${{ env.HONEYCOMB_WRITEKEY }}
23 dataset: ${{ env.HONEYCOMB_DATASET }}
24 job-status: ${{ job.status }}
26 - name: "Honeycomb: Start first step"
28 echo STEP_ID=setup-environment >> $GITHUB_ENV
29 echo STEP_START=$(date +%s) >> $GITHUB_ENV
31 - name: Checkout Source
32 uses: actions/checkout@v2
33 if: ${{ github.repository_owner == 'puppetlabs' }}
35 - name: Activate Ruby 2.7
36 uses: ruby/setup-ruby@v1
37 if: ${{ github.repository_owner == 'puppetlabs' }}
42 - name: Print bundle environment
43 if: ${{ github.repository_owner == 'puppetlabs' }}
45 echo ::group::bundler environment
46 buildevents cmd $TRACE_ID $STEP_ID 'bundle env' -- bundle env
49 - name: "Honeycomb: Record Setup Environment time"
50 if: ${{ github.repository_owner == 'puppetlabs' }}
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
56 - name: Setup Acceptance Test Matrix
58 if: ${{ github.repository_owner == 'puppetlabs' }}
60 if [ '${{ github.repository_owner }}' == 'puppetlabs' ]; then
61 buildevents cmd $TRACE_ID $STEP_ID matrix_from_metadata -- bundle exec matrix_from_metadata
63 echo "::set-output name=matrix::{}"
66 - name: "Honeycomb: Record Setup Test Matrix time"
69 buildevents step $TRACE_ID $STEP_ID $STEP_START 'Setup Test Matrix'
78 matrix: ${{fromJson(needs.setup_matrix.outputs.matrix)}}
81 BUILDEVENT_FILE: '../buildevents.txt'
85 echo 'platform=${{ matrix.platform }}' >> $BUILDEVENT_FILE
86 echo 'collection=${{ matrix.collection }}' >> $BUILDEVENT_FILE
88 - name: "Honeycomb: Start recording"
89 uses: puppetlabs/kvrhdn-gha-buildevents@pdk-templates-v1
91 apikey: ${{ env.HONEYCOMB_WRITEKEY }}
92 dataset: ${{ env.HONEYCOMB_DATASET }}
93 job-status: ${{ job.status }}
94 matrix-key: ${{ matrix.platform }}-${{ matrix.collection }}
96 - name: "Honeycomb: start first step"
98 echo STEP_ID=${{ matrix.platform }}-${{ matrix.collection }}-1 >> $GITHUB_ENV
99 echo STEP_START=$(date +%s) >> $GITHUB_ENV
101 - name: Checkout Source
102 uses: actions/checkout@v2
104 - name: Activate Ruby 2.7
105 uses: ruby/setup-ruby@v1
110 - name: Print bundle environment
112 echo ::group::bundler environment
113 buildevents cmd $TRACE_ID $STEP_ID 'bundle env' -- bundle env
116 - name: "Honeycomb: Record Setup Environment time"
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
123 - name: Provision test environment
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
130 echo ::group::=== INVENTORY ===
131 sed -e 's/password: .*/password: "[redacted]"/' < inventory.yaml || true
134 - name: Install agent
136 buildevents cmd $TRACE_ID $STEP_ID 'rake litmus:install_agent ${{ matrix.collection }}' -- bundle exec rake 'litmus:install_agent[${{ matrix.collection }}]'
138 - name: Install module
140 buildevents cmd $TRACE_ID $STEP_ID 'rake litmus:install_module' -- bundle exec rake 'litmus:install_module'
142 - name: "Honeycomb: Record deployment times"
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
151 - name: Run acceptance tests
153 buildevents cmd $TRACE_ID $STEP_ID 'rake litmus:acceptance:parallel' -- bundle exec rake 'litmus:acceptance:parallel'
155 - name: "Honeycomb: Record acceptance testing times"
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
162 - name: Remove test environment
164 continue-on-error: true
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
174 - name: "Honeycomb: Record removal times"
177 buildevents step $TRACE_ID $STEP_ID $STEP_START 'Remove test environment'
179 slack-workflow-status:
181 name: Post Workflow Status To Slack
184 runs-on: ubuntu-20.04
186 - name: Slack Workflow Notification
187 uses: puppetlabs/Gamesight-slack-workflow-status@pdk-templates-v1
190 repo_token: ${{ secrets.GITHUB_TOKEN }}
191 slack_webhook_url: ${{ secrets.SLACK_WEBHOOK }}
193 channel: '#team-ia-bots'