137 lines
5.6 KiB
YAML
137 lines
5.6 KiB
YAML
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 }}
|