mirror of
https://chromium.googlesource.com/chromium/tools/depot_tools.git
synced 2026-01-11 18:51:29 +00:00
Revert "gclient eval: Expand vars while parsing DEPS files"
This reverts commit 88f9c40e0c.
Reason for revert: suspected to be causing update scripts failures and prevent gce bots from connecting
https://build.chromium.org/deprecated/tryserver.chromium.win/builders/win7_chromium_rel_ng/builds/128479/steps/update_scripts/logs/stdio
Original change's description:
> gclient eval: Expand vars while parsing DEPS files
>
> Introduce a Parse function that takes care of expanding vars while parsing
> the DEPS file.
>
> It wraps Exec and exec calls, and supports deferring the expansion until
> later, so gclient flatten gets access to the unexpanded version.
>
> Bug: 821199
> Change-Id: I943b021cc4474c9cda67b3816b841dd8ada3f5b2
> Reviewed-on: https://chromium-review.googlesource.com/973749
> Commit-Queue: Edward Lesmes <ehmaldonado@chromium.org>
> Reviewed-by: Aaron Gable <agable@chromium.org>
> Reviewed-by: Dirk Pranke <dpranke@chromium.org>
TBR=agable@chromium.org,dpranke@chromium.org,ehmaldonado@chromium.org
Change-Id: Ib9b84c13ef9b56735fd8f714b74a6601c61715e5
No-Presubmit: true
No-Tree-Checks: true
No-Try: true
Bug: 821199
Reviewed-on: https://chromium-review.googlesource.com/976721
Reviewed-by: Benjamin Pastene <bpastene@chromium.org>
Commit-Queue: Benjamin Pastene <bpastene@chromium.org>
This commit is contained in:
committed by
Commit Bot
parent
88f9c40e0c
commit
728244f70a
@@ -20,17 +20,6 @@ import gclient_eval
|
||||
|
||||
|
||||
_SAMPLE_DEPS_FILE = textwrap.dedent("""\
|
||||
vars = {
|
||||
'git_repo': 'https://example.com/repo.git',
|
||||
# Some comment with bad indentation
|
||||
'dep_2_rev': '1ced',
|
||||
# Some more comments
|
||||
# 1
|
||||
# 2
|
||||
# 3
|
||||
'dep_3_rev': '5p1e5',
|
||||
}
|
||||
|
||||
deps = {
|
||||
'src/dep': Var('git_repo') + '/dep' + '@' + 'deadbeef',
|
||||
# Some comment
|
||||
@@ -56,82 +45,59 @@ deps = {
|
||||
'dep_type': 'cipd',
|
||||
},
|
||||
}
|
||||
""")
|
||||
|
||||
vars = {
|
||||
'git_repo': 'https://example.com/repo.git',
|
||||
# Some comment with bad indentation
|
||||
'dep_2_rev': '1ced',
|
||||
# Some more comments
|
||||
# 1
|
||||
# 2
|
||||
# 3
|
||||
'dep_3_rev': '5p1e5',
|
||||
}""")
|
||||
|
||||
|
||||
class GClientEvalTest(unittest.TestCase):
|
||||
def test_str(self):
|
||||
self.assertEqual(
|
||||
'foo',
|
||||
gclient_eval._gclient_eval('"foo"', vars_dict=None, expand_vars=False,
|
||||
filename='<unknown>'))
|
||||
self.assertEqual('foo', gclient_eval._gclient_eval('"foo"'))
|
||||
|
||||
def test_tuple(self):
|
||||
self.assertEqual(
|
||||
('a', 'b'),
|
||||
gclient_eval._gclient_eval('("a", "b")', vars_dict=None,
|
||||
expand_vars=False, filename='<unknown>'))
|
||||
self.assertEqual(('a', 'b'), gclient_eval._gclient_eval('("a", "b")'))
|
||||
|
||||
def test_list(self):
|
||||
self.assertEqual(
|
||||
['a', 'b'],
|
||||
gclient_eval._gclient_eval('["a", "b"]', vars_dict=None,
|
||||
expand_vars=False, filename='<unknown>'))
|
||||
self.assertEqual(['a', 'b'], gclient_eval._gclient_eval('["a", "b"]'))
|
||||
|
||||
def test_dict(self):
|
||||
self.assertEqual(
|
||||
{'a': 'b'},
|
||||
gclient_eval._gclient_eval('{"a": "b"}', vars_dict=None,
|
||||
expand_vars=False, filename='<unknown>'))
|
||||
self.assertEqual({'a': 'b'}, gclient_eval._gclient_eval('{"a": "b"}'))
|
||||
|
||||
def test_name_safe(self):
|
||||
self.assertEqual(
|
||||
True,
|
||||
gclient_eval._gclient_eval('True', vars_dict=None,
|
||||
expand_vars=False, filename='<unknown>'))
|
||||
self.assertEqual(True, gclient_eval._gclient_eval('True'))
|
||||
|
||||
def test_name_unsafe(self):
|
||||
with self.assertRaises(ValueError) as cm:
|
||||
gclient_eval._gclient_eval('UnsafeName', vars_dict=None,
|
||||
expand_vars=False, filename='<unknown>')
|
||||
gclient_eval._gclient_eval('UnsafeName')
|
||||
self.assertIn('invalid name \'UnsafeName\'', str(cm.exception))
|
||||
|
||||
def test_invalid_call(self):
|
||||
with self.assertRaises(ValueError) as cm:
|
||||
gclient_eval._gclient_eval('Foo("bar")', vars_dict=None,
|
||||
expand_vars=False, filename='<unknown>')
|
||||
self.assertIn('Var is the only allowed function', str(cm.exception))
|
||||
|
||||
def test_call(self):
|
||||
self.assertEqual(
|
||||
'{bar}',
|
||||
gclient_eval._gclient_eval('Var("bar")', vars_dict=None,
|
||||
expand_vars=False, filename='<unknown>'))
|
||||
gclient_eval._gclient_eval('Var("bar")'))
|
||||
|
||||
def test_plus(self):
|
||||
self.assertEqual(
|
||||
'foo',
|
||||
gclient_eval._gclient_eval('"f" + "o" + "o"', vars_dict=None,
|
||||
expand_vars=False, filename='<unknown>'))
|
||||
self.assertEqual('foo', gclient_eval._gclient_eval('"f" + "o" + "o"'))
|
||||
|
||||
def test_format(self):
|
||||
self.assertEqual(
|
||||
'foo',
|
||||
gclient_eval._gclient_eval('"%s" % "foo"', vars_dict=None,
|
||||
expand_vars=False, filename='<unknown>'))
|
||||
self.assertEqual('foo', gclient_eval._gclient_eval('"%s" % "foo"'))
|
||||
|
||||
def test_not_expression(self):
|
||||
with self.assertRaises(SyntaxError) as cm:
|
||||
gclient_eval._gclient_eval(
|
||||
'def foo():\n pass', vars_dict=None, expand_vars=False,
|
||||
filename='<unknown>')
|
||||
gclient_eval._gclient_eval('def foo():\n pass')
|
||||
self.assertIn('invalid syntax', str(cm.exception))
|
||||
|
||||
def test_not_whitelisted(self):
|
||||
with self.assertRaises(ValueError) as cm:
|
||||
gclient_eval._gclient_eval(
|
||||
'[x for x in [1, 2, 3]]', vars_dict=None, expand_vars=False,
|
||||
filename='<unknown>')
|
||||
gclient_eval._gclient_eval('[x for x in [1, 2, 3]]')
|
||||
self.assertIn(
|
||||
'unexpected AST node: <_ast.ListComp object', str(cm.exception))
|
||||
|
||||
@@ -139,9 +105,7 @@ class GClientEvalTest(unittest.TestCase):
|
||||
for test_case in itertools.permutations(range(4)):
|
||||
input_data = ['{'] + ['"%s": "%s",' % (n, n) for n in test_case] + ['}']
|
||||
expected = [(str(n), str(n)) for n in test_case]
|
||||
result = gclient_eval._gclient_eval(
|
||||
''.join(input_data), vars_dict=None, expand_vars=False,
|
||||
filename='<unknown>')
|
||||
result = gclient_eval._gclient_eval(''.join(input_data))
|
||||
self.assertEqual(expected, result.items())
|
||||
|
||||
|
||||
@@ -160,11 +124,12 @@ class ExecTest(unittest.TestCase):
|
||||
|
||||
def test_schema_wrong_type(self):
|
||||
with self.assertRaises(schema.SchemaError):
|
||||
gclient_eval.Exec('include_rules = {}')
|
||||
gclient_eval.Exec('include_rules = {}', '<string>')
|
||||
|
||||
def test_recursedeps_list(self):
|
||||
local_scope = gclient_eval.Exec(
|
||||
'recursedeps = [["src/third_party/angle", "DEPS.chromium"]]')
|
||||
'recursedeps = [["src/third_party/angle", "DEPS.chromium"]]',
|
||||
'<string>')
|
||||
self.assertEqual(
|
||||
{'recursedeps': [['src/third_party/angle', 'DEPS.chromium']]},
|
||||
local_scope)
|
||||
@@ -177,35 +142,7 @@ class ExecTest(unittest.TestCase):
|
||||
'deps = {',
|
||||
' "a_dep": "a" + Var("foo") + "b",',
|
||||
'}',
|
||||
]))
|
||||
self.assertEqual({
|
||||
'vars': collections.OrderedDict([('foo', 'bar')]),
|
||||
'deps': collections.OrderedDict([('a_dep', 'abarb')]),
|
||||
}, local_scope)
|
||||
|
||||
def test_braces_var(self):
|
||||
local_scope = gclient_eval.Exec('\n'.join([
|
||||
'vars = {',
|
||||
' "foo": "bar",',
|
||||
'}',
|
||||
'deps = {',
|
||||
' "a_dep": "a{foo}b",',
|
||||
'}',
|
||||
]))
|
||||
self.assertEqual({
|
||||
'vars': collections.OrderedDict([('foo', 'bar')]),
|
||||
'deps': collections.OrderedDict([('a_dep', 'abarb')]),
|
||||
}, local_scope)
|
||||
|
||||
def test_var_unexpanded(self):
|
||||
local_scope = gclient_eval.Exec('\n'.join([
|
||||
'vars = {',
|
||||
' "foo": "bar",',
|
||||
'}',
|
||||
'deps = {',
|
||||
' "a_dep": "a" + Var("foo") + "b",',
|
||||
'}',
|
||||
]), expand_vars=False)
|
||||
]), '<string>')
|
||||
self.assertEqual({
|
||||
'vars': collections.OrderedDict([('foo', 'bar')]),
|
||||
'deps': collections.OrderedDict([('a_dep', 'a{foo}b')]),
|
||||
|
||||
Reference in New Issue
Block a user