1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122
|
# SPDX-FileCopyrightText: Florian Bruhin (The Compiler) <mail@qutebrowser.org>
#
# SPDX-License-Identifier: GPL-3.0-or-later
"""Tests for qutebrowser.qutebrowser.
(Mainly commandline flag parsing)
"""
import re
import pytest
from qutebrowser import qutebrowser
@pytest.fixture
def parser():
return qutebrowser.get_argparser()
class TestDebugFlag:
def test_valid(self, parser):
args = parser.parse_args(['--debug-flag', 'chromium',
'--debug-flag', 'stack'])
assert args.debug_flags == ['chromium', 'stack']
def test_invalid(self, parser, capsys):
with pytest.raises(SystemExit):
parser.parse_args(['--debug-flag', 'invalid'])
_out, err = capsys.readouterr()
assert 'Invalid debug flag - valid flags:' in err
class TestLogFilter:
def test_valid(self, parser):
args = parser.parse_args(['--logfilter', 'misc'])
assert args.logfilter == 'misc'
def test_invalid(self, parser, capsys):
with pytest.raises(SystemExit):
parser.parse_args(['--logfilter', 'invalid'])
_out, err = capsys.readouterr()
print(err)
assert 'Invalid log category invalid - valid categories' in err
class TestJsonArgs:
def test_partial(self, parser):
"""Make sure we can provide a subset of all arguments.
This ensures that it's possible to restart into an older version of qutebrowser
when a new argument was added.
"""
args = parser.parse_args(['--json-args', '{"debug": true}'])
args = qutebrowser._unpack_json_args(args)
# pylint: disable=no-member
assert args.debug
assert not args.temp_basedir
class TestValidateUntrustedArgs:
@pytest.mark.parametrize('args', [
[],
[':nop'],
[':nop', '--untrusted-args'],
[':nop', '--debug', '--untrusted-args'],
[':nop', '--untrusted-args', 'foo'],
['--debug', '--untrusted-args', 'foo'],
['foo', '--untrusted-args', 'bar'],
])
def test_valid(self, args):
qutebrowser._validate_untrusted_args(args)
@pytest.mark.parametrize('args, message', [
(
['--untrusted-args', '--debug'],
"Found --debug after --untrusted-args, aborting.",
),
(
['--untrusted-args', ':nop'],
"Found :nop after --untrusted-args, aborting.",
),
(
['--debug', '--untrusted-args', '--debug'],
"Found --debug after --untrusted-args, aborting.",
),
(
[':nop', '--untrusted-args', '--debug'],
"Found --debug after --untrusted-args, aborting.",
),
(
[':nop', '--untrusted-args', ':nop'],
"Found :nop after --untrusted-args, aborting.",
),
(
[
':nop',
'--untrusted-args',
':nop',
'--untrusted-args',
'https://www.example.org',
],
(
"Found multiple arguments (:nop --untrusted-args "
"https://www.example.org) after --untrusted-args, aborting."
)
),
(
['--untrusted-args', 'okay1', 'okay2'],
"Found multiple arguments (okay1 okay2) after --untrusted-args, aborting.",
),
])
def test_invalid(self, args, message):
with pytest.raises(SystemExit, match=re.escape(message)):
qutebrowser._validate_untrusted_args(args)
|