mirror of
https://github.com/JasonN3/build-container-installer.git
synced 2025-12-25 02:47:56 +01:00
Split Makfile and move workflow to Makefile (#88)
Co-authored-by: codacy-production[bot] <61871480+codacy-production[bot]@users.noreply.github.com>
This commit is contained in:
parent
662f1a94e4
commit
b669420287
40 changed files with 800 additions and 665 deletions
100
test/vm/Makefile
Normal file
100
test/vm/Makefile
Normal file
|
|
@ -0,0 +1,100 @@
|
|||
VM_TESTS=$(wildcard install_*) $(if $(FLATPAK_REMOTE_REFS),$(wildcard flatpak_*))$(if $(FLATPAK_DIR),$(wildcard flatpak_*))
|
||||
|
||||
all: $(VM_TESTS) clean
|
||||
|
||||
$(VM_TESTS): start_vm ansible_inventory
|
||||
$(eval _VARS = IMAGE_REPO IMAGE_NAME IMAGE_TAG)
|
||||
|
||||
ansible -i ansible_inventory -m ansible.builtin.wait_for_connection vm
|
||||
|
||||
chmod +x $@
|
||||
$(foreach var,$(_VARS),$(var)=$($(var))) ./$@
|
||||
|
||||
ansible_inventory:
|
||||
echo "ungrouped:" > ansible_inventory
|
||||
echo " hosts:" >> ansible_inventory
|
||||
echo " vm:" >> ansible_inventory
|
||||
echo " ansible_host: $(VM_IP)" >> ansible_inventory
|
||||
echo " ansible_port: $(VM_PORT)" >> ansible_inventory
|
||||
echo " ansible_user: $(VM_USER)" >> ansible_inventory
|
||||
echo " ansible_password: $(VM_PASS)" >> ansible_inventory
|
||||
echo " ansible_become_pass: $(VM_PASS)" >> ansible_inventory
|
||||
echo " ansible_ssh_common_args: '-o StrictHostKeyChecking=no'" >> ansible_inventory
|
||||
|
||||
.PHONY: $(VM_TESTS) install-deps
|
||||
|
||||
install-deps:
|
||||
$(install_pkg) qemu qemu-utils xorriso qemu-system-x86 netcat socat jq ansible curl
|
||||
|
||||
files/mnt/iso:
|
||||
$(if $(wildcard files/mnt),,mkdir files/mnt)
|
||||
$(if $(wildcard files/mnt/iso),,mkdir files/mnt/iso)
|
||||
sudo mount -o loop ../../$(ISO_NAME) files/mnt/iso
|
||||
|
||||
files/grub.cfg: files/mnt/iso
|
||||
cp files/mnt/iso/boot/grub2/grub.cfg files/grub.cfg
|
||||
sed -i 's/quiet/console=ttyS0,115200n8 inst.ks=cdrom:\/ks.cfg/' files/grub.cfg
|
||||
sed -i 's/set default="1"/set default="0"/' files/grub.cfg
|
||||
sed -i 's/set timeout=60/set timeout=1/' files/grub.cfg
|
||||
|
||||
.PHONY: clean
|
||||
clean:
|
||||
$(if $(wildcard start_vm), kill "$(shell cat start_vm)")
|
||||
$(if $(wildcard files/mnt/iso),sudo umount files/mnt/iso)
|
||||
$(if $(wildcard files/mnt/iso),rmdir files/mnt/iso)
|
||||
$(if $(wildcard ansible_inventory),rm ansible_inventory)
|
||||
$(if $(wildcard files/install.iso),rm files/install.iso)
|
||||
$(if $(wildcard files/disk.qcow2),rm files/disk.qcow2)
|
||||
$(if $(wildcard install_os),rm install_os)
|
||||
$(if $(wildcard start_vm),rm start_vm)
|
||||
|
||||
files/install.iso: files/grub.cfg
|
||||
xorriso -dialog on << EOF
|
||||
-indev ../../$(ISO_NAME)
|
||||
-outdev files/install.iso
|
||||
-boot_image any replay
|
||||
-joliet on
|
||||
-compliance joliet_long_names
|
||||
-map files/ks.cfg ks.cfg
|
||||
-chmod 0444 ks.cfg
|
||||
-map files/grub.cfg boot/grub2/grub.cfg
|
||||
-end
|
||||
EOF
|
||||
|
||||
files/disk.qcow2:
|
||||
qemu-img create -f qcow2 files/disk.qcow2 50G
|
||||
|
||||
install_os: files/install.iso files/disk.qcow2
|
||||
timeout 1h qemu-system-x86_64 -name "Anaconda" -boot d -m 4096 -cpu qemu64 -display none -cdrom files/install.iso -smp 2 -hda files/disk.qcow2 -serial telnet:localhost:4321,server=on,wait=off & QEMU_PID=$$!
|
||||
echo "PID: $$QEMU_PID"
|
||||
timeout 1m bash -c "while ! (echo > /dev/tcp/127.0.0.1/4321); do sleep 0.1; done"
|
||||
(nc localhost 4321 | tee vm.stdout) &
|
||||
wait $$QEMU_PID
|
||||
touch install_os
|
||||
|
||||
.ONESHELL:
|
||||
|
||||
start_vm: install_os
|
||||
mkfifo vm.stdin
|
||||
qemu-system-x86_64 -name "Anaconda" \
|
||||
-m 4096 -cpu qemu64 -display none -smp 2 \
|
||||
-chardev socket,path=/tmp/qga.sock,server=on,wait=off,id=qga0 \
|
||||
-device e1000,netdev=net0 \
|
||||
-netdev user,id=net0,hostfwd=tcp::$(VM_PORT)-:22 \
|
||||
-device virtio-serial \
|
||||
-device virtserialport,chardev=qga0,name=org.qemu.guest_agent.0 \
|
||||
-boot c -hda files/disk.qcow2 -serial telnet:localhost:4321,server=on,wait=off & export QEMU_PID=$$!
|
||||
echo "PID: $$QEMU_PID"
|
||||
|
||||
timeout 1m bash -c "while ! (echo > /dev/tcp/127.0.0.1/4321); do sleep 0.1; done"
|
||||
(tail -f vm.stdin | nc localhost 4321 | tee vm.stdout) &
|
||||
|
||||
timeout 30m bash -c "while ! (echo > /dev/tcp/$(VM_IP)/$(VM_PORT)); do sleep 1; done"
|
||||
|
||||
if ! (echo > /dev/tcp/$(VM_IP)/$(VM_PORT))
|
||||
then
|
||||
echo "SSH must be installed and enabled inside the container"
|
||||
fi
|
||||
|
||||
echo "VM ready for tests at IP $(VM_IP):$(VM_PORT)"
|
||||
echo $$QEMU_PID > start_vm
|
||||
1
test/vm/README.md
Normal file
1
test/vm/README.md
Normal file
|
|
@ -0,0 +1 @@
|
|||
Place scripts that will test the VM. The VM will be available at ${VM_IP} using username ${VM_USER} and password ${VM_PASS}
|
||||
9
test/vm/files/ks.cfg
Normal file
9
test/vm/files/ks.cfg
Normal file
|
|
@ -0,0 +1,9 @@
|
|||
lang en_US.UTF-8
|
||||
keyboard us
|
||||
timezone Americas/New_York
|
||||
zerombr
|
||||
clearpart --all --initlabel
|
||||
autopart
|
||||
poweroff
|
||||
user --name=core --groups=wheel --password=foobar
|
||||
%include /usr/share/anaconda/interactive-defaults.ks
|
||||
16
test/vm/flatpak_fedora_repo_disabled.yml
Normal file
16
test/vm/flatpak_fedora_repo_disabled.yml
Normal file
|
|
@ -0,0 +1,16 @@
|
|||
#!/usr/bin/env -S ansible-playbook -i ./ansible_inventory
|
||||
---
|
||||
- name: Test fedora flatpak repo wasn't enabled
|
||||
hosts: vm
|
||||
gather_facts: no
|
||||
|
||||
tasks:
|
||||
- name: Collect facts about system services
|
||||
service_facts:
|
||||
register: services_state
|
||||
|
||||
- name: Check that flatpak-add-fedora-repos is disabled
|
||||
ansible.builtin.assert:
|
||||
that:
|
||||
- services_state['ansible_facts']['services']['flatpak-add-fedora-repos.service']['status'] == 'disabled'
|
||||
fail_msg: 'flatpak-add-fedora-repos.service is not disabled'
|
||||
25
test/vm/flatpak_installed.yml
Normal file
25
test/vm/flatpak_installed.yml
Normal file
|
|
@ -0,0 +1,25 @@
|
|||
#!/usr/bin/env -S ansible-playbook -i ./ansible_inventory
|
||||
---
|
||||
- name: Test for installed flatpaks
|
||||
hosts: vm
|
||||
gather_facts: no
|
||||
|
||||
tasks:
|
||||
# Verifies that the flatpaks are installed
|
||||
- name: Get list of installed Flatpaks
|
||||
become: true
|
||||
ansible.builtin.command:
|
||||
cmd: /usr/bin/flatpak list
|
||||
register: flatpaks
|
||||
|
||||
- name: Check that VLC is installed
|
||||
ansible.builtin.assert:
|
||||
that:
|
||||
- "'VLC' in flatpaks.stdout"
|
||||
fail_msg: 'VLC is not installed'
|
||||
|
||||
- name: Check that Firefox is installed
|
||||
ansible.builtin.assert:
|
||||
that:
|
||||
- "'Firefox' in flatpaks.stdout"
|
||||
fail_msg: 'Firefox is not installed'
|
||||
12
test/vm/flatpak_update.yml
Normal file
12
test/vm/flatpak_update.yml
Normal file
|
|
@ -0,0 +1,12 @@
|
|||
#!/usr/bin/env -S ansible-playbook -i ./ansible_inventory
|
||||
---
|
||||
- name: Test flatpak update
|
||||
hosts: vm
|
||||
gather_facts: no
|
||||
|
||||
tasks:
|
||||
# Verifies that the GPG key is functional
|
||||
- name: Test updating flatpak packages
|
||||
become: true
|
||||
ansible.builtin.command:
|
||||
cmd: /usr/bin/flatpak update -y --noninteractive
|
||||
25
test/vm/install_image_source.yml
Normal file
25
test/vm/install_image_source.yml
Normal file
|
|
@ -0,0 +1,25 @@
|
|||
#!/usr/bin/env -S ansible-playbook -i ./ansible_inventory
|
||||
---
|
||||
- name: Test Container Image source updates
|
||||
hosts: vm
|
||||
gather_facts: no
|
||||
|
||||
tasks:
|
||||
# Get list of origins
|
||||
- name: Get origin
|
||||
become: true
|
||||
ansible.builtin.command:
|
||||
cmd: /bin/bash -c "cat /ostree/deploy/default/deploy/*.origin"
|
||||
register: origin
|
||||
|
||||
- name: Get vars
|
||||
ansible.builtin.set_fact:
|
||||
image_repo: "{{ lookup('ansible.builtin.env', 'IMAGE_REPO') }}"
|
||||
image_name: "{{ lookup('ansible.builtin.env', 'IMAGE_NAME') }}"
|
||||
image_tag: "{{ lookup('ansible.builtin.env', 'IMAGE_TAG') }}"
|
||||
|
||||
- name: Tests
|
||||
ansible.builtin.assert:
|
||||
that:
|
||||
- (image_repo + '/' + image_name + ':' + image_tag) in origin.stdout
|
||||
fail_msg: 'Origin not configured'
|
||||
Loading…
Add table
Add a link
Reference in a new issue