Skip to content

GCVE Peering fixes and feature #173

GCVE Peering fixes and feature

GCVE Peering fixes and feature #173

Workflow file for this run

# Copyright 2022 Google LLC
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
name: 'Tests'
on:
push:
branches:
- 'main'
pull_request:
paths:
- "**.tf"
- "**.go"
jobs:
pre_run:
name: 'setup-gh-workers'
permissions:
id-token: write
contents: read
runs-on: 'ubuntu-latest'
steps:
- name: Clone repo
uses: actions/checkout@master
- id: 'auth'
uses: 'google-github-actions/auth@v1'
with:
workload_identity_provider: ${{ secrets.WORKLOAD_IDENTITY_POOL_PROVIDER_NAME }} # this is the output provider_name from the TF module
service_account: ${{ secrets.SVC_ACCOUNT_EMAIL }} # this is a SA email configured to create gh-runner MIGs
export_environment_variables: false
- name: Setup Terraform
uses: hashicorp/setup-terraform@v2
with:
terraform_version: 1.1.9
terraform_wrapper: false
- name: Set Secrets
id: secrets
run: |
bash test/setup/github-runners/scripts/fetch_vsphere_secrets.sh \
${{ steps.auth.outputs.project_id }} \
${{ steps.auth.outputs.credentials_file_path }} \
${{ secrets.SVC_ACCOUNT_EMAIL }} \
${{ secrets.VSPHERE_SERVER_SECRET }} \
${{ secrets.VSPHERE_USER_SECRET }} \
${{ secrets.VSPHERE_PASSWORD_SECRET }}
shell: bash
- name: Terraform Init
id: init
run: |
echo "bucket=\"${{ secrets.TF_BACKEND_BUCKET }}\"" > backend.tfvars
terraform init -backend-config=backend.tfvars
working-directory: ./test/setup/github-runners # Use your environment folder
shell: bash
- name: Terraform Plan
id: plan
run: |
echo ${{ secrets.GH_RUNNER_TFVAR }} | base64 -d > terraform.tfvars
terraform plan
working-directory: ./test/setup/github-runners # Use your environment folder
shell: bash
- name: Terraform Destroy
id: destroy
run: |
echo ${{ secrets.GH_RUNNER_TFVAR }} | base64 -d > terraform.tfvars
terraform destroy -auto-approve && terraform destroy -auto-approve && sleep 5
working-directory: ./test/setup/github-runners # Use your environment folder
shell: bash
- name: Terraform Apply
id: apply
run: |
echo ${{ secrets.GH_RUNNER_TFVAR }} | base64 -d > terraform.tfvars
terraform apply -auto-approve
working-directory: ./test/setup/github-runners # Use your environment folder
shell: bash
run_tests:
name: 'run-gcve-test'
needs: pre_run
permissions:
id-token: write
contents: read
runs-on: 'self-hosted'
container:
image: gcr.io/cloud-foundation-cicd/cft/developer-tools:1
steps:
- name: Clone repo
uses: actions/checkout@master
- id: 'auth'
uses: 'google-github-actions/auth@v1'
with:
workload_identity_provider: ${{ secrets.WORKLOAD_IDENTITY_POOL_PROVIDER_NAME }} # this is the output provider_name from the TF module
service_account: ${{ secrets.SVC_ACCOUNT_EMAIL }} # this is a SA email configured to create gh-runner MIGs
export_environment_variables: false
- name: Set Secrets
id: secrets
run: |
bash test/setup/github-runners/scripts/fetch_vsphere_secrets.sh \
${{ steps.auth.outputs.project_id }} \
${{ steps.auth.outputs.credentials_file_path }} \
${{ secrets.SVC_ACCOUNT_EMAIL }} \
${{ secrets.VSPHERE_SERVER_SECRET }} \
${{ secrets.VSPHERE_USER_SECRET }} \
${{ secrets.VSPHERE_PASSWORD_SECRET }} \
${{ secrets.NSXT_SERVER_SECRET }} \
${{ secrets.NSXT_USER_SECRET }} \
${{ secrets.NSXT_PASSWORD_SECRET }}
shell: bash
- name: CFT Test Init
id: cft_init
run: |
cft test run all --stage init --verbose
shell: bash
env:
TF_BACKEND_BUCKET: ${{ secrets.TF_BACKEND_BUCKET }}
- name: CFT Test Apply
id: cft_apply
run: |
cft test run all --stage apply --verbose
shell: bash
env:
TF_BACKEND_BUCKET: ${{ secrets.TF_BACKEND_BUCKET }}
- name: CFT Test Verify
id: cft_verify
run: |
cft test run all --stage verify --verbose
shell: bash
env:
TF_BACKEND_BUCKET: ${{ secrets.TF_BACKEND_BUCKET }}
- name: CFT Test Destroy
id: cft_destroy
run: |
cft test run all --stage destroy --verbose || cft test run all --stage destroy --verbose
shell: bash
env:
TF_BACKEND_BUCKET: ${{ secrets.TF_BACKEND_BUCKET }}
post_run:
name: 'cleanup-gh-workers'
needs: run_tests
permissions:
id-token: write
contents: read
runs-on: 'ubuntu-latest'
steps:
- name: Clone repo
uses: actions/checkout@master
- id: 'auth'
uses: 'google-github-actions/auth@v0.4.0'
with:
workload_identity_provider: ${{ secrets.WORKLOAD_IDENTITY_POOL_PROVIDER_NAME }} # this is the output provider_name from the TF module
service_account: ${{ secrets.SVC_ACCOUNT_EMAIL }} # this is a SA email configured to create gh-runner MIGs
export_environment_variables: false
- name: Setup Terraform
uses: hashicorp/setup-terraform@v2
with:
terraform_version: 1.1.9
terraform_wrapper: false
- name: Set Secrets
id: secrets
run: |
bash test/setup/github-runners/scripts/fetch_vsphere_secrets.sh \
${{ steps.auth.outputs.project_id }} \
${{ steps.auth.outputs.credentials_file_path }} \
${{ secrets.SVC_ACCOUNT_EMAIL }} \
${{ secrets.VSPHERE_SERVER_SECRET }} \
${{ secrets.VSPHERE_USER_SECRET }} \
${{ secrets.VSPHERE_PASSWORD_SECRET }}
shell: bash
- name: Terraform Init
id: init
run: |
echo "bucket=\"${{ secrets.TF_BACKEND_BUCKET }}\"" > backend.tfvars
terraform init -backend-config=backend.tfvars
working-directory: ./test/setup/github-runners # Use your environment folder
shell: bash
- name: Terraform Destroy
id: destroy
run: |
echo ${{ secrets.GH_RUNNER_TFVAR }} | base64 -d > terraform.tfvars
terraform destroy -auto-approve
working-directory: ./test/setup/github-runners # Use your environment folder
shell: bash