diff options
author | Klaus Aehlig <aehlig@google.com> | 2018-08-09 08:12:03 -0700 |
---|---|---|
committer | Copybara-Service <copybara-piper@google.com> | 2018-08-09 08:13:26 -0700 |
commit | 33afd3cfc718d222e8b23584652ba0628538a4e5 (patch) | |
tree | 655c3d3a849596a315805c57802d7648b7963ffa | |
parent | e7fcab3fbca88fb8637881f3b2cf0ea8a1e9c8bf (diff) |
Support a .bazelignore file
Add suport for a file .bazelignore, allowing to specify directories
that should be ignored. So far, even for the "ignored" directories,
the directory structure, including following symlinks, still has
to be well founded. We plan to lift that restriction in the future,
but already with the restriction, it is an improvement over the
status quo.
RELNOTES: bazel now supports a .bazelignore file specifying
directories to be ignored; however, these directories still
have to be well founded and, in particular, may not contain
symlink cycles.
Improves on #4888.
Change-Id: Icfe0b7f5c35eceea16e28944ca7711431b71271a
PiperOrigin-RevId: 208050372
-rw-r--r-- | src/main/java/com/google/devtools/build/lib/skyframe/BazelSkyframeExecutorConstants.java | 13 | ||||
-rw-r--r-- | src/test/shell/bazel/BUILD | 8 | ||||
-rwxr-xr-x | src/test/shell/bazel/bazelignore_test.sh | 45 |
3 files changed, 65 insertions, 1 deletions
diff --git a/src/main/java/com/google/devtools/build/lib/skyframe/BazelSkyframeExecutorConstants.java b/src/main/java/com/google/devtools/build/lib/skyframe/BazelSkyframeExecutorConstants.java index f7b19ce28f..331a4e4836 100644 --- a/src/main/java/com/google/devtools/build/lib/skyframe/BazelSkyframeExecutorConstants.java +++ b/src/main/java/com/google/devtools/build/lib/skyframe/BazelSkyframeExecutorConstants.java @@ -28,8 +28,19 @@ public class BazelSkyframeExecutorConstants { public static final ImmutableSet<PathFragment> HARDCODED_BLACKLISTED_PACKAGE_PREFIXES = ImmutableSet.of(); + /** + * The file .bazelignore can be used to specify directories to be ignored by bazel + * + * <p>This is intended for directories containing non-bazel sources (either generated, + * or versioned sources built by other tools) that happen to contain a file called BUILD.</p> + * + * <p>For the time being, this ignore functionality is limited by the fact that it is + * applied only after pattern expansion. So if a pattern expansion fails (e.g., due to + * symlink-cycles) and therefore fails the build, this ignore functionality currently + * has no chance to kick in.</p> + */ public static final PathFragment ADDITIONAL_BLACKLISTED_PACKAGE_PREFIXES_FILE = - PathFragment.EMPTY_FRAGMENT; + PathFragment.create(".bazelignore"); public static final CrossRepositoryLabelViolationStrategy CROSS_REPOSITORY_LABEL_VIOLATION_STRATEGY = CrossRepositoryLabelViolationStrategy.ERROR; diff --git a/src/test/shell/bazel/BUILD b/src/test/shell/bazel/BUILD index e8fd9c09a6..eafe9aadea 100644 --- a/src/test/shell/bazel/BUILD +++ b/src/test/shell/bazel/BUILD @@ -417,6 +417,14 @@ sh_test( ) sh_test( + name = "bazelignore_test", + size = "medium", + srcs = ["bazelignore_test.sh"], + data = [":test-deps"], + tags = ["no_windows"], +) + +sh_test( name = "workspace_resolved_test", size = "medium", srcs = ["workspace_resolved_test.sh"], diff --git a/src/test/shell/bazel/bazelignore_test.sh b/src/test/shell/bazel/bazelignore_test.sh new file mode 100755 index 0000000000..3e6aa1c601 --- /dev/null +++ b/src/test/shell/bazel/bazelignore_test.sh @@ -0,0 +1,45 @@ +#!/bin/bash +# +# Copyright 2016 The Bazel Authors. All rights reserved. +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. +# +# An end-to-end test that Bazel's experimental UI produces reasonable output. + +# Load the test setup defined in the parent directory +CURRENT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)" +source "${CURRENT_DIR}/../integration_test_setup.sh" \ + || { echo "integration_test_setup.sh not found!" >&2; exit 1; } + +#### SETUP ############################################################# + +set -e + +test_broken_BUILD_files_ignored() { + rm -rf work && mkdir work && cd work + touch WORKSPACE + mkdir -p ignoreme/deep/reallydep/stillignoreme + echo This is a broken BUILD file > ignoreme/BUILD + echo This is a broken BUILD file > ignoreme/deep/BUILD + echo This is a broken BUILD file > ignoreme/deep/reallydep/BUILD + echo This is a broken BUILD file > ignoreme/deep/reallydep/stillignoreme/BUILD + touch BUILD + bazel build ... && fail "Expected failure" || : + + echo; echo + echo ignoreme > .bazelignore + bazel build ... \ + || fail "directory mentioned in .bazelrc not ignored as it should" +} + +run_suite "Integration tests for .bazelignore" |