187 lines
5.1 KiB
YAML
187 lines
5.1 KiB
YAML
kind: pipeline
|
|
type: kubernetes
|
|
name: 'Packer Build'
|
|
|
|
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
|
|
pull: always
|
|
commands:
|
|
- ansible --version
|
|
- ovftool --version
|
|
- packer --version
|
|
- yamllint --version
|
|
|
|
- name: Linting
|
|
depends_on:
|
|
- Debugging information
|
|
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
|
|
depends_on:
|
|
- Linting
|
|
image: bv11-cr01.bessems.eu/library/packer-extended
|
|
pull: always
|
|
commands:
|
|
- |
|
|
ansible-galaxy install \
|
|
-r ansible/requirements.yml \
|
|
-p /scratch/ansible-galaxy
|
|
volumes:
|
|
- name: scratch
|
|
path: /scratch
|
|
|
|
- name: Kubernetes Bootstrap Appliance
|
|
depends_on:
|
|
- Install Ansible Galaxy collections
|
|
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 \
|
|
-var vm_name=$DRONE_BUILD_NUMBER-${DRONE_COMMIT_SHA:0:10} \
|
|
-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 \
|
|
-var vm_name=$DRONE_BUILD_NUMBER-${DRONE_COMMIT_SHA:0:10} \
|
|
-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:
|
|
- Install Ansible Galaxy collections
|
|
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 \
|
|
-var vm_name=$DRONE_BUILD_NUMBER-${DRONE_COMMIT_SHA:0:10} \
|
|
-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.upgrade \
|
|
-var vm_name=$DRONE_BUILD_NUMBER-${DRONE_COMMIT_SHA:0:10} \
|
|
-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: Remove temporary resources
|
|
depends_on:
|
|
- Kubernetes Bootstrap Appliance
|
|
- Kubernetes Upgrade Appliance
|
|
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
|