Document the new option and add more tests
This commit is contained in:
@@ -345,23 +345,98 @@ class QuotedTestCase(RuleTestCase):
|
|||||||
' word 2"\n',
|
' word 2"\n',
|
||||||
conf, problem1=(9, 3))
|
conf, problem1=(9, 3))
|
||||||
|
|
||||||
def test_needed_extra_regex(self):
|
def test_needed_extra_regex_1(self):
|
||||||
conf1 = 'quoted-strings: {quote-type: single, ' + \
|
conf = 'quoted-strings: {quote-type: single, ' + \
|
||||||
'required: only-when-needed, ' + \
|
'required: only-when-needed, ' + \
|
||||||
'needed-extra-regex: ""}\n'
|
'needed-extra-regex: ^%.*%$}\n'
|
||||||
|
|
||||||
self.check('---\n'
|
self.check('---\n'
|
||||||
'string1: foo\n'
|
'string1: \'$foo$\'\n' # fails
|
||||||
'string2: \'foo\'\n' # fails
|
'string2: \'%foo%\'\n',
|
||||||
'string3: \'%foo\'\n', # fails
|
conf, problem1=(2, 10))
|
||||||
conf1, problem1=(3, 10), problem2=(4, 10))
|
self.check('---\n'
|
||||||
|
'multiline string 1: |\n'
|
||||||
|
' \'%line 1\n'
|
||||||
|
' line 2%\'\n'
|
||||||
|
'multiline string 2: >\n'
|
||||||
|
' \'%word 1\n'
|
||||||
|
' word 2%\'\n'
|
||||||
|
'multiline string 3:\n'
|
||||||
|
' \'%word 1\n'
|
||||||
|
' word 2%\'\n'
|
||||||
|
'multiline string 4:\n'
|
||||||
|
' "\'%word 1\\\n' # fails
|
||||||
|
' word 2%\'"\n',
|
||||||
|
conf, problem1=(12, 3))
|
||||||
|
|
||||||
conf2 = 'quoted-strings: {quote-type: single, ' + \
|
def test_needed_extra_regex_2(self):
|
||||||
'required: only-when-needed, ' + \
|
conf = 'quoted-strings: {quote-type: single, ' + \
|
||||||
'needed-extra-regex: ^%.*$}\n'
|
'required: only-when-needed, ' + \
|
||||||
|
'needed-extra-regex: ^%}\n'
|
||||||
|
|
||||||
self.check('---\n'
|
self.check('---\n'
|
||||||
'string1: foo\n'
|
'string1: \'$foo\'\n' # fails
|
||||||
'string2: \'foo\'\n' # fails
|
'string2: \'%foo\'\n',
|
||||||
'string3: \'%foo\'\n',
|
conf, problem1=(2, 10))
|
||||||
conf2, problem1=(3, 10))
|
self.check('---\n'
|
||||||
|
'multiline string 1: |\n'
|
||||||
|
' \'%line 1\n'
|
||||||
|
' line 2\'\n'
|
||||||
|
'multiline string 2: >\n'
|
||||||
|
' \'%word 1\n'
|
||||||
|
' word 2\'\n'
|
||||||
|
'multiline string 3:\n'
|
||||||
|
' \'%word 1\n'
|
||||||
|
' word 2\'\n'
|
||||||
|
'multiline string 4:\n'
|
||||||
|
' "\'%word 1\\\n' # fails
|
||||||
|
' word 2\'"\n',
|
||||||
|
conf, problem1=(12, 3))
|
||||||
|
|
||||||
|
def test_needed_extra_regex_3(self):
|
||||||
|
conf = 'quoted-strings: {quote-type: single, ' + \
|
||||||
|
'required: only-when-needed, ' + \
|
||||||
|
'needed-extra-regex: ;$}\n'
|
||||||
|
|
||||||
|
self.check('---\n'
|
||||||
|
'string1: \'foo,\'\n' # fails
|
||||||
|
'string2: \'foo;\'\n',
|
||||||
|
conf, problem1=(2, 10))
|
||||||
|
self.check('---\n'
|
||||||
|
'multiline string 1: |\n'
|
||||||
|
' \'line 1;\n'
|
||||||
|
' line 2\'\n'
|
||||||
|
'multiline string 2: >\n'
|
||||||
|
' \'word 1;\n'
|
||||||
|
' word 2\'\n'
|
||||||
|
'multiline string 3:\n'
|
||||||
|
' \'word 1;\n' # fails
|
||||||
|
' word 2\'\n'
|
||||||
|
'multiline string 4:\n'
|
||||||
|
' "\'word 1;\\\n' # fails
|
||||||
|
' word 2\'"\n',
|
||||||
|
conf, problem1=(9, 3), problem2=(12, 3))
|
||||||
|
|
||||||
|
def test_needed_extra_regex_4(self):
|
||||||
|
conf = 'quoted-strings: {quote-type: single, ' + \
|
||||||
|
'required: only-when-needed, ' + \
|
||||||
|
'needed-extra-regex: ".+ .+"}\n'
|
||||||
|
|
||||||
|
self.check('---\n'
|
||||||
|
'string1: \'foo\'\n' # fails
|
||||||
|
'string2: \'foo bar\'\n',
|
||||||
|
conf, problem1=(2, 10))
|
||||||
|
self.check('---\n'
|
||||||
|
'multiline string 1: |\n'
|
||||||
|
' \'line1\n'
|
||||||
|
' line2\'\n'
|
||||||
|
'multiline string 2: >\n'
|
||||||
|
' \'word1\n'
|
||||||
|
' word2\'\n'
|
||||||
|
'multiline string 3:\n'
|
||||||
|
' \'word1\n'
|
||||||
|
' word2\'\n'
|
||||||
|
'multiline string 4:\n'
|
||||||
|
' "\'word1\\\n' # fails
|
||||||
|
' word2\'"\n',
|
||||||
|
conf, problem1=(12, 3))
|
||||||
|
|||||||
@@ -26,6 +26,8 @@ used.
|
|||||||
* ``required`` defines whether using quotes in string values is required
|
* ``required`` defines whether using quotes in string values is required
|
||||||
(``true``, default) or not (``false``), or only allowed when really needed
|
(``true``, default) or not (``false``), or only allowed when really needed
|
||||||
(``only-when-needed``).
|
(``only-when-needed``).
|
||||||
|
* ``needed-extra-regex`` allows strings matching the given PCRE regex to be
|
||||||
|
quoted even when quoting is only allowed when really needed
|
||||||
|
|
||||||
**Note**: Multi-line strings (with ``|`` or ``>``) will not be checked.
|
**Note**: Multi-line strings (with ``|`` or ``>``) will not be checked.
|
||||||
|
|
||||||
@@ -63,9 +65,22 @@ used.
|
|||||||
::
|
::
|
||||||
|
|
||||||
foo: 'bar'
|
foo: 'bar'
|
||||||
|
|
||||||
|
#. With ``quoted-strings: {quote-type: single, required: only-when-needed, needed-extra-regex: ^%.*%$ }``
|
||||||
|
|
||||||
|
the following code snippet would **PASS**:
|
||||||
|
::
|
||||||
|
|
||||||
|
foo: '%bar%'
|
||||||
|
|
||||||
|
the following code snippet would **FAIL**:
|
||||||
|
::
|
||||||
|
|
||||||
|
foo: 'bar'
|
||||||
"""
|
"""
|
||||||
|
|
||||||
import re
|
import re
|
||||||
|
|
||||||
import yaml
|
import yaml
|
||||||
|
|
||||||
from yamllint.linter import LintProblem
|
from yamllint.linter import LintProblem
|
||||||
@@ -137,7 +152,7 @@ def check(conf, token, prev, next, nextnext, context):
|
|||||||
and token.value[0] not in START_TOKENS):
|
and token.value[0] not in START_TOKENS):
|
||||||
extra_regex = conf['needed-extra-regex']
|
extra_regex = conf['needed-extra-regex']
|
||||||
|
|
||||||
if extra_regex == '' or not re.match(extra_regex, token.value):
|
if extra_regex == '' or not re.search(extra_regex, token.value):
|
||||||
msg = "string value is redundantly quoted with %s quotes" % (
|
msg = "string value is redundantly quoted with %s quotes" % (
|
||||||
quote_type)
|
quote_type)
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user