mirror of
https://chromium.googlesource.com/chromium/tools/depot_tools.git
synced 2026-01-11 18:51:29 +00:00
Add support for multi argument ands and ors, and the same precedence with
left to right grouping Bug: 905740 Change-Id: I6a0b971556ab66bec841004fbbe8760b9136f216 Reviewed-on: https://chromium-review.googlesource.com/c/chromium/tools/depot_tools/+/1793775 Reviewed-by: Edward Lesmes <ehmaldonado@chromium.org> Commit-Queue: Anthony Polito <apolito@google.com>
This commit is contained in:
committed by
Commit Bot
parent
cc6f585f05
commit
2ae039a065
@@ -250,6 +250,26 @@ class EvaluateConditionTest(unittest.TestCase):
|
||||
self.assertFalse(gclient_eval.EvaluateCondition(
|
||||
'foo != "baz"', {'foo': '"baz"'}))
|
||||
|
||||
def test_triple_or(self):
|
||||
self.assertTrue(gclient_eval.EvaluateCondition(
|
||||
'a or b or c', {'a': 'False', 'b': 'False', 'c': 'True'}))
|
||||
self.assertFalse(gclient_eval.EvaluateCondition(
|
||||
'a or b or c', {'a': 'False', 'b': 'False', 'c': 'False'}))
|
||||
|
||||
def test_triple_and(self):
|
||||
self.assertTrue(gclient_eval.EvaluateCondition(
|
||||
'a and b and c', {'a': 'True', 'b': 'True', 'c': 'True'}))
|
||||
self.assertFalse(gclient_eval.EvaluateCondition(
|
||||
'a and b and c', {'a': 'True', 'b': 'True', 'c': 'False'}))
|
||||
|
||||
def test_triple_and_and_or(self):
|
||||
self.assertTrue(gclient_eval.EvaluateCondition(
|
||||
'a and b and c or d or e',
|
||||
{'a': 'False', 'b': 'False', 'c': 'False', 'd': 'False', 'e': 'True'}))
|
||||
self.assertFalse(gclient_eval.EvaluateCondition(
|
||||
'a and b and c or d or e',
|
||||
{'a': 'True', 'b': 'True', 'c': 'False', 'd': 'False', 'e': 'False'}))
|
||||
|
||||
def test_string_bool(self):
|
||||
self.assertFalse(gclient_eval.EvaluateCondition(
|
||||
'false_str_var and true_var',
|
||||
@@ -265,6 +285,26 @@ class EvaluateConditionTest(unittest.TestCase):
|
||||
'(inside \'false_var_str and true_var\')',
|
||||
str(cm.exception))
|
||||
|
||||
def test_non_bool_in_or(self):
|
||||
with self.assertRaises(ValueError) as cm:
|
||||
gclient_eval.EvaluateCondition(
|
||||
'string_var or true_var',
|
||||
{'string_var': 'Kittens', 'true_var': True})
|
||||
self.assertIn(
|
||||
'invalid "or" operand \'Kittens\' '
|
||||
'(inside \'string_var or true_var\')',
|
||||
str(cm.exception))
|
||||
|
||||
def test_non_bool_in_and(self):
|
||||
with self.assertRaises(ValueError) as cm:
|
||||
gclient_eval.EvaluateCondition(
|
||||
'string_var and true_var',
|
||||
{'string_var': 'Kittens', 'true_var': True})
|
||||
self.assertIn(
|
||||
'invalid "and" operand \'Kittens\' '
|
||||
'(inside \'string_var and true_var\')',
|
||||
str(cm.exception))
|
||||
|
||||
def test_tuple_presence(self):
|
||||
self.assertTrue(gclient_eval.EvaluateCondition(
|
||||
'foo in ("bar", "baz")', {'foo': 'bar'}))
|
||||
|
||||
Reference in New Issue
Block a user