-
Notifications
You must be signed in to change notification settings - Fork 1.3k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[workspace] Enhance check_lists_consistency docs and failure message
- Loading branch information
1 parent
c1c18a4
commit d1c7a67
Showing
3 changed files
with
26 additions
and
22 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,25 +1,29 @@ | ||
# -*- python -*- | ||
|
||
def check_lists_consistency( | ||
glob, | ||
file_list): | ||
"""Checks consistency between lists of files and glob expression. | ||
*, | ||
files, | ||
glob_include, | ||
glob_exclude = None): | ||
"""Checks that a hard-coded list of files fully covers a glob expression. | ||
If lists of files are hard-coded (e.g. public and private headers), one may | ||
want to verify that all the files that should be listed are indeed listed. | ||
This is especially important when the version of the target is updated, to | ||
verify that the lists of files are also updated if necessary. | ||
When a package.BUILD.bazel file hard-codes a list of files (e.g., a list of | ||
headers of source files), we would like to fail-fast when upstream adds new | ||
files so that we can refresh our list. This is especially important when | ||
the version of the external is updated. | ||
Args: | ||
glob (:obj:`str`): expression used to find all the files. The list of | ||
files created thanks to this expression is compared to the given | ||
lists of files. | ||
file_list (:obj:`list` of :obj:`str`): List of file names. This is | ||
typically a list of public headers concatenated with a list of private | ||
headers. | ||
files (:obj:`list` of :obj:`str`): List of expected file names that | ||
will be matched by the glob expressions. | ||
glob_include (:obj:`list` of :obj:`str`): List of glob patterns to | ||
search for, per native.glob(include = ...). | ||
glob_exclude (:obj:`list` of :obj:`str`): List of glob patterns to | ||
exclude from the search, per native.glob(exclude = ...). | ||
""" | ||
all_headers = native.glob(glob) | ||
unknown_headers = [x for x in all_headers if x not in file_list] | ||
if len(unknown_headers) != 0: | ||
fail("Inconsistent file lists. Unknown file(s): " + | ||
str(unknown_headers)) | ||
all_files = native.glob(glob_include, exclude = (glob_exclude or [])) | ||
uncovered_files = sorted([x for x in all_files if x not in files]) | ||
if len(uncovered_files) != 0: | ||
fail("The following files matched a glob of upstream sources, but " + | ||
"were not covered by the package.BUILD.bazel file: {}".format( | ||
uncovered_files, | ||
)) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters