summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorToshio Kuratomi <toshio@fedoraproject.org>2015-07-06 13:15:11 -0700
committerToshio Kuratomi <toshio@fedoraproject.org>2015-07-06 13:17:28 -0700
commit8b3875f2866c73525e448dcea97ebd329edf4cf9 (patch)
tree4c1019ae265b69b55be58a36fed12bb5291bbc70
parentec4ce7821e26baf88c7537fd20d6a2cf93ea8d5e (diff)
downloadansible-8b3875f2866c73525e448dcea97ebd329edf4cf9.tar.gz
Test unquote works as expected and fix two bugs:
* escaped end quote * a single quote character
-rw-r--r--test/units/parsing/test_unquote.py58
-rw-r--r--v2/ansible/parsing/splitter.py2
2 files changed, 59 insertions, 1 deletions
diff --git a/test/units/parsing/test_unquote.py b/test/units/parsing/test_unquote.py
new file mode 100644
index 0000000000..afb11d4e23
--- /dev/null
+++ b/test/units/parsing/test_unquote.py
@@ -0,0 +1,58 @@
+# coding: utf-8
+# (c) 2015, Toshio Kuratomi <tkuratomi@ansible.com>
+#
+# This file is part of Ansible
+#
+# Ansible is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# Ansible is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with Ansible. If not, see <http://www.gnu.org/licenses/>.
+
+# Make coding more python3-ish
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+from nose import tools
+from ansible.compat.tests import unittest
+
+from ansible.parsing.splitter import unquote
+
+
+# Tests using nose's test generators cannot use unittest base class.
+# http://nose.readthedocs.org/en/latest/writing_tests.html#test-generators
+class TestUnquote:
+ UNQUOTE_DATA = (
+ (u'1', u'1'),
+ (u'\'1\'', u'1'),
+ (u'"1"', u'1'),
+ (u'"1 \'2\'"', u'1 \'2\''),
+ (u'\'1 "2"\'', u'1 "2"'),
+ (u'\'1 \'2\'\'', u'1 \'2\''),
+ (u'"1\\"', u'"1\\"'),
+ (u'\'1\\\'', u'\'1\\\''),
+ (u'"1 \\"2\\" 3"', u'1 \\"2\\" 3'),
+ (u'\'1 \\\'2\\\' 3\'', u'1 \\\'2\\\' 3'),
+ (u'"', u'"'),
+ (u'\'', u'\''),
+ # Not entirely sure these are good but they match the current
+ # behaviour
+ (u'"1""2"', u'1""2'),
+ (u'\'1\'\'2\'', u'1\'\'2'),
+ (u'"1" 2 "3"', u'1" 2 "3'),
+ (u'"1"\'2\'"3"', u'1"\'2\'"3'),
+ )
+
+ def check_unquote(self, quoted, expected):
+ tools.eq_(unquote(quoted), expected)
+
+ def test_unquote(self):
+ for datapoint in self.UNQUOTE_DATA:
+ yield self.check_unquote, datapoint[0], datapoint[1]
diff --git a/v2/ansible/parsing/splitter.py b/v2/ansible/parsing/splitter.py
index 9705baf169..ab80d6f3d9 100644
--- a/v2/ansible/parsing/splitter.py
+++ b/v2/ansible/parsing/splitter.py
@@ -249,7 +249,7 @@ def split_args(args):
return params
def is_quoted(data):
- return len(data) > 0 and (data[0] == '"' and data[-1] == '"' or data[0] == "'" and data[-1] == "'")
+ return len(data) > 1 and data[0] == data[-1] and data[0] in ('"', "'") and data[-2] != '\\'
def unquote(data):
''' removes first and last quotes from a string, if the string starts and ends with the same quotes '''