Skip to content

config_setting incorrectly treated as implicit dependency by --incompatible_visibility_private_attributes_at_definition #19126

@dgp1130

Description

@dgp1130

Description of the bug:

When explicitly depending on a config_setting and enabling --incompatible_visibility_private_attributes_at_definition, the setting is incorrectly treated as an implicit dependency which must be visible to the dependent's rule definition, which doesn't make logical sense. The full set of conditions from my understanding is:

  1. A target which depends on a config_setting from a different package through a select key.
  2. The target is an instance of a rule from a another package which does not have visibility into the config_setting.
  3. --incompatible_visibility_private_attributes_at_definition.
# BUILD.bazel

load("//build_defs:defs.bzl", "my_rule")

my_rule(
    name = "my_target",
    value = select({
        "//config_setting:my_setting": "foo",
        "//conditions:default": "bar",
    }),
)

When all three happen it throws an error like this:

$ bazel build //:my_target
ERROR: /home/doug/Source/bazel_visibility/BUILD.bazel:3:8: in my_rule rule //:my_target: target '//config_setting:my_setting' is not visible from target '//build_defs:defs.bzl'. Check the visibility declaration of the former target if you think the dependency is legitimate
ERROR: /home/doug/Source/bazel_visibility/BUILD.bazel:3:8: Analysis of target '//:my_target' failed
ERROR: Analysis of target '//:my_target' failed; build aborted: 
INFO: Elapsed time: 0.064s
INFO: 0 processes.
FAILED: Build did NOT complete successfully (2 packages loaded, 2 targets configured)

This doesn't make sense: target '//config_setting:my_setting' is not visible from target '//build_defs:defs.bzl'. This should not be required, as the config setting is not an implicit dependency.

What's the simplest, easiest way to reproduce this bug? Please provide a minimal example if possible.

Minimal reproduction here: https://github.com/dgp1130/bazel-config-setting-visibility-bug/

It does rely on Skylib which probably isn't necessary but I figured that wasn't too significant and I didn't want to try and figure out how to define flags manually.

Which operating system are you running Bazel on?

Ubuntu on WSL

What is the output of bazel info release?

release 6.3.0

If bazel info release returns development version or (@non-git), tell us how you built Bazel.

No response

What's the output of git remote get-url origin; git rev-parse master; git rev-parse HEAD ?

$ git remote get-url origin; git rev-parse main; git rev-parse HEAD
[email protected]:dgp1130/bazel-config-setting-visibility-bug
d86833d09fb3bcb3eb0429d74eb80364db7e684a
d86833d09fb3bcb3eb0429d74eb80364db7e684a

Is this a regression? If yes, please try to identify the Bazel commit where the bug was introduced.

I don't know, however I initially reproduced on version 6.0.0 before upgrading to 6.3.0 to confirm it was still present on latest. The bug is at least that old.

Have you found anything relevant by searching the web?

#12932 feels like it might be relevant, however I found that --incompatible_enforce_config_setting_visibility had no effect, so it could be nothing.

Any other information, logs, or outputs that you want to share?

No response

Metadata

Metadata

Assignees

No one assigned

    Labels

    team-Loading-APIBUILD file and macro processing: labels, package(), visibility, globtype: buguntriaged

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions