-
Notifications
You must be signed in to change notification settings - Fork 4.1k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
--output_base in workspace causes infinite symlink when WORKSPACE uses load() #6989
Comments
As a follow-up with the last comment, based on |
Any update on this? |
Have you tried this workaround mkdir $HOME/bazel_output_base That seems to work for me. |
Hi @aiuto , |
@irengrig is this something that your managed directories can solve? |
Friendly ping :) |
Running into the same problem. Our reason to place --output_base in the workspace is that we use Gilab, and, in order to pass build output from one Gitlab stage to another, we need the output_base to be a Gitlab artifact - which can only reside in the sandbox. Any solutions to this? |
I solved my own problem listing the --output_base location in .bazelignore. The output_base can also be listed as a startup option in the .bazelrc file, to not have to repeat it manually in all bazel commands. |
Hi there! We're doing a clean up of old issues and will be closing this one. Please reopen if you’d like to discuss anything further. We’ll respond as soon as we have the bandwidth/resources to do so. |
This is still an issue. |
Description of the problem / feature request:
Bazel will recurse through the output base into the current workspace when
--output_base
is a directory in the workspace and theWORKSPACE
file loads from a.bzl
file in the workspace, causing an infinite symlink failure.Feature requests: what underlying problem are you trying to solve with this feature?
We use
--output_base=.bazel
with.bazel
in the.bazelignore
file to keep the output base in the workspace to cache build output between CI steps.This works well, unless we try to
load()
a repository rule from a.bzl
file in the workspace. This requires us to use a@current_workspace//foo:path.bzl
-style label. Doing so creates.bazel/external/current_workspace
, which Bazel reports as an infinite symlink error.Bugs: what's the simplest, easiest way to reproduce this bug? Please provide a minimal example if possible.
Clone https://github.com/clintharrison/output-base-bug and run
bazel --output_base=.bazel query //...
What operating system are you running Bazel on?
macOS 10.13
What's the output of
bazel info release
?release 0.21.0
Any other information, logs, or outputs that you want to share?
It's also unclear why we need to use
@current_workspace//
labels here; in the toy example I linked above, it works to use a simple//foo:bar.bzl
path, but that doesn't seem viable if we are writing Starlark rules that others want to include from their workspaces.The text was updated successfully, but these errors were encountered: