Skip to content

Commit

Permalink
status: Render ostree metadata source-title key
Browse files Browse the repository at this point in the history
Depends: ostreedev/ostree#1296

As I mention in the commit there, I see two uses for this in rpm-ostree; first
in our test suite, and second for OCI-built image imports.

I also took a step further here and inject an `original-origin` metadata
key, though we aren't actually using that yet.  The problem I'm trying
to solve there is that repeated `make vmoverlay` starts chaining things up,
but that gets very confusing.  I think we should always have `vmoverlay` unwind
back to the base ref.  (Or at least do that by default)
  • Loading branch information
cgwalters committed Oct 19, 2017
1 parent a9c8b1f commit e467547
Show file tree
Hide file tree
Showing 3 changed files with 14 additions and 2 deletions.
4 changes: 4 additions & 0 deletions src/app/rpmostree-builtin-status.c
Original file line number Diff line number Diff line change
Expand Up @@ -301,6 +301,10 @@ status_generic (RPMOSTreeSysroot *sysroot_proxy,
else
g_print ("%s", checksum);
g_print ("\n");
const gchar *source_title = NULL;
g_variant_dict_lookup (dict, "source-title", "&s", &source_title);
if (source_title)
g_print (" └ %s\n", source_title);

const char *base_checksum = NULL;
g_variant_dict_lookup (dict, "base-checksum", "&s", &base_checksum);
Expand Down
2 changes: 2 additions & 0 deletions src/daemon/rpmostreed-deployment-utils.c
Original file line number Diff line number Diff line change
Expand Up @@ -253,6 +253,8 @@ rpmostreed_deployment_generate_variant (OstreeSysroot *sysroot,
variant_add_metadata_attribute (&dict, OSTREE_COMMIT_META_KEY_ENDOFLIFE, "endoflife", commit);
}

variant_add_metadata_attribute (&dict, OSTREE_COMMIT_META_KEY_SOURCE_TITLE, "source-title", commit);

sigs = rpmostreed_deployment_gpg_results (repo, refspec, base_checksum, &gpg_enabled);
variant_add_commit_details (&dict, NULL, commit);

Expand Down
10 changes: 8 additions & 2 deletions tests/vmcheck/overlay.sh
Original file line number Diff line number Diff line change
Expand Up @@ -21,13 +21,19 @@ set -x

# And then this code path in the VM

# get csum of current default deployment
# get csum and origin of current default deployment
commit=$(rpm-ostree status --json | \
python -c '
import sys, json;
deployment = json.load(sys.stdin)["deployments"][0]
print deployment["checksum"]
exit()')
origin=$(rpm-ostree status --json | \
python -c '
import sys, json;
deployment = json.load(sys.stdin)["deployments"][0]
print deployment["origin"]
exit()')

if [[ -z $commit ]] || ! ostree rev-parse $commit; then
echo "Error while determining current commit" >&2
Expand Down Expand Up @@ -59,6 +65,6 @@ fi
rm -vrf vmcheck/usr/etc/selinux/targeted/semanage.*.LOCK
# ✀✀✀ END tmp hack

ostree commit --parent=none -b vmcheck --link-checkout-speedup \
ostree commit --parent=none -b vmcheck --add-metadata-string=ostree.source-title="Dev overlay on ${origin}" --add-metadata-string=rpmostree.original-origin=${origin} --link-checkout-speedup \
--selinux-policy=vmcheck --tree=dir=vmcheck
ostree admin deploy vmcheck

0 comments on commit e467547

Please sign in to comment.