Skip to content

.github/workflows/spectesting.yml #303

.github/workflows/spectesting.yml

.github/workflows/spectesting.yml #303

Workflow file for this run

on:
# Allows manual trigger on arbitrary branches via GitHub UI/API
workflow_dispatch:
repository_dispatch:
types: [prerelease]
schedule:
# Run nightly on weekdays at 05:00 UTC or midnight-ish in US time zones
- cron: '0 5 * * 1-5'
jobs:
setup-packet:
if: github.repository == 'hashicorp/vagrant-acceptance'
runs-on: ['self-hosted', 'ondemand', 'linux', 'type=t3.nano']
name: Build Packet Instance
steps:
- name: Authentication
id: vault-auth
run: vault-auth
- name: Secrets
id: secrets
uses: hashicorp/vault-action@v2
with:
url: ${{ steps.vault-auth.outputs.addr }}
caCertificate: ${{ steps.vault-auth.outputs.ca_certificate }}
token: ${{ steps.vault-auth.outputs.token }}
secrets:
kv/data/teams/vagrant/slack webhook | slack_webhook;
kv/data/teams/vagrant/packet token | packet_token;
kv/data/teams/vagrant/packet project_id | packet_project_id;
kv/data/teams/vagrant/packet ssh_key_content | packet_ssh_key_content;
- name: Code Checkout
uses: actions/checkout@v3
- name: Create packet instance
run: ./.ci/spec/create-packet.sh
working-directory: ${{github.workspace}}
env:
PACKET_EXEC_TOKEN: ${{ steps.secrets.outputs.packet_token }}
PACKET_EXEC_PROJECT_ID: ${{ steps.secrets.outputs.packet_project_id }}
PACKET_SSH_KEY_CONTENT: ${{ steps.secrets.outputs.packet_ssh_key_content }}
SLACK_WEBHOOK: ${{ steps.secrets.outputs.slack_webhook }}
setup-hosts:
if: github.repository == 'hashicorp/vagrant-acceptance'
runs-on: ['self-hosted', 'ondemand', 'linux', 'type=t3.nano']
name: Vagrant-Spec Start Hosts
needs: setup-packet
strategy:
matrix:
host_os: ['hashicorp/bionic64']
guest_os: ['hashicorp-vagrant/ubuntu-16.04']
providers: ['virtualbox', 'docker']
steps:
- name: Code Checkout
uses: actions/checkout@v3
with:
submodules: 'recursive'
- name: Create hosts for tests (provider ${{ matrix.providers }})
run: ./.ci/spec/create-hosts.sh
working-directory: ${{github.workspace}}
env:
PACKET_EXEC_TOKEN: ${{ steps.secrets.outputs.packet_token }}
PACKET_EXEC_PROJECT_ID: ${{ steps.secrets.outputs.packet_project_id }}
PACKET_SSH_KEY_CONTENT: ${{ steps.secrets.outputs.packet_ssh_key_content }}
SLACK_WEBHOOK: ${{ steps.secrets.outputs.slack_webhook }}
VAGRANT_HOST_BOXES: ${{matrix.host_os}}
VAGRANT_GUEST_BOXES: ${{matrix.guest_os}}
VAGRANT_PRERELEASE_VERSION: ${{ github.event.client_payload.prerelease_version }}
VAGRANT_SPEC_PROVIDERS: ${{matrix.providers}}
spec-tests:
if: github.repository == 'hashicorp/vagrant-acceptance'
runs-on: ['self-hosted', 'ondemand', 'linux', 'type=t3.nano']
name: Vagrant-Spec Tests
needs: setup-hosts
strategy:
matrix:
host_os: ['hashicorp/bionic64']
guest_os: ['hashicorp-vagrant/ubuntu-16.04']
docker_images: ['nginx']
providers: ['virtualbox', 'docker']
steps:
- name: Run Tests with host ${{ matrix.host_os }} using provider ${{ matrix.providers }}
run: ./.ci/spec/run-test.sh
working-directory: ${{github.workspace}}
env:
PACKET_EXEC_TOKEN: ${{ steps.secrets.outputs.packet_token }}
PACKET_EXEC_PROJECT_ID: ${{ steps.secrets.outputs.packet_project_id }}
PACKET_SSH_KEY_CONTENT: ${{ steps.secrets.outputs.packet_ssh_key_content }}
SLACK_WEBHOOK: ${{ steps.secrets.outputs.slack_webhook }}
VAGRANT_HOST_BOXES: ${{matrix.host_os}}
VAGRANT_GUEST_BOXES: ${{matrix.guest_os}}
VAGRANT_SPEC_PROVIDERS: ${{matrix.providers}}
VAGRANT_DOCKER_IMAGES: ${{matrix.docker_images}}
- name: Pull log from guest
if: always()
run: ./.ci/spec/pull-log.sh
env:
PACKET_EXEC_TOKEN: ${{ steps.secrets.outputs.packet_token }}
PACKET_EXEC_PROJECT_ID: ${{ steps.secrets.outputs.packet_project_id }}
PACKET_SSH_KEY_CONTENT: ${{ steps.secrets.outputs.packet_ssh_key_content }}
SLACK_WEBHOOK: ${{ steps.secrets.outputs.slack_webhook }}
VAGRANT_HOST_BOXES: ${{matrix.host_os}}
VAGRANT_GUEST_BOXES: ${{matrix.guest_os}}
VAGRANT_SPEC_PROVIDERS: ${{matrix.providers}}
VAGRANT_DOCKER_IMAGES: ${{matrix.docker_images}}
- name: Upload log
if: always()
uses: actions/upload-artifact@v3
with:
name: vagrant-spec-${{matrix.providers}}.log
path: ${{ github.workspace }}/vagrant-spec.log
notify-on-success:
if: github.repository == 'hashicorp/vagrant-acceptance' && success()
runs-on: self-hosted
name: Notify on Success
needs: spec-tests
steps:
- name: Notify on Success
run: ./.ci/spec/notify-success.sh
env:
SLACK_WEBHOOK: ${{ steps.secrets.outputs.slack_webhook }}
cleanup:
if: github.repository == 'hashicorp/vagrant-acceptance'
runs-on: self-hosted
name: Cleanup Post Vagrant-Spec Tests
needs: [spec-tests, notify-on-success]
steps:
- name: Clean Packet
run: ./.ci/spec/clean-packet.sh
env:
PACKET_EXEC_TOKEN: ${{ steps.secrets.outputs.packet_token }}
PACKET_EXEC_PROJECT_ID: ${{ steps.secrets.outputs.packet_project_id }}
PACKET_SSH_KEY_CONTENT: ${{ steps.secrets.outputs.packet_ssh_key_content }}
SLACK_WEBHOOK: ${{ steps.secrets.outputs.slack_webhook }}
- name: Clean Workspace
run: rm -rf ${{ github.workspace }}