Accepting request 839820 from home:favogt:combustion

- Implement support for systems without transactional-update
- Require rmdir explicitly

- Fail properly when the retval file doesn't exist
- Stop ignition-mount.service to avoid conflict (boo#1176746)

OBS-URL: https://build.opensuse.org/request/show/839820
OBS-URL: https://build.opensuse.org/package/show/devel:kubic:ignition/combustion?expand=0&rev=9
This commit is contained in:
Fabian Vogt 2020-10-06 13:08:49 +00:00 committed by Git OBS Bridge
parent 651ee08f24
commit 3a12418b0e
3 changed files with 43 additions and 15 deletions

View File

@ -89,6 +89,13 @@ if ! [ -d "${config_mount}/combustion" ]; then
exit 0
fi
# ignition-mount.service mounts stuff below /sysroot in ExecStart and umounts
# it on ExecStop, failing if umounting fails. This conflicts with the
# mounts/umounts done by combustion. Ignition is already done, so just stop it.
if systemctl --quiet is-active ignition-mount.service; then
systemctl stop ignition-mount.service
fi
# Copy config
mkdir "${exchangedir}"
config_dir="${exchangedir}/config"
@ -125,20 +132,29 @@ if [ -r /etc/resolv.conf ]; then
fi
fi
# t-u doesn't allow running arbitrary commands and
# also ignores the shell's exit code, so DIY.
if ! chroot /sysroot transactional-update shell <<EOF; then
cd "${config_dir}"
chmod a+x script
./script
echo \$? > "${exchangedir}/retval"
if [ -x /sysroot/usr/sbin/transactional-update ]; then
# t-u doesn't allow running arbitrary commands and
# also ignores the shell's exit code, so DIY.
if ! chroot /sysroot transactional-update shell <<EOF; then
cd "${config_dir}"
chmod a+x script
./script
echo \$? > "${exchangedir}/retval"
EOF
echo "transactional-update failed"
exit 1
fi
echo "transactional-update failed"
exit 1
fi
if [ "$(cat "${exchangedir}/retval")" -ne 0 ]; then
echo "Command failed, rolling back"
chroot /sysroot transactional-update --no-selfupdate rollback
exit 1
if ! [ -e "${exchangedir}/retval" ] || [ "$(cat "${exchangedir}/retval")" -ne 0 ]; then
echo "Command failed, rolling back"
chroot /sysroot transactional-update --no-selfupdate rollback
exit 1
fi
else
mount -o remount,rw /sysroot
if ! chroot /sysroot sh -e -c "cd '${config_dir}'; chmod a+x script; ./script"; then
echo "Command failed"
exit 1
fi
chroot /sysroot snapper --no-dbus create -d "After combustion configuration" || :
fi

View File

@ -1,3 +1,15 @@
-------------------------------------------------------------------
Tue Oct 6 10:19:57 UTC 2020 - Fabian Vogt <fvogt@suse.com>
- Implement support for systems without transactional-update
- Require rmdir explicitly
-------------------------------------------------------------------
Mon Oct 5 08:33:19 UTC 2020 - Fabian Vogt <fvogt@suse.com>
- Fail properly when the retval file doesn't exist
- Stop ignition-mount.service to avoid conflict (boo#1176746)
-------------------------------------------------------------------
Thu Sep 17 10:56:44 UTC 2020 - Fabian Vogt <fvogt@suse.com>

View File

@ -8,7 +8,7 @@ install() {
inst_simple "${moddir}/combustion.rules" "/etc/udev/rules.d/70-combustion.rules"
mkdir -p "${initdir}/${systemdsystemunitdir}/initrd.target.requires/"
ln_r "../combustion.service" "${systemdsystemunitdir}/initrd.target.requires/combustion.service"
inst_multiple awk chroot findmnt
inst_multiple awk chroot findmnt rmdir
inst_simple "${moddir}/combustion" "/usr/bin/combustion"
# Wait up to 10s (30s on aarch64) for the config drive