Skip to content

Commit

Permalink
Bug 1138579 - Support multiple Files patterns in moz.build r=gps
Browse files Browse the repository at this point in the history
Add support for |with Files('a/**', 'b/**')| in mozbuild config files.

MozReview-Commit-ID: IoM4qfEhXXc

Differential Revision: https://phabricator.services.mozilla.com/D5315

--HG--
extra : moz-landing-system : lando
  • Loading branch information
moztcampbell committed Sep 20, 2018
1 parent 8d7c299 commit 388abb1
Show file tree
Hide file tree
Showing 4 changed files with 40 additions and 20 deletions.
11 changes: 6 additions & 5 deletions config/tests/test_mozbuild_reading.py
Original file line number Diff line number Diff line change
Expand Up @@ -97,11 +97,12 @@ def pattern_exists(pat):
if not isinstance(ctx, Files):
continue
relsrcdir = ctx.relsrcdir
if not pattern_exists(os.path.join(relsrcdir, ctx.pattern)):
self.fail("The pattern '%s' in a Files() entry in "
"'%s' corresponds to no files in the tree.\n"
"Please update this entry." %
(ctx.pattern, ctx.main_path))
for p in ctx.patterns:
if not pattern_exists(os.path.join(relsrcdir, p)):
self.fail("The pattern '%s' in a Files() entry in "
"'%s' corresponds to no files in the tree.\n"
"Please update this entry." %
(p, ctx.main_path))
test_files = ctx['IMPACTED_TESTS'].files
for p in test_files:
if not pattern_exists(os.path.relpath(p.full_path, config.topsrcdir)):
Expand Down
4 changes: 2 additions & 2 deletions python/mozbuild/mozbuild/frontend/context.py
Original file line number Diff line number Diff line change
Expand Up @@ -1069,9 +1069,9 @@ class Files(SubContext):
"""),
}

def __init__(self, parent, pattern=None):
def __init__(self, parent, *patterns):
super(Files, self).__init__(parent)
self.pattern = pattern
self.patterns = patterns
self.finalized = set()
self.test_files = set()
self.test_tags = set()
Expand Down
17 changes: 10 additions & 7 deletions python/mozbuild/mozbuild/frontend/reader.py
Original file line number Diff line number Diff line change
Expand Up @@ -1342,6 +1342,15 @@ def test_defaults_for_path(ctxs):

r = {}

# Only do wildcard matching if the '*' character is present.
# Otherwise, mozpath.match will match directories, which we've
# arbitrarily chosen to not allow.
def path_matches_pattern(relpath, pattern):
if pattern == relpath:
return True

return '*' in pattern and mozpath.match(relpath, pattern)

for path, ctxs in paths.items():
# Should be normalized by read_relevant_mozbuilds.
assert '\\' not in path
Expand All @@ -1364,13 +1373,7 @@ def test_defaults_for_path(ctxs):
else:
relpath = path

pattern = ctx.pattern

# Only do wildcard matching if the '*' character is present.
# Otherwise, mozpath.match will match directories, which we've
# arbitrarily chosen to not allow.
if pattern == relpath or \
('*' in pattern and mozpath.match(relpath, pattern)):
if any(path_matches_pattern(relpath, p) for p in ctx.patterns):
flags += ctx

if not any([flags.test_tags, flags.test_files, flags.test_flavors]):
Expand Down
28 changes: 22 additions & 6 deletions python/mozbuild/mozbuild/test/frontend/test_context.py
Original file line number Diff line number Diff line change
Expand Up @@ -663,7 +663,7 @@ class TestFiles(unittest.TestCase):
def test_aggregate_empty(self):
c = Context({})

files = {'moz.build': Files(c, pattern='**')}
files = {'moz.build': Files(c, '**')}

self.assertEqual(Files.aggregate(files), {
'bug_component_counts': [],
Expand All @@ -672,7 +672,7 @@ def test_aggregate_empty(self):

def test_single_bug_component(self):
c = Context({})
f = Files(c, pattern='**')
f = Files(c, '**')
f['BUG_COMPONENT'] = (u'Product1', u'Component1')

files = {'moz.build': f}
Expand All @@ -683,10 +683,10 @@ def test_single_bug_component(self):

def test_multiple_bug_components(self):
c = Context({})
f1 = Files(c, pattern='**')
f1 = Files(c, '**')
f1['BUG_COMPONENT'] = (u'Product1', u'Component1')

f2 = Files(c, pattern='**')
f2 = Files(c, '**')
f2['BUG_COMPONENT'] = (u'Product2', u'Component2')

files = {'a': f1, 'b': f2, 'c': f1}
Expand All @@ -701,10 +701,10 @@ def test_multiple_bug_components(self):
def test_no_recommended_bug_component(self):
"""If there is no clear count winner, we don't recommend a bug component."""
c = Context({})
f1 = Files(c, pattern='**')
f1 = Files(c, '**')
f1['BUG_COMPONENT'] = (u'Product1', u'Component1')

f2 = Files(c, pattern='**')
f2 = Files(c, '**')
f2['BUG_COMPONENT'] = (u'Product2', u'Component2')

files = {'a': f1, 'b': f2}
Expand All @@ -716,6 +716,22 @@ def test_no_recommended_bug_component(self):
'recommended_bug_component': None,
})

def test_multiple_patterns(self):
c = Context({})
f1 = Files(c, 'a/**')
f1['BUG_COMPONENT'] = (u'Product1', u'Component1')
f2 = Files(c, 'b/**', 'a/bar')
f2['BUG_COMPONENT'] = (u'Product2', u'Component2')

files = {'a/foo': f1, 'a/bar' : f2, 'b/foo' : f2 }
self.assertEqual(Files.aggregate(files), {
'bug_component_counts': [
((u'Product2', u'Component2'), 2),
((u'Product1', u'Component1'), 1),
],
'recommended_bug_component': (u'Product2', u'Component2'),
})


if __name__ == '__main__':
main()

0 comments on commit 388abb1

Please sign in to comment.