diff options
author | Colin Walters <walters@verbum.org> | 2017-05-18 18:12:33 -0400 |
---|---|---|
committer | Atomic Bot <atomic-devel@projectatomic.io> | 2017-08-21 18:24:07 +0000 |
commit | 618617d68b6ea82a71b3394ccd726e6b4b3e156e (patch) | |
tree | 44c73d98da2a73593bbf8a894ce49a3977c6fc3e /tests/test-admin-upgrade-not-backwards.sh | |
parent | ca61a2bd9d5002ac6cdf2371077e15b0c25da2bc (diff) | |
download | ostree-618617d68b6ea82a71b3394ccd726e6b4b3e156e.tar.gz |
lib/pull: Add support for timestamp-check option, use in upgrader
For both flatpak and ostree-as-host, we really want to verify up front during
pulls that we're not being downgraded. Currently both flatpak and
`OstreeSysrootUpgrader` do this before deployments, but at that point we've
already downloaded all the data, which is annoying.
Closes: https://github.com/ostreedev/ostree/issues/687
Closes: #1055
Approved by: jlebon
Diffstat (limited to 'tests/test-admin-upgrade-not-backwards.sh')
-rwxr-xr-x | tests/test-admin-upgrade-not-backwards.sh | 30 |
1 files changed, 23 insertions, 7 deletions
diff --git a/tests/test-admin-upgrade-not-backwards.sh b/tests/test-admin-upgrade-not-backwards.sh index fd1e1108..67d51737 100755 --- a/tests/test-admin-upgrade-not-backwards.sh +++ b/tests/test-admin-upgrade-not-backwards.sh @@ -26,26 +26,42 @@ setup_os_repository "archive-z2" "syslinux" echo "1..2" +ref=testos/buildmaster/x86_64-runtime cd ${test_tmpdir} ${CMD_PREFIX} ostree --repo=sysroot/ostree/repo remote add --set=gpg-verify=false testos $(cat httpd-address)/ostree/testos-repo -${CMD_PREFIX} ostree --repo=sysroot/ostree/repo pull testos testos/buildmaster/x86_64-runtime -rev=$(${CMD_PREFIX} ostree --repo=sysroot/ostree/repo rev-parse testos/buildmaster/x86_64-runtime) +${CMD_PREFIX} ostree --repo=sysroot/ostree/repo pull testos ${ref} +rev=$(${CMD_PREFIX} ostree --repo=sysroot/ostree/repo rev-parse ${ref}) export rev echo "rev=${rev}" -# This initial deployment gets kicked off with some kernel arguments -${CMD_PREFIX} ostree admin deploy --karg=root=LABEL=MOO --karg=quiet --os=testos testos:testos/buildmaster/x86_64-runtime +# This initial deployment gets kicked off with some kernel arguments +${CMD_PREFIX} ostree admin deploy --karg=root=LABEL=MOO --karg=quiet --os=testos testos:${ref} assert_has_dir sysroot/boot/ostree/testos-${bootcsum} # This should be a no-op ${CMD_PREFIX} ostree admin upgrade --os=testos -# Now reset to an older revision -${CMD_PREFIX} ostree --repo=${test_tmpdir}/testos-repo reset testos/buildmaster/x86_64-runtime{,^} - +# Generate a new commit with an older timestamp that also has +# some new content, so we test timestamp checking during pull +# <https://github.com/ostreedev/ostree/pull/1055> +origrev=$(ostree --repo=${test_tmpdir}/sysroot/ostree/repo rev-parse testos:${ref}) +cd ${test_tmpdir}/osdata +echo "new content for pull timestamp checking" > usr/share/test-pull-ts-check.txt +${CMD_PREFIX} ostree --repo=${test_tmpdir}/testos-repo commit --add-metadata-string "version=tscheck" \ + -b ${ref} --timestamp='October 25 1985' +newrev=$(ostree --repo=${test_tmpdir}/testos-repo rev-parse ${ref}) +assert_not_streq ${origrev} ${newrev} +cd ${test_tmpdir} +tscheck_checksum=$(ostree_file_path_to_checksum testos-repo ${ref} /usr/share/test-pull-ts-check.txt) +tscheck_fileobjpath=$(ostree_checksum_to_relative_object_path testos-repo ${tscheck_checksum}) +assert_has_file testos-repo/${tscheck_fileobjpath} if ${CMD_PREFIX} ostree admin upgrade --os=testos 2>upgrade-err.txt; then assert_not_reached 'upgrade unexpectedly succeeded' fi assert_file_has_content upgrade-err.txt 'chronologically older' +currev=$(ostree --repo=sysroot/ostree/repo rev-parse testos:${ref}) +assert_not_streq ${newrev} ${currev} +assert_streq ${origrev} ${currev} +assert_not_has_file sysroot/ostree/repo/$tscheck_fileobjpath echo 'ok upgrade will not go backwards' |