From ffe7d21f4274aafab7d58fd43d85d61527f183c5 Mon Sep 17 00:00:00 2001 From: Jonathan Lebon Date: Wed, 22 Apr 2020 12:53:00 -0400 Subject: [PATCH] cmd-fetch: include overrides when updating lockfile I'm working on a lockfile updater[1], and I'd like it to just be able to do `cosa fetch --update-lockfile` the same way a human would. This normally would run `rpm-ostree compose tree` without passing any lockfiles and blocking out the pool so that all packages come from the base repo. Sadly, that doesn't currently work for FCOS right now because we have an override for crypto-policies from f32 so that we don't pull in Python. And because we also have an `exclude-packages` for Python, without the f32 crypto-policies, we can't get a depsolve from just the base f31 repos. (This is the same issue that killed bodhi-updates[2].) As a short-term hack, just include the overrides for now. This dillutes the meaning of a "base" lockfile of course, because it will now include the packages from the overrides. I don't think this really matters for now though (it does make the checking for whether overrides are still needed harder, but I'd like to automate dropping overrides eventually too). Anyway, we can drop this hack once we move to f32, though I have some ideas too on how to solve this more correctly. [1] https://github.com/coreos/fedora-coreos-tracker/issues/293 [2] https://github.com/coreos/fedora-coreos-config/pull/335#issuecomment-610634917 --- src/cmd-fetch | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/src/cmd-fetch b/src/cmd-fetch index 02eaf47ea6..bbdf72bc79 100755 --- a/src/cmd-fetch +++ b/src/cmd-fetch @@ -70,8 +70,10 @@ if [ -n "${UPDATE_LOCKFILE}" ]; then # Put this under tmprepo so it gets automatically chown'ed if needed args="--ex-write-lockfile-to=${tmprepo}/tmp/manifest-lock.json" if [ -f "${manifest_lock_overrides}" ]; then - echo "NB: ignoring overrides ${manifest_lock_overrides}" - sleep 1 + # Include the overrides in the resulting lockfile here; otherwise, we + # might not even be able to get a depsolve solely from the non-lockfile + # repos. + args+=" --ex-lockfile=${manifest_lock_overrides}" fi else for lock in "${manifest_lock}" "${manifest_lock_overrides}"; do