summaryrefslogtreecommitdiffstats
path: root/tests/rules/test_braces.py
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-05-04 00:38:50 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-05-04 00:38:50 +0000
commit09e7b47bad7e7310a6f52bdc20e9a9f251e79769 (patch)
treec93d189c1318902b8f1e5333d7ee34a1e9db9a34 /tests/rules/test_braces.py
parentInitial commit. (diff)
downloadyamllint-09e7b47bad7e7310a6f52bdc20e9a9f251e79769.tar.xz
yamllint-09e7b47bad7e7310a6f52bdc20e9a9f251e79769.zip
Adding upstream version 1.33.0.upstream/1.33.0
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'tests/rules/test_braces.py')
-rw-r--r--tests/rules/test_braces.py340
1 files changed, 340 insertions, 0 deletions
diff --git a/tests/rules/test_braces.py b/tests/rules/test_braces.py
new file mode 100644
index 0000000..03636a9
--- /dev/null
+++ b/tests/rules/test_braces.py
@@ -0,0 +1,340 @@
+# Copyright (C) 2016 Adrien Vergé
+#
+# This program 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.
+#
+# This program 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 this program. If not, see <http://www.gnu.org/licenses/>.
+
+from tests.common import RuleTestCase
+
+
+class ColonTestCase(RuleTestCase):
+ rule_id = 'braces'
+
+ def test_disabled(self):
+ conf = 'braces: disable'
+ self.check('---\n'
+ 'dict1: {}\n'
+ 'dict2: { }\n'
+ 'dict3: { a: 1, b}\n'
+ 'dict4: {a: 1, b, c: 3 }\n'
+ 'dict5: {a: 1, b, c: 3 }\n'
+ 'dict6: { a: 1, b, c: 3 }\n'
+ 'dict7: { a: 1, b, c: 3 }\n', conf)
+
+ def test_forbid(self):
+ conf = ('braces:\n'
+ ' forbid: false\n')
+ self.check('---\n'
+ 'dict: {}\n', conf)
+ self.check('---\n'
+ 'dict: {a}\n', conf)
+ self.check('---\n'
+ 'dict: {a: 1}\n', conf)
+ self.check('---\n'
+ 'dict: {\n'
+ ' a: 1\n'
+ '}\n', conf)
+
+ conf = ('braces:\n'
+ ' forbid: true\n')
+ self.check('---\n'
+ 'dict:\n'
+ ' a: 1\n', conf)
+ self.check('---\n'
+ 'dict: {}\n', conf, problem=(2, 8))
+ self.check('---\n'
+ 'dict: {a}\n', conf, problem=(2, 8))
+ self.check('---\n'
+ 'dict: {a: 1}\n', conf, problem=(2, 8))
+ self.check('---\n'
+ 'dict: {\n'
+ ' a: 1\n'
+ '}\n', conf, problem=(2, 8))
+
+ conf = ('braces:\n'
+ ' forbid: non-empty\n')
+ self.check('---\n'
+ 'dict:\n'
+ ' a: 1\n', conf)
+ self.check('---\n'
+ 'dict: {}\n', conf)
+ self.check('---\n'
+ 'dict: {\n'
+ '}\n', conf)
+ self.check('---\n'
+ 'dict: {\n'
+ '# commented: value\n'
+ '# another: value2\n'
+ '}\n', conf)
+ self.check('---\n'
+ 'dict: {a}\n', conf, problem=(2, 8))
+ self.check('---\n'
+ 'dict: {a: 1}\n', conf, problem=(2, 8))
+ self.check('---\n'
+ 'dict: {\n'
+ ' a: 1\n'
+ '}\n', conf, problem=(2, 8))
+
+ def test_min_spaces(self):
+ conf = ('braces:\n'
+ ' max-spaces-inside: -1\n'
+ ' min-spaces-inside: 0\n'
+ ' max-spaces-inside-empty: -1\n'
+ ' min-spaces-inside-empty: -1\n')
+ self.check('---\n'
+ 'dict: {}\n', conf)
+
+ conf = ('braces:\n'
+ ' max-spaces-inside: -1\n'
+ ' min-spaces-inside: 1\n'
+ ' max-spaces-inside-empty: -1\n'
+ ' min-spaces-inside-empty: -1\n')
+ self.check('---\n'
+ 'dict: {}\n', conf, problem=(2, 8))
+ self.check('---\n'
+ 'dict: { }\n', conf)
+ self.check('---\n'
+ 'dict: {a: 1, b}\n', conf,
+ problem1=(2, 8), problem2=(2, 15))
+ self.check('---\n'
+ 'dict: { a: 1, b }\n', conf)
+ self.check('---\n'
+ 'dict: {\n'
+ ' a: 1,\n'
+ ' b\n'
+ '}\n', conf)
+
+ conf = ('braces:\n'
+ ' max-spaces-inside: -1\n'
+ ' min-spaces-inside: 3\n'
+ ' max-spaces-inside-empty: -1\n'
+ ' min-spaces-inside-empty: -1\n')
+ self.check('---\n'
+ 'dict: { a: 1, b }\n', conf,
+ problem1=(2, 9), problem2=(2, 17))
+ self.check('---\n'
+ 'dict: { a: 1, b }\n', conf)
+
+ def test_max_spaces(self):
+ conf = ('braces:\n'
+ ' max-spaces-inside: 0\n'
+ ' min-spaces-inside: -1\n'
+ ' max-spaces-inside-empty: -1\n'
+ ' min-spaces-inside-empty: -1\n')
+ self.check('---\n'
+ 'dict: {}\n', conf)
+ self.check('---\n'
+ 'dict: { }\n', conf, problem=(2, 8))
+ self.check('---\n'
+ 'dict: {a: 1, b}\n', conf)
+ self.check('---\n'
+ 'dict: { a: 1, b }\n', conf,
+ problem1=(2, 8), problem2=(2, 16))
+ self.check('---\n'
+ 'dict: { a: 1, b }\n', conf,
+ problem1=(2, 10), problem2=(2, 20))
+ self.check('---\n'
+ 'dict: {\n'
+ ' a: 1,\n'
+ ' b\n'
+ '}\n', conf)
+
+ conf = ('braces:\n'
+ ' max-spaces-inside: 3\n'
+ ' min-spaces-inside: -1\n'
+ ' max-spaces-inside-empty: -1\n'
+ ' min-spaces-inside-empty: -1\n')
+ self.check('---\n'
+ 'dict: { a: 1, b }\n', conf)
+ self.check('---\n'
+ 'dict: { a: 1, b }\n', conf,
+ problem1=(2, 11), problem2=(2, 23))
+
+ def test_min_and_max_spaces(self):
+ conf = ('braces:\n'
+ ' max-spaces-inside: 0\n'
+ ' min-spaces-inside: 0\n'
+ ' max-spaces-inside-empty: -1\n'
+ ' min-spaces-inside-empty: -1\n')
+ self.check('---\n'
+ 'dict: {}\n', conf)
+ self.check('---\n'
+ 'dict: { }\n', conf, problem=(2, 8))
+ self.check('---\n'
+ 'dict: { a: 1, b}\n', conf, problem=(2, 10))
+
+ conf = ('braces:\n'
+ ' max-spaces-inside: 1\n'
+ ' min-spaces-inside: 1\n'
+ ' max-spaces-inside-empty: -1\n'
+ ' min-spaces-inside-empty: -1\n')
+ self.check('---\n'
+ 'dict: {a: 1, b, c: 3 }\n', conf, problem=(2, 8))
+
+ conf = ('braces:\n'
+ ' max-spaces-inside: 2\n'
+ ' min-spaces-inside: 0\n'
+ ' max-spaces-inside-empty: -1\n'
+ ' min-spaces-inside-empty: -1\n')
+ self.check('---\n'
+ 'dict: {a: 1, b, c: 3 }\n', conf)
+ self.check('---\n'
+ 'dict: { a: 1, b, c: 3 }\n', conf)
+ self.check('---\n'
+ 'dict: { a: 1, b, c: 3 }\n', conf, problem=(2, 10))
+
+ def test_min_spaces_empty(self):
+ conf = ('braces:\n'
+ ' max-spaces-inside: -1\n'
+ ' min-spaces-inside: -1\n'
+ ' max-spaces-inside-empty: 0\n'
+ ' min-spaces-inside-empty: 0\n')
+ self.check('---\n'
+ 'array: {}\n', conf)
+
+ conf = ('braces:\n'
+ ' max-spaces-inside: -1\n'
+ ' min-spaces-inside: -1\n'
+ ' max-spaces-inside-empty: -1\n'
+ ' min-spaces-inside-empty: 1\n')
+ self.check('---\n'
+ 'array: {}\n', conf, problem=(2, 9))
+ self.check('---\n'
+ 'array: { }\n', conf)
+
+ conf = ('braces:\n'
+ ' max-spaces-inside: -1\n'
+ ' min-spaces-inside: -1\n'
+ ' max-spaces-inside-empty: -1\n'
+ ' min-spaces-inside-empty: 3\n')
+ self.check('---\n'
+ 'array: {}\n', conf, problem=(2, 9))
+ self.check('---\n'
+ 'array: { }\n', conf)
+
+ def test_max_spaces_empty(self):
+ conf = ('braces:\n'
+ ' max-spaces-inside: -1\n'
+ ' min-spaces-inside: -1\n'
+ ' max-spaces-inside-empty: 0\n'
+ ' min-spaces-inside-empty: -1\n')
+ self.check('---\n'
+ 'array: {}\n', conf)
+ self.check('---\n'
+ 'array: { }\n', conf, problem=(2, 9))
+
+ conf = ('braces:\n'
+ ' max-spaces-inside: -1\n'
+ ' min-spaces-inside: -1\n'
+ ' max-spaces-inside-empty: 1\n'
+ ' min-spaces-inside-empty: -1\n')
+ self.check('---\n'
+ 'array: {}\n', conf)
+ self.check('---\n'
+ 'array: { }\n', conf)
+ self.check('---\n'
+ 'array: { }\n', conf, problem=(2, 10))
+
+ conf = ('braces:\n'
+ ' max-spaces-inside: -1\n'
+ ' min-spaces-inside: -1\n'
+ ' max-spaces-inside-empty: 3\n'
+ ' min-spaces-inside-empty: -1\n')
+ self.check('---\n'
+ 'array: {}\n', conf)
+ self.check('---\n'
+ 'array: { }\n', conf)
+ self.check('---\n'
+ 'array: { }\n', conf, problem=(2, 12))
+
+ def test_min_and_max_spaces_empty(self):
+ conf = ('braces:\n'
+ ' max-spaces-inside: -1\n'
+ ' min-spaces-inside: -1\n'
+ ' max-spaces-inside-empty: 2\n'
+ ' min-spaces-inside-empty: 1\n')
+ self.check('---\n'
+ 'array: {}\n', conf, problem=(2, 9))
+ self.check('---\n'
+ 'array: { }\n', conf)
+ self.check('---\n'
+ 'array: { }\n', conf)
+ self.check('---\n'
+ 'array: { }\n', conf, problem=(2, 11))
+
+ def test_mixed_empty_nonempty(self):
+ conf = ('braces:\n'
+ ' max-spaces-inside: -1\n'
+ ' min-spaces-inside: 1\n'
+ ' max-spaces-inside-empty: 0\n'
+ ' min-spaces-inside-empty: 0\n')
+ self.check('---\n'
+ 'array: { a: 1, b }\n', conf)
+ self.check('---\n'
+ 'array: {a: 1, b}\n', conf,
+ problem1=(2, 9), problem2=(2, 16))
+ self.check('---\n'
+ 'array: {}\n', conf)
+ self.check('---\n'
+ 'array: { }\n', conf,
+ problem1=(2, 9))
+
+ conf = ('braces:\n'
+ ' max-spaces-inside: 0\n'
+ ' min-spaces-inside: -1\n'
+ ' max-spaces-inside-empty: 1\n'
+ ' min-spaces-inside-empty: 1\n')
+ self.check('---\n'
+ 'array: { a: 1, b }\n', conf,
+ problem1=(2, 9), problem2=(2, 17))
+ self.check('---\n'
+ 'array: {a: 1, b}\n', conf)
+ self.check('---\n'
+ 'array: {}\n', conf,
+ problem1=(2, 9))
+ self.check('---\n'
+ 'array: { }\n', conf)
+
+ conf = ('braces:\n'
+ ' max-spaces-inside: 2\n'
+ ' min-spaces-inside: 1\n'
+ ' max-spaces-inside-empty: 1\n'
+ ' min-spaces-inside-empty: 1\n')
+ self.check('---\n'
+ 'array: { a: 1, b }\n', conf)
+ self.check('---\n'
+ 'array: {a: 1, b }\n', conf,
+ problem1=(2, 9), problem2=(2, 18))
+ self.check('---\n'
+ 'array: {}\n', conf,
+ problem1=(2, 9))
+ self.check('---\n'
+ 'array: { }\n', conf)
+ self.check('---\n'
+ 'array: { }\n', conf,
+ problem1=(2, 11))
+
+ conf = ('braces:\n'
+ ' max-spaces-inside: 1\n'
+ ' min-spaces-inside: 1\n'
+ ' max-spaces-inside-empty: 1\n'
+ ' min-spaces-inside-empty: 1\n')
+ self.check('---\n'
+ 'array: { a: 1, b }\n', conf)
+ self.check('---\n'
+ 'array: {a: 1, b}\n', conf,
+ problem1=(2, 9), problem2=(2, 16))
+ self.check('---\n'
+ 'array: {}\n', conf,
+ problem1=(2, 9))
+ self.check('---\n'
+ 'array: { }\n', conf)