Update aws packages #484
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: ec2-pulumi-ansible | |
on: [push] | |
jobs: | |
ec2-pulumi-ansible: | |
runs-on: ubuntu-latest | |
env: | |
AWS_REGION: eu-central-1 | |
AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }} | |
AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }} | |
PULUMI_ACCESS_TOKEN: ${{ secrets.PULUMI_ACCESS_TOKEN }} | |
steps: | |
- uses: actions/checkout@v2 | |
- name: Cache pipenv virtualenvs incl. all pip packages | |
uses: actions/cache@v2 | |
with: | |
path: ~/.local/share/virtualenvs | |
key: ${{ runner.os }}-pipenv-${{ hashFiles('**/Pipfile.lock') }} | |
restore-keys: | | |
${{ runner.os }}-pipenv- | |
- uses: actions/setup-python@v2 | |
with: | |
python-version: '3.9' | |
- name: Install Pulumi CLI | |
uses: pulumi/action-install-pulumi-cli@v1.1.0 | |
- name: Install required dependencies with pipenv & login to Pulumi app & select stack | |
run: | | |
pip install pipenv | |
pipenv install | |
echo "login to app.pulumi.com with the predefined PULUMI_ACCESS_TOKEN" | |
pulumi login | |
echo "Select your Pulumi projects stack" | |
pulumi stack select dev | |
- name: Destroy pre-created Pulumi instances | |
run: pipenv run pulumi destroy --yes | |
- name: Generate EC2 keypair and save private key locally (since Pulumi isn't able to do that now) | |
run: pipenv run ansible-playbook keypair.yml | |
- name: Execute Pulumi to create EC2 instances | |
run: pipenv run pulumi up --yes | |
- name: Downloading the Ansible role 'docker' with ansible-galaxy & run Ansible role to install Docker on Ubuntu | |
run: | | |
pipenv run ansible-galaxy install -r requirements.yml -p roles/ | |
pipenv run ansible-playbook playbook.yml | |
- name: Use Testinfra with Pytest to execute our tests | |
run: pipenv run py.test -v tests/test_docker.py --ssh-identity-file=.ec2ssh/pulumi_key --ssh-config=tests/pytest_ssh_config --hosts='ssh://'$(pulumi stack output publicIp) | |
- name: Destroy Pulumi instances after successful tests | |
run: pipenv run pulumi destroy --yes |