diff --git a/.github/workflows/podman_image.yml b/.github/workflows/podman_image.yml new file mode 100644 index 0000000..43b4aa8 --- /dev/null +++ b/.github/workflows/podman_image.yml @@ -0,0 +1,101 @@ +name: Podman image + +on: + push: + paths: + - '.github/workflows/podman_image.yml' + - 'ci/*.yml' + - 'ci/containers/podman_image.yml' + - 'plugins/modules/podman_image.py' + - 'plugins/modules/podman_image_info.py' + - 'tests/integration/targets/podman_image/**' + branches: + - master + pull_request: + paths: + - '.github/workflows/podman_image.yml' + - 'ci/*.yml' + - 'ci/containers/podman_image.yml' + - 'plugins/modules/podman_image.py' + - 'plugins/modules/podman_image_info.py' + - 'tests/integration/targets/podman_image/**' + schedule: + - cron: 4 0 * * * # Run daily at 0:03 UTC + +jobs: + + test_podman_container: + name: Podman container ${{ matrix.ansible-version }}-${{ matrix.os.vm || 'ubuntu-latest' }} + runs-on: ${{ matrix.os.vm || 'ubuntu-latest' }} + defaults: + run: + shell: bash + strategy: + fail-fast: false + matrix: + ansible-version: + - ansible<2.10 + - git+https://github.com/ansible/ansible.git@devel + os: + - vm: ubuntu-latest + python-version: + - 3.7 + steps: + + - name: Check out repository + uses: actions/checkout@v2 + + - name: Set up Python ${{ matrix.python-version }} + uses: actions/setup-python@v2 + with: + python-version: ${{ matrix.python-version }} + + - name: Upgrade pip and display Python and PIP versions + run: | + python -m pip install --upgrade pip + python -V + pip --version + + - name: Set up pip cache + uses: actions/cache@v1 + with: + path: ~/.cache/pip + key: ${{ runner.os }}-pip-${{ github.ref }}-units-VMs + restore-keys: | + ${{ runner.os }}-pip- + ${{ runner.os }}- + + - name: Install Ansible ${{ matrix.ansible-version }} + run: python -m pip install --user '${{ matrix.ansible-version }}' + + - name: Build and install the collection tarball + run: | + rm -rf /tmp/just_new_collection + ~/.local/bin/ansible-galaxy collection build --output-path /tmp/just_new_collection --force + ~/.local/bin/ansible-galaxy collection install -vvv --force /tmp/just_new_collection/*.tar.gz + sudo ~/.local/bin/ansible-galaxy collection install -vvv --force /tmp/just_new_collection/*.tar.gz + + - name: Run collection tests for connection + run: | + export PATH=~/.local/bin:$PATH + + if [[ '${{ matrix.ansible-version }}' == 'git+https://github.com/ansible/ansible.git@devel' ]]; then + export ANSIBLE_CONFIG=$(pwd)/ci/ansible-dev.cfg + elif [[ '${{ matrix.ansible-version }}' == 'ansible<2.10' ]]; then + export ANSIBLE_CONFIG=$(pwd)/ci/ansible-2.9.cfg + fi + + echo $ANSIBLE_CONFIG + command -v ansible-playbook + pip --version + python --version + ansible-playbook --version + + ansible-playbook -vv ci/playbooks/pre.yml \ + -e host=localhost \ + -i localhost, \ + -e ansible_connection=local \ + -e setup_python=false + + TEST2RUN=podman_image ./ci/run_containers_tests.sh + shell: bash diff --git a/ci/playbooks/containers/podman_image.yml b/ci/playbooks/containers/podman_image.yml new file mode 100644 index 0000000..65bbb98 --- /dev/null +++ b/ci/playbooks/containers/podman_image.yml @@ -0,0 +1,6 @@ +--- +- hosts: all + gather_facts: true + tasks: + - include_role: + name: podman_image diff --git a/tests/integration/targets/podman_image/aliases b/tests/integration/targets/podman_image/aliases deleted file mode 100644 index 137b828..0000000 --- a/tests/integration/targets/podman_image/aliases +++ /dev/null @@ -1,5 +0,0 @@ -shippable/posix/group3 -skip/aix -skip/osx -skip/freebsd -destructive diff --git a/tests/integration/targets/podman_image/meta/main.yml b/tests/integration/targets/podman_image/meta/main.yml deleted file mode 100644 index f514004..0000000 --- a/tests/integration/targets/podman_image/meta/main.yml +++ /dev/null @@ -1,2 +0,0 @@ -dependencies: - - setup_podman diff --git a/tests/integration/targets/podman_image/tasks/main.yml b/tests/integration/targets/podman_image/tasks/main.yml index e3f7375..70e9370 100644 --- a/tests/integration/targets/podman_image/tasks/main.yml +++ b/tests/integration/targets/podman_image/tasks/main.yml @@ -1,7 +1,4 @@ - name: Test podman_image - when: - - ansible_facts.virtualization_type != 'docker' - - ansible_facts.distribution == 'RedHat' block: - name: Pull image containers.podman.podman_image: