Skip to content

Commit

Permalink
ostree-sysroot-deploy: check if deployments are in the same stateroot.
Browse files Browse the repository at this point in the history
  • Loading branch information
jmarrero committed May 3, 2024
1 parent a00062b commit cb70e40
Show file tree
Hide file tree
Showing 3 changed files with 57 additions and 0 deletions.
1 change: 1 addition & 0 deletions Makefile-tests.am
Original file line number Diff line number Diff line change
Expand Up @@ -125,6 +125,7 @@ _installed_or_uninstalled_test_scripts = \
tests/test-admin-locking.sh \
tests/test-admin-deploy-clean.sh \
tests/test-admin-kargs.sh \
tests/test-admin-stateroot.sh \
tests/test-reset-nonlinear.sh \
tests/test-oldstyle-partial.sh \
tests/test-delta.sh \
Expand Down
6 changes: 6 additions & 0 deletions src/libostree/ostree-sysroot-deploy.c
Original file line number Diff line number Diff line change
Expand Up @@ -2383,6 +2383,12 @@ deployment_bootconfigs_equal (OstreeRepo *repo, OstreeDeployment *a, OstreeDeplo
if (g_strcmp0 (a_version, b_version) != 0)
return FALSE;

/* same stateroot? */
const char *a_stateroot = ostree_deployment_get_osname (a);
const char *b_stateroot = ostree_deployment_get_osname (b);
if (g_strcmp0 (a_stateroot, b_stateroot) != 0)
return FALSE;

return TRUE;
}

Expand Down
50 changes: 50 additions & 0 deletions tests/test-admin-stateroot.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,50 @@
#!/bin/bash
#
# Copyright (C) 2011 Colin Walters <[email protected]>
# Copyright (C) 2022 Huijing Hei <[email protected]>
#
# SPDX-License-Identifier: LGPL-2.0+
#
# This library is free software; you can redistribute it and/or
# modify it under the terms of the GNU Lesser General Public
# License as published by the Free Software Foundation; either
# version 2 of the License, or (at your option) any later version.
#
# This library is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
# Lesser General Public License for more details.
#
# You should have received a copy of the GNU Lesser General Public
# License along with this library. If not, see <https://www.gnu.org/licenses/>.

set -euo pipefail

. $(dirname $0)/libtest.sh

# Exports OSTREE_SYSROOT so --sysroot not needed.
setup_os_repository "archive" "syslinux"

echo "1..2"

# Initial deployment on testos stateroot
${CMD_PREFIX} ostree --repo=sysroot/ostree/repo pull-local --remote=testos testos-repo testos/buildmain/x86_64-runtime
${CMD_PREFIX} ostree admin deploy --os=testos testos:testos/buildmain/x86_64-runtime

REF=$(${CMD_PREFIX} ostree admin status | grep -oE 'testos .*\.0' | sed -e 's/^testos //' -e 's/\.0$//')

# Should prompt bootloader update as it does have a different stateroot
${CMD_PREFIX} ostree admin stateroot-init testos2
${CMD_PREFIX} ostree admin deploy ${REF} --os=testos2
${CMD_PREFIX} ostree admin set-default 1 >out.txt

assert_file_has_content out.txt 'bootconfig swap: yes'
echo "ok stateroot new-deployment"

# Should not prompt update to bootloader as stateroot/commit and kargs are all the same.
${CMD_PREFIX} ostree admin deploy ${REF} --os=testos2
${CMD_PREFIX} ostree admin deploy ${REF} --os=testos2
${CMD_PREFIX} ostree admin set-default 1 >out.txt

assert_file_has_content out.txt 'bootconfig swap: no'
echo "ok stateroot equal-deployment"

0 comments on commit cb70e40

Please sign in to comment.