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
|
# vim: ft=python fileencoding=utf-8 sts=4 sw=4 et:
# Copyright 2021 Florian Bruhin (The Compiler) <mail@qutebrowser.org>
#
# 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 <https://www.gnu.org/licenses/>.
import pytest
from qutebrowser.qt.core import QUrl
from qutebrowser.qt.network import QSslError
from qutebrowser.browser.webkit import certificateerror
class FakeError:
def __init__(self, msg):
self.msg = msg
def errorString(self):
return self.msg
@pytest.mark.parametrize('errors, expected', [
(
[QSslError(QSslError.SslError.UnableToGetIssuerCertificate)],
['<p>The issuer certificate could not be found</p>'],
),
(
[
QSslError(QSslError.SslError.UnableToGetIssuerCertificate),
QSslError(QSslError.SslError.UnableToDecryptCertificateSignature),
],
[
'<ul>',
'<li>The issuer certificate could not be found</li>',
'<li>The certificate signature could not be decrypted</li>',
'</ul>',
],
),
(
[FakeError('Escaping test: <>')],
['<p>Escaping test: <></p>'],
),
(
[
FakeError('Escaping test 1: <>'),
FakeError('Escaping test 2: <>'),
],
[
'<ul>',
'<li>Escaping test 1: <></li>',
'<li>Escaping test 2: <></li>',
'</ul>',
],
),
])
def test_html(stubs, errors, expected):
reply = stubs.FakeNetworkReply(url=QUrl("https://example.com"))
wrapper = certificateerror.CertificateErrorWrapper(reply=reply, errors=errors)
lines = [line.strip() for line in wrapper.html().splitlines() if line.strip()]
assert lines == expected
|