From 53e706b1708684bb19be98be0fc7147f02b42dc2 Mon Sep 17 00:00:00 2001 From: Florian Bruhin Date: Thu, 3 Dec 2020 18:47:27 +0100 Subject: Add a test for problem matchers --- tests/unit/scripts/test_problemmatchers.py | 38 ++++++++++++++++++++++++++++++ 1 file changed, 38 insertions(+) create mode 100644 tests/unit/scripts/test_problemmatchers.py diff --git a/tests/unit/scripts/test_problemmatchers.py b/tests/unit/scripts/test_problemmatchers.py new file mode 100644 index 000000000..98bd9c7a5 --- /dev/null +++ b/tests/unit/scripts/test_problemmatchers.py @@ -0,0 +1,38 @@ +# vim: ft=python fileencoding=utf-8 sts=4 sw=4 et: + +# Copyright 2015-2020 Florian Bruhin (The Compiler) + +# This file is part of qutebrowser. +# +# qutebrowser 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. +# +# qutebrowser 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 qutebrowser. If not, see . + +import re + +import pytest + +from scripts.dev.ci import problemmatchers + + +@pytest.mark.parametrize('matcher_name', list(problemmatchers.MATCHERS)) +def test_patterns(matcher_name): + """Make sure all regexps are valid. + + They aren't actually Python syntax, but hopefully close enough to it to compile with + Python's re anyways. + """ + for matcher in problemmatchers.MATCHERS[matcher_name]: + for pattern in matcher['pattern']: + regexp = pattern['regexp'] + print(regexp) + re.compile(regexp) -- cgit v1.2.3-54-g00ecf