summaryrefslogtreecommitdiffstats
path: root/gitlint/tests/config/test_config_precedence.py
diff options
context:
space:
mode:
Diffstat (limited to 'gitlint/tests/config/test_config_precedence.py')
-rw-r--r--gitlint/tests/config/test_config_precedence.py100
1 files changed, 0 insertions, 100 deletions
diff --git a/gitlint/tests/config/test_config_precedence.py b/gitlint/tests/config/test_config_precedence.py
deleted file mode 100644
index 9689e55..0000000
--- a/gitlint/tests/config/test_config_precedence.py
+++ /dev/null
@@ -1,100 +0,0 @@
-# -*- coding: utf-8 -*-
-
-try:
- # python 2.x
- from StringIO import StringIO
-except ImportError:
- # python 3.x
- from io import StringIO
-
-from click.testing import CliRunner
-
-try:
- # python 2.x
- from mock import patch
-except ImportError:
- # python 3.x
- from unittest.mock import patch # pylint: disable=no-name-in-module, import-error
-
-from gitlint.tests.base import BaseTestCase
-from gitlint import cli
-from gitlint.config import LintConfigBuilder
-
-
-class LintConfigPrecedenceTests(BaseTestCase):
- def setUp(self):
- self.cli = CliRunner()
-
- @patch('gitlint.cli.get_stdin_data', return_value=u"WIP\n\nThis is å test message\n")
- def test_config_precedence(self, _):
- # TODO(jroovers): this test really only test verbosity, we need to do some refactoring to gitlint.cli
- # to more easily test everything
- # Test that the config precedence is followed:
- # 1. commandline convenience flags
- # 2. commandline -c flags
- # 3. config file
- # 4. default config
- config_path = self.get_sample_path("config/gitlintconfig")
-
- # 1. commandline convenience flags
- with patch('gitlint.display.stderr', new=StringIO()) as stderr:
- result = self.cli.invoke(cli.cli, ["-vvv", "-c", "general.verbosity=2", "--config", config_path])
- self.assertEqual(result.output, "")
- self.assertEqual(stderr.getvalue(), "1: T5 Title contains the word 'WIP' (case-insensitive): \"WIP\"\n")
-
- # 2. commandline -c flags
- with patch('gitlint.display.stderr', new=StringIO()) as stderr:
- result = self.cli.invoke(cli.cli, ["-c", "general.verbosity=2", "--config", config_path])
- self.assertEqual(result.output, "")
- self.assertEqual(stderr.getvalue(), "1: T5 Title contains the word 'WIP' (case-insensitive)\n")
-
- # 3. config file
- with patch('gitlint.display.stderr', new=StringIO()) as stderr:
- result = self.cli.invoke(cli.cli, ["--config", config_path])
- self.assertEqual(result.output, "")
- self.assertEqual(stderr.getvalue(), "1: T5\n")
-
- # 4. default config
- with patch('gitlint.display.stderr', new=StringIO()) as stderr:
- result = self.cli.invoke(cli.cli)
- self.assertEqual(result.output, "")
- self.assertEqual(stderr.getvalue(), "1: T5 Title contains the word 'WIP' (case-insensitive): \"WIP\"\n")
-
- @patch('gitlint.cli.get_stdin_data', return_value=u"WIP: This is å test")
- def test_ignore_precedence(self, get_stdin_data):
- with patch('gitlint.display.stderr', new=StringIO()) as stderr:
- # --ignore takes precedence over -c general.ignore
- result = self.cli.invoke(cli.cli, ["-c", "general.ignore=T5", "--ignore", "B6"])
- self.assertEqual(result.output, "")
- self.assertEqual(result.exit_code, 1)
- # We still expect the T5 violation, but no B6 violation as --ignore overwrites -c general.ignore
- self.assertEqual(stderr.getvalue(),
- u"1: T5 Title contains the word 'WIP' (case-insensitive): \"WIP: This is å test\"\n")
-
- # test that we can also still configure a rule that is first ignored but then not
- with patch('gitlint.display.stderr', new=StringIO()) as stderr:
- get_stdin_data.return_value = u"This is å test"
- # --ignore takes precedence over -c general.ignore
- result = self.cli.invoke(cli.cli, ["-c", "general.ignore=title-max-length",
- "-c", "title-max-length.line-length=5",
- "--ignore", "B6"])
- self.assertEqual(result.output, "")
- self.assertEqual(result.exit_code, 1)
-
- # We still expect the T1 violation with custom config,
- # but no B6 violation as --ignore overwrites -c general.ignore
- self.assertEqual(stderr.getvalue(), u"1: T1 Title exceeds max length (14>5): \"This is å test\"\n")
-
- def test_general_option_after_rule_option(self):
- # We used to have a bug where we didn't process general options before setting specific options, this would
- # lead to errors when e.g.: trying to configure a user rule before the rule class was loaded by extra-path
- # This test is here to test for regressions against this.
-
- config_builder = LintConfigBuilder()
- config_builder.set_option(u'my-üser-commit-rule', 'violation-count', 3)
- user_rules_path = self.get_sample_path("user_rules")
- config_builder.set_option('general', 'extra-path', user_rules_path)
- config = config_builder.build()
-
- self.assertEqual(config.extra_path, user_rules_path)
- self.assertEqual(config.get_rule_option(u'my-üser-commit-rule', 'violation-count'), 3)