Packer.Images/.drone.yml

189 lines
5.3 KiB
YAML
Raw Normal View History

kind: pipeline
type: kubernetes
name: 'Packer Build'
2021-04-10 13:32:31 +00:00
volumes:
- name: output
claim:
name: flexvolsmb-drone-output
- name: scratch
claim:
name: flexvolsmb-drone-scratch
steps:
- name: Debugging information
image: bv11-cr01.bessems.eu/library/packer-extended
2023-04-03 14:26:38 +00:00
pull: always
commands:
2021-06-07 11:19:00 +00:00
- ansible --version
- ovftool --version
2022-06-27 07:54:57 +00:00
- packer --version
- yamllint --version
2023-04-03 13:43:10 +00:00
2023-04-03 14:26:38 +00:00
- name: Linting
2023-04-03 14:32:05 +00:00
depends_on:
- Debugging information
2023-04-03 14:26:38 +00:00
image: bv11-cr01.bessems.eu/library/packer-extended
pull: always
commands:
- |
yamllint -d "{extends: relaxed, rules: {line-length: disable}}" \
ansible \
packer/preseed/UbuntuServer22.04/user-data \
scripts
- name: Install Ansible Galaxy collections
2023-04-03 14:32:05 +00:00
depends_on:
- Linting
2023-04-03 14:26:38 +00:00
image: bv11-cr01.bessems.eu/library/packer-extended
pull: always
commands:
2023-04-03 14:29:16 +00:00
- |
ansible-galaxy collection install \
2023-04-03 14:26:38 +00:00
-r ansible/requirements.yml \
-p ./ansible/collections
2023-04-03 14:26:38 +00:00
volumes:
- name: scratch
path: /scratch
- name: Kubernetes Bootstrap Appliance
2023-04-03 13:43:10 +00:00
depends_on:
2023-04-03 14:26:38 +00:00
- Install Ansible Galaxy collections
2023-04-03 13:43:10 +00:00
image: bv11-cr01.bessems.eu/library/packer-extended
pull: always
commands:
- |
sed -i -e "s/<<img-password>>/$${SSH_PASSWORD}/g" \
packer/preseed/UbuntuServer22.04/user-data
- |
export K8S_VERSION=$(yq '.components.clusterapi.workload.version.k8s' < ./ansible/vars/metacluster.yml)
- |
packer init -upgrade \
./packer
- |
packer validate \
2023-04-05 15:01:36 +00:00
-only=vsphere-iso.bootstrap \
-var vm_name=${DRONE_BUILD_NUMBER}-${DRONE_COMMIT_SHA:0:10}-$(openssl rand -hex 3) \
2023-04-03 13:43:10 +00:00
-var docker_username=$${DOCKER_USERNAME} \
-var docker_password=$${DOCKER_PASSWORD} \
-var repo_username=$${REPO_USERNAME} \
-var repo_password=$${REPO_PASSWORD} \
-var ssh_password=$${SSH_PASSWORD} \
-var vsphere_password=$${VSPHERE_PASSWORD} \
-var k8s_version=$K8S_VERSION \
./packer
- |
packer build \
-on-error=cleanup -timestamp-ui \
-only=vsphere-iso.bootstrap \
2023-04-05 15:01:36 +00:00
-var vm_name=${DRONE_BUILD_NUMBER}-${DRONE_COMMIT_SHA:0:10}-$(openssl rand -hex 3) \
2023-04-03 13:43:10 +00:00
-var docker_username=$${DOCKER_USERNAME} \
-var docker_password=$${DOCKER_PASSWORD} \
-var repo_username=$${REPO_USERNAME} \
-var repo_password=$${REPO_PASSWORD} \
-var ssh_password=$${SSH_PASSWORD} \
-var vsphere_password=$${VSPHERE_PASSWORD} \
-var k8s_version=$K8S_VERSION \
./packer
environment:
DOCKER_USERNAME:
from_secret: docker_username
DOCKER_PASSWORD:
from_secret: docker_password
# PACKER_LOG: 1
REPO_USERNAME:
from_secret: repo_username
REPO_PASSWORD:
from_secret: repo_password
SSH_PASSWORD:
from_secret: ssh_password
VSPHERE_PASSWORD:
from_secret: vsphere_password
volumes:
- name: output
path: /output
- name: scratch
path: /scratch
- name: Kubernetes Upgrade Appliance
depends_on:
2023-04-03 14:26:38 +00:00
- Install Ansible Galaxy collections
image: bv11-cr01.bessems.eu/library/packer-extended
2023-04-05 15:01:36 +00:00
pull: alwaysquery(
commands:
- |
2021-06-07 11:19:00 +00:00
sed -i -e "s/<<img-password>>/$${SSH_PASSWORD}/g" \
packer/preseed/UbuntuServer22.04/user-data
- |
export K8S_VERSION=$(yq '.components.clusterapi.workload.version.k8s' < ./ansible/vars/metacluster.yml)
- |
packer init -upgrade \
./packer
- |
packer validate \
2023-04-05 15:01:36 +00:00
-only=vsphere-iso.upgrade \
-var vm_name=${DRONE_BUILD_NUMBER}-${DRONE_COMMIT_SHA:0:10}-$(openssl rand -hex 3) \
2023-03-09 11:45:51 +00:00
-var docker_username=$${DOCKER_USERNAME} \
-var docker_password=$${DOCKER_PASSWORD} \
-var repo_username=$${REPO_USERNAME} \
-var repo_password=$${REPO_PASSWORD} \
2021-06-07 11:29:22 +00:00
-var ssh_password=$${SSH_PASSWORD} \
2023-03-09 11:45:51 +00:00
-var vsphere_password=$${VSPHERE_PASSWORD} \
2023-03-15 09:26:42 +00:00
-var k8s_version=$K8S_VERSION \
./packer
- |
packer build \
2021-06-07 13:31:46 +00:00
-on-error=cleanup -timestamp-ui \
2023-04-03 13:43:10 +00:00
-only=vsphere-iso.upgrade \
2023-04-05 15:01:36 +00:00
-var vm_name=${DRONE_BUILD_NUMBER}-${DRONE_COMMIT_SHA:0:10}-$(openssl rand -hex 3) \
2023-03-09 11:45:51 +00:00
-var docker_username=$${DOCKER_USERNAME} \
-var docker_password=$${DOCKER_PASSWORD} \
-var repo_username=$${REPO_USERNAME} \
-var repo_password=$${REPO_PASSWORD} \
2021-06-07 11:29:22 +00:00
-var ssh_password=$${SSH_PASSWORD} \
2023-03-09 11:45:51 +00:00
-var vsphere_password=$${VSPHERE_PASSWORD} \
2023-03-15 09:56:55 +00:00
-var k8s_version=$K8S_VERSION \
./packer
environment:
2023-03-09 11:45:51 +00:00
DOCKER_USERNAME:
from_secret: docker_username
DOCKER_PASSWORD:
from_secret: docker_password
# PACKER_LOG: 1
REPO_USERNAME:
from_secret: repo_username
REPO_PASSWORD:
from_secret: repo_password
2023-03-09 11:45:51 +00:00
SSH_PASSWORD:
from_secret: ssh_password
VSPHERE_PASSWORD:
from_secret: vsphere_password
volumes:
- name: output
path: /output
- name: scratch
path: /scratch
2023-04-03 13:43:10 +00:00
2021-04-10 13:32:31 +00:00
- name: Remove temporary resources
2023-04-03 13:43:10 +00:00
depends_on:
- Kubernetes Bootstrap Appliance
- Kubernetes Upgrade Appliance
2021-04-10 13:32:31 +00:00
image: bv11-cr01.bessems.eu/library/packer-extended
commands:
- |
pwsh -file scripts/Remove-Resources.ps1 \
-VMName $DRONE_BUILD_NUMBER-${DRONE_COMMIT_SHA:0:10} \
-VSphereFQDN 'bv11-vc.bessems.lan' \
-VSphereUsername 'administrator@vsphere.local' \
-VSpherePassword $${VSPHERE_PASSWORD}
environment:
VSPHERE_PASSWORD:
from_secret: vsphere_password
volumes:
- name: scratch
path: /scratch
when:
status:
- success
- failure