From 0660801321893614be41433ddd6e39eae8463d90 Mon Sep 17 00:00:00 2001 From: Dirk Thomas Date: Mon, 28 Sep 2020 08:07:21 -0700 Subject: [PATCH] support quoted values in conditions (#295) * support quoted values in conditions * add test cases for quoted values --- src/catkin_pkg/condition.py | 10 +++++++++- test/test_package.py | 16 ++++++++++++++++ 2 files changed, 25 insertions(+), 1 deletion(-) diff --git a/src/catkin_pkg/condition.py b/src/catkin_pkg/condition.py index 68feac0f..22f0b099 100644 --- a/src/catkin_pkg/condition.py +++ b/src/catkin_pkg/condition.py @@ -50,7 +50,15 @@ def _get_condition_expression(): value = pp.Word(pp.alphanums + '_-').setName('value') value.setParseAction(_Value) - comparison_term = identifier | value + double_quoted_value = pp.QuotedString('"').setName( + 'double_quoted_value') + double_quoted_value.setParseAction(_Value) + single_quoted_value = pp.QuotedString("'").setName( + 'single_quoted_value') + single_quoted_value.setParseAction(_Value) + + comparison_term = identifier | value | double_quoted_value | \ + single_quoted_value condition = pp.Group(comparison_term + operator + comparison_term).setName('condition') condition.setParseAction(_Condition) diff --git a/test/test_package.py b/test/test_package.py index a8470904..b988a9f3 100644 --- a/test/test_package.py +++ b/test/test_package.py @@ -121,6 +121,22 @@ def test_init_dependency(self): dep = Dependency('foo', condition='foo <= bar or bar >= baz') self.assertFalse(dep.evaluate_condition({})) + dep = Dependency('foo', condition='$foo == ""') + self.assertTrue(dep.evaluate_condition({})) + self.assertFalse(dep.evaluate_condition({'foo': 'foo'})) + + dep = Dependency('foo', condition='$foo == "foo \' bar"') + self.assertTrue(dep.evaluate_condition({'foo': "foo ' bar"})) + self.assertFalse(dep.evaluate_condition({})) + + dep = Dependency('foo', condition="$foo == ''") + self.assertTrue(dep.evaluate_condition({})) + self.assertFalse(dep.evaluate_condition({'foo': 'foo'})) + + dep = Dependency('foo', condition="$foo == 'foo \" bar'") + self.assertTrue(dep.evaluate_condition({'foo': 'foo " bar'})) + self.assertFalse(dep.evaluate_condition({})) + # Testing for more than 1 conditions dep = Dependency('foo', condition='foo > bar and bar < baz and foo > bar') self.assertTrue(dep.evaluate_condition({}))