From ad64e38c48229bdf73811f0a87d871c12a47f0fb Mon Sep 17 00:00:00 2001 From: Dimitri John Ledkov Date: Fri, 17 Apr 2020 00:10:35 +0100 Subject: [PATCH] Run snap info on the downloaded snap, rather than against the store. First of all snap info doesn't have --channel argument, thus queries the wrong channel, and depening on the cohort, a different snap might be visible too. Thus seed the base of the snap revision we dowanloaded, rather than some random one from the store. --- debian/changelog | 10 ++++++++++ live-build/functions | 39 ++++++++++++++++++++------------------- 2 files changed, 30 insertions(+), 19 deletions(-) diff --git a/debian/changelog b/debian/changelog index 713c0de2..288154c8 100644 --- a/debian/changelog +++ b/debian/changelog @@ -1,3 +1,13 @@ +livecd-rootfs (2.663) UNRELEASED; urgency=medium + + * Run snap info on the downloaded snap, rather than against the + store. First of all snap info doesn't have --channel argument, thus + queries the wrong channel, and depening on the cohort, a different + snap might be visible too. Thus seed the base of the snap revision we + dowanloaded, rather than some random one from the store. + + -- Dimitri John Ledkov Fri, 17 Apr 2020 00:00:52 +0100 + livecd-rootfs (2.662) focal; urgency=medium * Print subiquity ssh login details on s390x line based consoles. diff --git a/live-build/functions b/live-build/functions index f730e0ba..d86f27d6 100644 --- a/live-build/functions +++ b/live-build/functions @@ -482,6 +482,24 @@ _snap_preseed() { return fi + sh -c " + set -x; + cd \"$CHROOT_ROOT/var/lib/snapd/seed\"; + SNAPPY_STORE_NO_CDN=1 snap download \ + --cohort="${COHORT_KEY:-}" \ + --channel=\"$CHANNEL\" \"$SNAP_NAME\"" || snap_download_failed=1 + if [ $snap_download_failed = 1 ] ; then + echo "If the channel ($CHANNEL) includes '*/ubuntu-##.##' track per " + echo "Ubuntu policy (ex. stable/ubuntu-18.04) the publisher will need " + echo "to temporarily create the channel/track to allow fallback during" + echo "download (ex. stable/ubuntu-18.04 falls back to stable if the" + echo "prior had been created in the past)." + exit 1 + fi + + mv -v $seed_dir/*.assert $assertions_dir + mv -v $seed_dir/*.snap $snaps_dir + # Pre-seed snap's base case $SNAP_NAME in snapd) @@ -494,7 +512,8 @@ _snap_preseed() { # Determine which core snap is needed local snap_info - snap_info=$(snap info --verbose "${SNAP_NAME}") + # snap info doesn't have --channel, so must run agains the downloaded snap + snap_info=$(snap info --verbose ${snaps_dir}/${SNAP_NAME}_[0-9]*.snap) if [ $? -ne 0 ]; then echo "Failed to retrieve base of $SNAP_NAME!" @@ -510,24 +529,6 @@ _snap_preseed() { ;; esac - sh -c " - set -x; - cd \"$CHROOT_ROOT/var/lib/snapd/seed\"; - SNAPPY_STORE_NO_CDN=1 snap download \ - --cohort="${COHORT_KEY:-}" \ - --channel=\"$CHANNEL\" \"$SNAP_NAME\"" || snap_download_failed=1 - if [ $snap_download_failed = 1 ] ; then - echo "If the channel ($CHANNEL) includes '*/ubuntu-##.##' track per " - echo "Ubuntu policy (ex. stable/ubuntu-18.04) the publisher will need " - echo "to temporarily create the channel/track to allow fallback during" - echo "download (ex. stable/ubuntu-18.04 falls back to stable if the" - echo "prior had been created in the past)." - exit 1 - fi - - mv -v $seed_dir/*.assert $assertions_dir - mv -v $seed_dir/*.snap $snaps_dir - # Add the snap to the seed.yaml ! [ -e $seed_yaml ] && echo "snaps:" > $seed_yaml cat <> $seed_yaml