diff --git a/src/app/rpmostree-compose-builtin-tree.c b/src/app/rpmostree-compose-builtin-tree.c index e308b6c9..28cb97b0 100644 --- a/src/app/rpmostree-compose-builtin-tree.c +++ b/src/app/rpmostree-compose-builtin-tree.c @@ -934,9 +934,6 @@ impl_compose_tree (const char *treefile_pathstr, cancellable, error)) return glnx_prefix_error (error, "Preparing rootfs for commit"); - if (!rpmostree_copy_additional_files (rootfs_fd, self->treefile_context_dirs->pdata[0], treefile, cancellable, error)) - return FALSE; - g_autoptr(GFile) treefile_dirpath = g_file_get_parent (self->treefile); if (!rpmostree_check_passwd (self->repo, rootfs_fd, treefile_dirpath, treefile, self->previous_checksum, diff --git a/src/libpriv/rpmostree-postprocess.c b/src/libpriv/rpmostree-postprocess.c index 9b7ac182..053e55d9 100644 --- a/src/libpriv/rpmostree-postprocess.c +++ b/src/libpriv/rpmostree-postprocess.c @@ -1225,18 +1225,15 @@ rpmostree_rootfs_postprocess_common (int rootfs_fd, return TRUE; } -/** - * rpmostree_copy_additional_files: - * - * Copy external files, if specified in the configuration file, from +/* Copy external files, if specified in the configuration file, from * the context directory to the rootfs. */ -gboolean -rpmostree_copy_additional_files (int rootfs_dfd, - GFile *context_directory, - JsonObject *treefile, - GCancellable *cancellable, - GError **error) +static gboolean +copy_additional_files (int rootfs_dfd, + GFile *context_directory, + JsonObject *treefile, + GCancellable *cancellable, + GError **error) { guint len; JsonArray *add = NULL; @@ -1581,6 +1578,10 @@ rpmostree_treefile_postprocessing (int rootfs_fd, } } + /* Copy in additional files before postprocessing */ + if (!copy_additional_files (rootfs_fd, context_directory, treefile, cancellable, error)) + return FALSE; + const char *postprocess_script = NULL; if (!_rpmostree_jsonutil_object_get_optional_string_member (treefile, "postprocess-script", &postprocess_script, error)) diff --git a/src/libpriv/rpmostree-postprocess.h b/src/libpriv/rpmostree-postprocess.h index a653c44d..6a8288dc 100644 --- a/src/libpriv/rpmostree-postprocess.h +++ b/src/libpriv/rpmostree-postprocess.h @@ -78,9 +78,3 @@ rpmostree_commit (int rootfs_dfd, char **out_new_revision, GCancellable *cancellable, GError **error); -gboolean -rpmostree_copy_additional_files (int rootfs_dfd, - GFile *context_directory, - JsonObject *treefile, - GCancellable *cancellable, - GError **error); diff --git a/tests/compose-tests/test-misc-tweaks.sh b/tests/compose-tests/test-misc-tweaks.sh index f07f9407..c2bed2f2 100755 --- a/tests/compose-tests/test-misc-tweaks.sh +++ b/tests/compose-tests/test-misc-tweaks.sh @@ -16,6 +16,15 @@ pysetjsonmember "units" '["tuned.service"]' pysetjsonmember "add-files" '[["foo.txt", "/usr/etc/foo.txt"], ["baz.txt", "/usr/share/baz.txt"], ["bar.txt", "/etc/bar.txt"]]' +pysetjsonmember "postprocess-script" \"$PWD/postprocess.sh\" +cat > postprocess.sh << EOF +#!/bin/bash +set -xeuo pipefail +echo misc-tweaks-postprocess-done > /usr/share/misc-tweaks-postprocess-done.txt +cp -a /usr/etc/foo.txt /usr/share/misc-tweaks-foo.txt +EOF +chmod a+x postprocess.sh + pysetjsonmember "remove-files" '["etc/hosts"]' pysetjsonmember "remove-from-packages" '[["setup", "/etc/hosts\..*"]]' rnd=$RANDOM @@ -52,6 +61,9 @@ ostree --repo=${repobuild} cat ${treeref} /usr/etc/bar.txt > out.txt assert_file_has_content out.txt bar ostree --repo=${repobuild} cat ${treeref} /usr/share/baz.txt > out.txt assert_file_has_content out.txt baz +# https://github.com/projectatomic/rpm-ostree/pull/997 +ostree --repo=${repobuild} cat ${treeref} /usr/share/misc-tweaks-foo.txt > out.txt +assert_file_has_content out.txt $rnd echo "ok add-files" ostree --repo=${repobuild} ls ${treeref} /usr/etc > out.txt