6 HONEYCOMB_WRITEKEY: 7f3c63a70eecc61d635917de46bea4e6
7 HONEYCOMB_DATASET: litmus tests
11 name: "Setup Test Matrix"
14 matrix: ${{ steps.get-matrix.outputs.matrix }}
17 - name: "Honeycomb: Start recording"
18 uses: puppetlabs/kvrhdn-gha-buildevents@pdk-templates-v1
20 apikey: ${{ env.HONEYCOMB_WRITEKEY }}
21 dataset: ${{ env.HONEYCOMB_DATASET }}
22 job-status: ${{ job.status }}
24 - name: "Honeycomb: Start first step"
26 echo STEP_ID=setup-environment >> $GITHUB_ENV
27 echo STEP_START=$(date +%s) >> $GITHUB_ENV
29 - name: Checkout Source
30 uses: actions/checkout@v2
31 if: ${{ github.repository_owner == 'puppetlabs' }}
33 - name: Activate Ruby 2.7
34 uses: ruby/setup-ruby@v1
35 if: ${{ github.repository_owner == 'puppetlabs' }}
40 - name: Print bundle environment
41 if: ${{ github.repository_owner == 'puppetlabs' }}
43 echo ::group::bundler environment
44 buildevents cmd $TRACE_ID $STEP_ID 'bundle env' -- bundle env
47 - name: "Honeycomb: Record Setup Environment time"
48 if: ${{ github.repository_owner == 'puppetlabs' }}
50 buildevents step $TRACE_ID $STEP_ID $STEP_START 'Setup Environment'
51 echo STEP_ID=Setup-Acceptance-Test-Matrix >> $GITHUB_ENV
52 echo STEP_START=$(date +%s) >> $GITHUB_ENV
54 - name: Setup Acceptance Test Matrix
57 if [ '${{ github.repository_owner }}' == 'puppetlabs' ]; then
58 buildevents cmd $TRACE_ID $STEP_ID matrix_from_metadata -- bundle exec matrix_from_metadata
60 echo "::set-output name=matrix::{}"
63 - name: "Honeycomb: Record Setup Test Matrix time"
66 buildevents step $TRACE_ID $STEP_ID $STEP_START 'Setup Test Matrix'
71 if: ${{ needs.setup_matrix.outputs.matrix != '{}' }}
76 matrix: ${{fromJson(needs.setup_matrix.outputs.matrix)}}
79 BUILDEVENT_FILE: '../buildevents.txt'
83 echo 'platform=${{ matrix.platform }}' >> $BUILDEVENT_FILE
84 echo 'collection=${{ matrix.collection }}' >> $BUILDEVENT_FILE
86 - name: "Honeycomb: Start recording"
87 uses: puppetlabs/kvrhdn-gha-buildevents@pdk-templates-v1
89 apikey: ${{ env.HONEYCOMB_WRITEKEY }}
90 dataset: ${{ env.HONEYCOMB_DATASET }}
91 job-status: ${{ job.status }}
92 matrix-key: ${{ matrix.platform }}-${{ matrix.collection }}
94 - name: "Honeycomb: start first step"
96 echo STEP_ID=${{ matrix.platform }}-${{ matrix.collection }}-1 >> $GITHUB_ENV
97 echo STEP_START=$(date +%s) >> $GITHUB_ENV
99 - name: Checkout Source
100 uses: actions/checkout@v2
102 - name: Activate Ruby 2.7
103 uses: ruby/setup-ruby@v1
108 - name: Print bundle environment
110 echo ::group::bundler environment
111 buildevents cmd $TRACE_ID $STEP_ID 'bundle env' -- bundle env
114 - name: "Honeycomb: Record Setup Environment time"
117 buildevents step $TRACE_ID $STEP_ID $STEP_START 'Setup Environment'
118 echo STEP_ID=${{ matrix.platform }}-${{ matrix.collection }}-2 >> $GITHUB_ENV
119 echo STEP_START=$(date +%s) >> $GITHUB_ENV
121 - name: Provision test environment
123 buildevents cmd $TRACE_ID $STEP_ID 'rake litmus:provision ${{ matrix.platform }}' -- bundle exec rake 'litmus:provision[provision::provision_service,${{ matrix.platform }}]'
124 echo ::group::=== REQUEST ===
125 cat request.json || true
128 echo ::group::=== INVENTORY ===
129 sed -e 's/password: .*/password: "[redacted]"/' < inventory.yaml || true
132 - name: Install agent
134 buildevents cmd $TRACE_ID $STEP_ID 'rake litmus:install_agent ${{ matrix.collection }}' -- bundle exec rake 'litmus:install_agent[${{ matrix.collection }}]'
136 - name: Install module
138 buildevents cmd $TRACE_ID $STEP_ID 'rake litmus:install_module' -- bundle exec rake 'litmus:install_module'
140 - name: "Honeycomb: Record deployment times"
143 echo ::group::honeycomb step
144 buildevents step $TRACE_ID $STEP_ID $STEP_START 'Deploy test system'
145 echo STEP_ID=${{ matrix.platform }}-${{ matrix.collection }}-3 >> $GITHUB_ENV
146 echo STEP_START=$(date +%s) >> $GITHUB_ENV
149 - name: Run acceptance tests
151 buildevents cmd $TRACE_ID $STEP_ID 'rake litmus:acceptance:parallel' -- bundle exec rake 'litmus:acceptance:parallel'
153 - name: "Honeycomb: Record acceptance testing times"
156 buildevents step $TRACE_ID $STEP_ID $STEP_START 'Run acceptance tests'
157 echo STEP_ID=${{ matrix.platform }}-${{ matrix.collection }}-4 >> $GITHUB_ENV
158 echo STEP_START=$(date +%s) >> $GITHUB_ENV
160 - name: Remove test environment
162 continue-on-error: true
164 if [ -f inventory.yaml ]; then
165 buildevents cmd $TRACE_ID $STEP_ID 'rake litmus:tear_down' -- bundle exec rake 'litmus:tear_down'
166 echo ::group::=== REQUEST ===
167 cat request.json || true
172 - name: "Honeycomb: Record removal times"
175 buildevents step $TRACE_ID $STEP_ID $STEP_START 'Remove test environment'