forked from sustainable-computing-io/kepler
-
Notifications
You must be signed in to change notification settings - Fork 0
117 lines (107 loc) · 4.29 KB
/
mock_acpi.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
# This workflow will run mock-acpi compose on self-hosted equinix runners and run validator tool
name: Mock ACPI
on: # yamllint disable-line rule:truthy
issue_comment:
types: [created]
jobs:
initalize-workflow:
if: github.event.issue.pull_request && github.event.comment.body == '/test-acpi'
name: Initialize workflow
runs-on: ubuntu-latest
outputs:
head_sha: ${{ steps.pr_branch.outputs.head_sha }}
steps:
# Since `issue_comment` event runs on the default branch,
# we need to get the branch of the pull request
- name: Get PR branch
id: pr_branch
uses: xt0rted/pull-request-comment-branch@v3
# Since `issue_comment` event workflow will not appear on the
# pull request page, we need to set the status of the job
# in order to attach it to the pull request itself
- name: Set job status as pending
if: ${{ success() }}
uses: myrotvorets/set-commit-status-action@master
with:
sha: ${{ steps.pr_branch.outputs.head_sha }}
token: ${{ secrets.GITHUB_TOKEN }}
status: pending
create-runner:
if: github.event.issue.pull_request && github.event.comment.body == '/test-acpi'
name: Create self-hosted runner
needs: initalize-workflow
runs-on: ubuntu-latest
steps:
- name: metal-runner-action
uses: sustainable-computing-io/metal-runner-action@main
with:
github_token: ${{ secrets.GH_SELF_HOSTED_RUNNER_TOKEN }}
metal_auth_token: ${{ secrets.EQUINIX_API_TOKEN }}
metal_project_id: ${{ secrets.EQUINIX_PROJECT_ID }}
metro: da
plan: c3.small.x86
os: ubuntu_20_04
organization: sustainable-computing-io
test-mock-acpi:
if: github.event.issue.pull_request && github.event.comment.body == '/test-acpi'
name: Test Mock ACPI
needs: [initalize-workflow, create-runner]
continue-on-error: true
runs-on: self-hosted
outputs:
runner-name: ${{ runner.name }}
steps:
- name: Checkout code
uses: actions/checkout@v4
with:
ref: ${{ needs.initalize-workflow.outputs.head_sha }}
- name: Configure SSH
if: ${{ success() }}
run: |
echo "Configuring SSH for runner"
sudo ssh-keygen -t rsa -b 4096 -f /root/.ssh/ansible_rsa -N ''
sudo cat ~/.ssh/ansible_rsa.pub >> ~/.ssh/authorized_keys
sudo echo "StrictHostKeyChecking no" >> ~/.ssh/config
- name: Install Dependencies
if: ${{ success() }}
run: |
echo "Installing Ansible and Docker module"
sudo apt install software-properties-common -y
sudo add-apt-repository --yes --update ppa:ansible/ansible
sudo apt install -y ansible python3-pip
sudo ansible-galaxy collection install community.docker
- name: Run playbook
id: run-playbook
if: ${{ success() }}
run: |
echo "Setting up the infra"
cd ${GITHUB_WORKSPACE}/ansible
ansible-playbook -vv -i inventory.yaml setup.yaml
echo "Launching Mock ACPI compose and running validator"
ansible-playbook -vv -i inventory.yaml mock_acpi_playbook.yaml -e "pr_number=${{ github.event.issue.number }}"
cleanup:
if: github.event.issue.pull_request && github.event.comment.body == '/test-acpi'
name: Cleanup
needs: [initalize-workflow, test-mock-acpi]
runs-on: ubuntu-latest
steps:
- name: delete runner
if: ${{ always() }}
uses: sustainable-computing-io/metal-sweeper-action@main
with:
authToken: ${{ secrets.EQUINIX_API_TOKEN }}
projectID: ${{ secrets.EQUINIX_PROJECT_ID }}
runnerName: ${{ needs.test-mock-acpi.outputs.runner-name }}
# Marking the workflow as failed if the playbook fails
- name: Mark workflow as failed if playbook failed
if: ${{ needs.test-mock-acpi.result == 'failure' }}
run: |
echo "Playbook failed, marking workflow as failed"
exit 1
- name: Set job status as ${{ job.status }}
uses: myrotvorets/set-commit-status-action@master
if: ${{ always() }}
with:
sha: ${{ needs.initalize-workflow.outputs.head_sha }}
token: ${{ secrets.GITHUB_TOKEN }}
status: ${{ job.status }}