If you are unsure how to resolve build errors in Bazel-orchestrated builds, please send an email to chromeos-build-discuss@google.com.
Cause: Only explicitly declared build-time dependency packages are made available in the ephemeral CrOS SDK container when building a Portage package under Bazel.
Symptom: Missing build-time dependencies result in a variety of error messages, including:
foobar: command not found
No such file or directory: 'foobar'
Package foobar was not found in the pkg-config search path.
'path/to/foobar.h' file not found
unable to find library -lfoobar
Program 'foobar' not found or not executable
import error: No module named 'foobar'
no matching package named foobar found
cannot find package "foobar" in any of:
Solution: Make sure you declare proper DEPEND
/BDEPEND
in your ebuild/eclasses.
Example fixes:
Cause: sudo
doesn't work in the ephemeral CrOS SDK container used to build Portage packages as it is unprivileged. In fact, /usr/bin/sudo
is replaced with a fake script that just executes the specified command.
Symptom: If your package attempts to run sudo
, the following message will be printed to the standard error:
fake_sudo: INFO: This is the fake sudo for the ephemeral CrOS SDK.
This message doesn't mean an immediate failure, but the subsequent process will run unprivileged.
Solution: Do not use sudo
in the package build.
If your package uses platform2_test.py
to run foreign-architecture executables on build, pass --strategy=unprivileged
to run the script without sudo.
Example fixes:
Sometimes you want to enter an ephemeral CrOS SDK container where a package build is failing to inspect the environment interactively.
To enter an ephemeral CrOS SDK container, run the following command:
$ BOARD=amd64-generic bazel run @portage//target/sys-apps/attr:debug -- --login=after
This command will give you an interactive shell after building a package. You can also specify other values to --login
to choose the timing to enter an interactive console:
--login=before
: before building the package--login=after
: after building the package (default)--login=after-fail
: after failing to build the packageBazel is able to correctly reuse content from the cache when all inputs are identified to it so it can detect when they change. Since our toolchain and our host tools (e.g. gsutil) are not yet fully hermetic, it‘s possible that you’ll run into problems when tools not yet tracked by Bazel are updated. In these situations we've found it useful to run bazel clean --expunge
to clear cached artifacts that seem not to be cleared without the --expunge
flag.
If you find you need the --expunge
flag, please file a bug to let the Bazelification team know about the non-hermeticity so we can fix the problem.