Merge pull request #3100 from cgwalters/misc-finalization

This commit is contained in:
Jonathan Lebon 2023-11-29 14:10:22 -05:00 committed by GitHub
commit 5cc78fd73b
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 60 additions and 2 deletions

View File

@ -126,7 +126,7 @@ License along with this library. If not, see <https://www.gnu.org/licenses/>.
<listitem><para>
The deployment will not be "finalized" by default on shutdown; to later
queue it, use <literal>ostree admin unlock-finalization</literal>.
queue it, use <literal>ostree admin lock-finalization --unlock</literal>.
</para></listitem>
</varlistentry>

View File

@ -61,7 +61,8 @@ License along with this library. If not, see <https://www.gnu.org/licenses/>.
will be set into a "finalization locked" state, which means it will not be queued for the next boot by default.
</para>
<para>
This is the same as the <literal>--lock-finalization</literal> argument for <literal>ostree admin deploy</literal>.
This is the same as the <literal>--lock-finalization</literal> argument for <literal>ostree admin deploy</literal>,
which is the recommended way to use this feature in a race-free way.
</para>
<para>
However more commonly, one will use the <literal>--unlock</literal> argument for this command to later unlock

View File

@ -0,0 +1,57 @@
#!/bin/bash
set -xeuo pipefail
. ${KOLA_EXT_DATA}/libinsttest.sh
require_writable_sysroot
prepare_tmpdir
case "${AUTOPKGTEST_REBOOT_MARK:-}" in
"")
# Need to disable gpg verification for test builds
sed -i -e 's,gpg-verify=true,gpg-verify=false,' /etc/ostree/remotes.d/*.conf
# xref https://github.com/coreos/coreos-assembler/pull/2814
systemctl mask --now zincati
# Create a synthetic commit for upgrade
ostree commit --no-bindings --parent="${host_commit}" -b staged-deploy -I --tree=ref="${host_commit}"
newcommit=$(ostree rev-parse staged-deploy)
ostree admin deploy --lock-finalization staged-deploy
systemctl show -p ActiveState ostree-finalize-staged.service | grep active
ostree admin status > status.txt
assert_file_has_content status.txt 'finalization locked'
# Because finalization was locked, we shouldn't deploy on shutdown
/tmp/autopkgtest-reboot "2"
;;
"2")
# Verify we didn't finalize
newcommit=$(ostree rev-parse staged-deploy)
booted=$(rpm-ostree status --json | jq -r .deployments[0].checksum)
assert_not_streq "${newcommit}" "${booted}"
prev_bootid=$(journalctl --list-boots -o json |jq -r '.[] | select(.index == -1) | .boot_id')
journalctl -b $prev_bootid -u ostree-finalize-staged.service > svc.txt
assert_file_has_content svc.txt 'Not finalizing'
ostree admin status > status.txt
assert_not_file_has_content status.txt 'finalization locked'
# Now re-deploy
ostree admin deploy --lock-finalization staged-deploy
ostree admin status > status.txt
assert_file_has_content status.txt 'finalization locked'
# And unlock
ostree admin lock-finalization --unlock
ostree admin status > status.txt
assert_not_file_has_content status.txt 'finalization locked'
/tmp/autopkgtest-reboot "3"
;;
"3")
newcommit=$(ostree rev-parse staged-deploy)
booted=$(rpm-ostree status --json | jq -r .deployments[0].checksum)
assert_streq "${newcommit}" "${booted}"
prev_bootid=$(journalctl --list-boots -o json |jq -r '.[] | select(.index == -1) | .boot_id')
journalctl -b $prev_bootid -u ostree-finalize-staged.service > svc.txt
assert_file_has_content svc.txt 'Bootloader updated'
;;
*) fatal "Unexpected AUTOPKGTEST_REBOOT_MARK=${AUTOPKGTEST_REBOOT_MARK}" ;;
esac