-
Notifications
You must be signed in to change notification settings - Fork 20
98 lines (85 loc) · 2.85 KB
/
ci-packer-image.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
---
# yamllint disable rule:truthy
name: Build Packer image
on:
workflow_dispatch:
inputs:
publish:
type: boolean
description: Whether to publish the image as artifact
required: false
default: true
ref:
type: string
required: true
description: The GIT ref from which the image will be build
default: fac-golden-image
infrahub_version:
type: string
default: "0.11"
description: Infrahub version to use in the image
pull_request:
push:
branches:
- fac-golden-image
concurrency:
group: ${{ github.workflow }}-${{ github.ref }}
cancel-in-progress: true
jobs:
build:
runs-on: ci-runner-huge03-ghrunner3
#group: huge-runners
steps:
- name: Checkout
uses: actions/checkout@v4
with:
ref: ${{ inputs.ref }}
- name: Checkout ansible playbooks
uses: actions/checkout@v4
with:
repository: opsmill/terraform-config
ref: main
token: ${{ secrets.GH_INFRA_REPO_TOKEN }}
path: terraform-config
sparse-checkout: |
customer-bootstrap
common
- name: Setup symlink towards playbook
run: ln -s ../../terraform-config/customer-bootstrap packaging/packer/ansible
- name: "Setup environment"
run: |
pipx install poetry
poetry config virtualenvs.prefer-active-python true
- name: Setup packer
uses: hashicorp/setup-packer@v3.0.0
id: setup
with:
version: "1.10.1"
- name: Packer init
working-directory: packaging/packer
run: packer init .
- name: Packer build
working-directory: packaging/packer
run: packer build . -var infrahub_version=${{ inputs.infrahub_version }}
# Disabled because GH artifacts are slow to download
# - name: Upload
# if: ${{ inputs.publish == 'true' }}
# uses: actions/upload-artifact@v4
# with:
# name: image.qcow2
# compression-level: 0
# path: packaging/packer/output/*
- name: Set up S3cmd cli tool
#if: ${{ inputs.publish == 'true' }}
uses: s3-actions/s3cmd@v1.5.0
with:
provider: scaleway
region: 'gra'
access_key: ${{ secrets.ARTIFACTS_S3_ACCESS_KEY }}
secret_key: ${{ secrets.ARTIFACTS_S3_SECRET_KEY }}
- name: Upload to S3
#if: ${{ inputs.publish == 'true' }}
run: |
s3cmd sync --host https://s3.gra.io.cloud.ovh.net --host-bucket "" --recursive --acl-public packaging/packer/output/ s3://infrahub-artifacts/${{ github.run_id }}/
- name: Print download URL
run: "echo Image available at https://infrahub-artifacts.s3.gra.io.cloud.ovh.net/${{ github.run_id }}/infrahub-${{ inputs.infrahub_version }}-ubuntu-22.04.qcow2"