From a55ac9dde8ebbd43f61e052a2fee7c131163f07e Mon Sep 17 00:00:00 2001 From: Pavel Raiskup Date: Tue, 22 Oct 2024 12:59:24 +0200 Subject: [PATCH] oci-as-buildroot Fixes: #1482 --- mock/py/mockbuild/config.py | 4 +- mock/py/mockbuild/plugins/oci_as_buildroot.py | 39 +++++++++++++++++++ 2 files changed, 42 insertions(+), 1 deletion(-) create mode 100644 mock/py/mockbuild/plugins/oci_as_buildroot.py diff --git a/mock/py/mockbuild/config.py b/mock/py/mockbuild/config.py index 533d9f3ce..e786506ef 100644 --- a/mock/py/mockbuild/config.py +++ b/mock/py/mockbuild/config.py @@ -31,7 +31,7 @@ 'ccache', 'selinux', 'package_state', 'chroot_scan', 'lvm_root', 'compress_logs', 'sign', 'pm_request', 'hw_info', 'procenv', 'showrc', 'rpkg_preprocessor', - 'rpmautospec', 'buildroot_lock'] + 'rpmautospec', 'buildroot_lock', 'oci_as_buildroot'] def nspawn_supported(): """Detect some situations where the systemd-nspawn chroot code won't work""" @@ -234,6 +234,8 @@ def setup_default_config_opts(): 'process-distgit', ] }, + 'oci_as_buildroot_enable': True, + 'oci_as_buildroot_opts': {}, } config_opts['environment'] = { diff --git a/mock/py/mockbuild/plugins/oci_as_buildroot.py b/mock/py/mockbuild/plugins/oci_as_buildroot.py new file mode 100644 index 000000000..31f347961 --- /dev/null +++ b/mock/py/mockbuild/plugins/oci_as_buildroot.py @@ -0,0 +1,39 @@ +""" +Generate OCI from prepared build chroot. +Use given OCI image as build chroot (TODO). +""" + +from mockbuild.util import do + +requires_api_version = "1.1" + + +def init(plugins, conf, buildroot): + """ The obligatory plugin entry point """ + OCIAsBuildroot(plugins, conf, buildroot) + + +class OCIAsBuildroot: + """ + OCIAsBuildroot plugin (class). + """ + def __init__(self, plugins, conf, buildroot): + self.buildroot = buildroot + self.state = buildroot.state + self.conf = conf + plugins.add_hook("postdeps", self.produce_buildroot_image) + + def _produce_image_as_root(self): + + name = "mock-container-foo" + tarball = "/tmp/mock.tar" + chroot = self.buildroot.make_chroot_path() + do(["buildah", "from", "--name", name, "scratch"]) + do(["buildah", "add", name, chroot, "/"]) + do(["buildah", "commit", "--format", "oci", name, + "oci-archive:" + tarball]) + + def produce_buildroot_image(self): + """ Generate OCI image from buildroot using Buildah """ + with self.buildroot.uid_manager.elevated_privileges(): + self._produce_image_as_root()