The build-requirements for Fedora (and other rpm-based distributions) are:
gpgme-devel
To build images, you will also need to install osbuild
and its sub-packages.
The following utilities, defined in the cmd/
directory, are useful for
development and testing. They should not be relied on for production
purposes. In particular, command line options and default behaviour can change
at any time.
The following are high level descriptions of what some of the utilities can do and how they can be used during development. For specific flags and options, refer to each command's help output and doc strings.
Each utility can be compiled using go build -o <outputfile> ./cmd/<utility>
or run directly using go run ./cmd/<utility>
. Use go run ./cmd/<utility> -help
for option descriptions (e.g. go run ./cmd/gen-manifests -help
).
The gen-manifests
tool can be used to generate all or a subset of the
manifests for the images defined in the repository. This is useful for quickly
seeing the effects of changes in image definitions on the manifest and the
image build itself. While manifests are meant to be machine readable, it is
often much faster to inspect the difference between two manifests (before and
after a change in code) to evaluate if a change is having the desired effect.
Manifests can be generated with or without content resolution (e.g. package depsolving, containers, ostree commits). If you are working on changes in image definitions that do not rely on content (e.g. an image type's partition table), manifests without resolved content can be generated almost instantly. Note that even though content is not resolved and packages are not depsolved, the selected packages without their dependencies are still added to generated manifests, so disabling package depsolving can also be used to inspect package selection without dependencies.
Manifests should be generated with all content enabled if they are going to be built. A common workflow when working on changing image definitions, or adding a new image type, might be:
- Generate the manifests for the image types that you will be working on.
- Make changes in an existing image definition or add a new image type.
- Add appropriate configuration changes:
- If a new image type is added, add it to the config map under an appropriate configuration file or write a new one.
- If an existing image type is being modified, and the change depends on an image customization, make sure the modification is covered by an existing test config.
- Generate the relevant manifests without content (
-packages=false -containers=false -commits=false
).- If the change depends on a customization, it might be more useful to generate multiple manifests with different configuration options set and inspect the differences between them.
- Inspect the differences between manifests generated in steps 1 and 4.
- Generate manifest with all content enabled for the relevant image types.
- Build at least one of the manifests using
osuild
and inspect the output (boot the image or mount it to look for the desired changes).
NOTE: By default, manifests created with the gen-manifest
tool contain extra
metadata. The manifest itself is stored under the key "manifest". You can
extract the actual manifest using jq .manifest <manifestfile>.json
. Alternatively, you can generate manifests without
metadata using the -metadata=false
option.
You can build an image by generating its manifest and then running
osbuild. Alternatively, the cmd/build
tool can perform both steps in one
call. It will generate a manifest, build the image, and store both the image
and its manifest in the output directory.
The build tool must be run as root because image building with osbuild requires
superuser privileges. It is not recommended to run sudo go run ./cmd/build
however. The go run
command can make changes to the go build
cache and if these changes are made as root, it can cause issues when running
other go commands in the future as a regular user. Instead, it is recommended
to first build the binary and then run it as root:
go build -o build ./cmd/build
sudo ./build ...
The cmd/list-images
utility simply lists all available combinations of
distribution, architecture, and image type. It also supports filtering one or
more of those three variables.