Skip to content

Ubuntu security updates component #25

Ubuntu security updates component

Ubuntu security updates component #25

Workflow file for this run

---
name: Molecule
on:
push:
branches:
- main
pull_request:
branches:
- main
jobs:
provide_scenarios:
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v4
with:
path: "${{ github.repository }}"
- name: Get changed files
id: changed-files-yaml
uses: tj-actions/changed-files@v39
with:
json: true
quotepath: false
files_yaml: |
playbooks:
- 'playbooks/*.yml'
roles:
- 'playbooks/roles/**/**'
- id: set-playbooks-matrix
run: echo "matrix=${{ steps.changed-files-yaml.outputs.playbooks_all_changed_files }}" >> $GITHUB_OUTPUT
- id: set-roles-matrix
run: echo "matrix=${{ steps.changed-files-yaml.outputs.playbooks_all_changed_files }}" >> $GITHUB_OUTPUT
- name: Debug
run: echo ${{ steps.set-playbooks-matrix.outputs.playbooks }}
outputs:
playbooks_matrix: ${{ steps.set-playbooks-matrix.outputs.matrix }}
roles_matrix: ${{ steps.set-roles-matrix.outputs.matrix }}
molecule_playbooks:
needs: provide_scenarios
runs-on: ubuntu-latest
if: ${{ needs.provide_scenarios.outputs.playbooks_matrix != '[]' && needs.provide_scenarios.outputs.playbooks_matrix != '' }}
strategy:
fail-fast: false
matrix:
playbooks: ${{ fromJSON(needs.provide_scenarios.outputs.playbooks_matrix) }}
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Filename to scenario name
id: set-scenario
run: echo "scenario_name=playbook-`basename -s .yml ${{ matrix.playbooks }}`" >> $GITHUB_OUTPUT
- name: Check if scenario exists
run: stat molecule/${{ steps.set-scenario.outputs.scenario_name }}
- name: Molecule tests for playbooks
uses: gofrolist/molecule-action@v2
if: ${{ success() }}
with:
molecule_command: test
molecule_args: --scenario-name ${{ steps.set-scenario.outputs.scenario_name }}
env:
ANSIBLE_FORCE_COLOR: '1'
molecule_roles:
needs: provide_scenarios
runs-on: ubuntu-latest
if: ${{ needs.provide_scenarios.outputs.roles_matrix != '[]' && needs.provide_scenarios.outputs.roles_matrix != '' }}
strategy:
fail-fast: false
matrix:
roles: ${{ fromJSON(needs.provide_scenarios.outputs.roles_matrix) }}
steps:
- name: Checkout
uses: actions/checkout@v4
if: ${{ success() }}
- name: Filename to scenario name
id: set-scenario
run: echo "role_name=role-`basename -s .yml ${{ matrix.roles }}`" >> $GITHUB_OUTPUT
- name: Check if scenario exists
run: stat molecule/${{ steps.set-scenario.outputs.role_name }}
- name: Molecule tests for playbooks
uses: gofrolist/molecule-action@v2
if: ${{ success() }}
with:
molecule_command: test
molecule_args: --scenario-name ${{ steps.set-scenario.outputs.scenario_name }}
env:
ANSIBLE_FORCE_COLOR: '1'