Skip to content

Github actions

Github actions #90

Workflow file for this run

name: test gha
on:
push:
branches:
- main
pull_request:
permissions:
id-token: write
contents: read
env:
ARM_SKIP_PROVIDER_REGISTRATION: true
ARM_USE_OIDC: true
ARM_SUBSCRIPTION_ID: ${{ secrets.AZURE_SUBSCRIPTION_ID }}
ARM_TENANT_ID: ${{ secrets.AZURE_TENANT_ID }}
ARM_CLIENT_ID: ${{ secrets.AZURE_CLIENT_ID }}
jobs:
# deploy-infrastructure:
# runs-on: ubuntu-latest
# env:
# ARM_SKIP_PROVIDER_REGISTRATION: true
# ARM_USE_OIDC: true
# ARM_SUBSCRIPTION_ID: ${{ secrets.AZURE_SUBSCRIPTION_ID }}
# ARM_TENANT_ID: ${{ secrets.AZURE_TENANT_ID }}
# ARM_CLIENT_ID: ${{ secrets.AZURE_CLIENT_ID }}
# steps:
# - uses: actions/checkout@v4
# - name: Setup Terraform
# uses: hashicorp/setup-terraform@v3
# with:
# terraform_version: 1.8.3
# terraform_wrapper: false
# - name: configure provider
# run: cp .github/provider.tf .
# - name: Terraform init
# run: terraform init
# - name: Terraform apply
# run: terraform plan -var "create_vm=true" -var "create_app_service=true" -var "ssh_key=${{ secrets.SSH_PUBLIC_KEY }}"
# # run: terraform apply -auto-approve -var "create_vm=true" -var "create_app_service=true" -var "ssh_key=${{ secrets.SSH_PUBLIC_KEY }}"
azurevm_test:
#needs: deploy-infrastructure
runs-on: ubuntu-latest
steps:
- name: Install libvips
run: sudo apt-get install -y libvips
- name: SSH key
env:
SSH_AUTH_SOCK: /tmp/ssh_agent.sock
run: |
mkdir -p /home/runner/.ssh
echo "${{ secrets.SSH_PRIVATE_KEY }}" > /home/runner/.ssh/id_rsa
chmod 600 /home/runner/.ssh/id_rsa
ssh-agent -a $SSH_AUTH_SOCK > /dev/null
ssh-add /home/runner/.ssh/id_rsa
- name: Checkout
uses: actions/checkout@v4
- name: Setup Terraform
uses: hashicorp/setup-terraform@v3
with:
terraform_version: 1.8.3
terraform_wrapper: false
- name: Setup ruby
uses: ruby/setup-ruby@v1
with:
ruby-version: "3.1.6"
bundler-cache: true
- name: Tests
env:
AZURE_ACCOUNT_NAME: ${{secrets.AZURE_ACCOUNT_NAME}}
AZURE_ACCESS_KEY: ${{secrets.AZURE_ACCESS_KEY}}
AZURE_PRIVATE_CONTAINER: ${{secrets.AZURE_PRIVATE_CONTAINER}}
AZURE_PUBLIC_CONTAINER: ${{secrets.AZURE_PUBLIC_CONTAINER}}
AZURE_PRINCIPAL_ID: ${{secrets.AZURE_PRINCIPAL_ID}}
SSH_AUTH_SOCK: /tmp/ssh_agent.sock
run: bundle exec rake test_azure_vm
# teardown-infrastructure:
# runs-on: ubuntu-latest
# needs: [azurevm_test]
# #needs: [deploy-infrastructure]
# env:
# ARM_SKIP_PROVIDER_REGISTRATION: true
# ARM_USE_OIDC: true
# ARM_SUBSCRIPTION_ID: ${{ secrets.AZURE_SUBSCRIPTION_ID }}
# ARM_TENANT_ID: ${{ secrets.AZURE_TENANT_ID }}
# ARM_CLIENT_ID: ${{ secrets.AZURE_CLIENT_ID }}
# steps:
# - uses: actions/checkout@v4
# - name: Setup Terraform
# uses: hashicorp/setup-terraform@v3
# with:
# terraform_version: 1.8.3
# terraform_wrapper: false
# - name: configure provider
# run: cp .github/provider.tf .
# - name: Terraform init
# run: terraform init
# - name: Terraform apply
# run: terraform plan
# # run: terraform apply -auto-approve
# test:
# runs-on: ubuntu-latest
# steps:
# - name: Install libvips
# run: sudo apt-get install -y libvips
# - name: Checkout
# uses: actions/checkout@v4
# - name: Setup ruby
# uses: ruby/setup-ruby@v1
# with:
# ruby-version: "3.1.6"
# bundler-cache: true
# - name: Tests
# env:
# AZURE_ACCOUNT_NAME: ${{secrets.AZURE_ACCOUNT_NAME}}
# AZURE_ACCESS_KEY: ${{secrets.AZURE_ACCESS_KEY}}
# AZURE_PRIVATE_CONTAINER: ${{secrets.AZURE_PRIVATE_CONTAINER}}
# AZURE_PUBLIC_CONTAINER: ${{secrets.AZURE_PUBLIC_CONTAINER}}
# AZURE_PRINCIPAL_ID: ${{secrets.AZURE_PRINCIPAL_ID}}
# run: bundle exec rake test