summaryrefslogtreecommitdiffstats
path: root/tests/auto/quick/qmltests/data/tst_certificateError.qml
blob: 220ef9ac8320aa24b889a03999861df49be3981e (plain)
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
// Copyright (C) 2020 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only WITH Qt-GPL-exception-1.0

import QtQuick
import QtTest
import QtWebEngine

import Test.Shared as Shared

TestWebEngineView {
    id: view; width: 320; height: 320

    property bool deferError: false
    property bool acceptCertificate: false

    SignalSpy {
        id: spyError
        target: view
        signalName: 'certificateError'
    }

    TestCase {
        id: testCase
        name: 'CertificateError'
        when: windowShown

        function initTestCase() {
            Shared.HttpsServer.setExpectError(true)
            Shared.HttpsServer.newRequest.connect(function (request) {
                request.setResponseBody('<html><body>Test</body></html>')
                request.sendResponse()
            })
            view.settings.errorPageEnabled = false
        }

        function init() {
            verify(Shared.HttpsServer.start())
        }

        function cleanup() {
            Shared.HttpsServer.stop()
            view.deferError = false
            view.acceptCertificate = false
            spyError.clear()
        }

        function test_error_data() {
            return [
                { tag: 'reject',       deferError: false, acceptCertificate: false, expectedContent: '' },
                { tag: 'defer_reject', deferError: true,  acceptCertificate: false, expectedContent: '' },
                { tag: 'defer_accept', deferError: true,  acceptCertificate: true,  expectedContent: 'Test' },
            ]
        }

        function test_error(data) {
            view.deferError = data.deferError
            view.acceptCertificate = data.acceptCertificate
            var handleCertificateError = function(error) {
                if (deferError)
                    error.defer()
                else if (acceptCertificate)
                    error.acceptCertificate()
                else
                    error.rejectCertificate()
            }
            view.certificateError.connect(handleCertificateError)

            const server_url = Shared.HttpsServer.url()
            view.url = server_url

            if (data.deferError) {
                spyError.wait()
                compare(spyError.count, 1)
                compare('', view.getBodyText())

                let error = spyError.signalArguments[0][0]
                if (data.acceptCertificate)
                    error.acceptCertificate()
                else
                    error.rejectCertificate()
            }

            if (data.acceptCertificate)
                verify(view.waitForLoadSucceeded())
            else
                verify(view.waitForLoadFailed())

            compare(spyError.count, 1)
            compare(data.expectedContent, view.getBodyText())

            view.certificateError.disconnect(handleCertificateError)

            let error = spyError.signalArguments[0][0]
            compare(error.url, server_url)
            verify(error.description.length > 0)
            verify(error.overridable)
            compare(error.type, WebEngineCertificateError.CertificateAuthorityInvalid)
        }

        function test_fatalError() {
            let error = undefined
            var handleCertificateError = function(e) { error = e; }
            view.certificateError.connect(handleCertificateError);

            view.url = Qt.resolvedUrl('https://revoked.badssl.com');
            if (!view.waitForLoadResult()) {
                verify(!error, "There shouldn't be any certificate error if not loaded due to missing internet access!");
                skip("Couldn't load page from network, skipping test.");
            }
            view.certificateError.disconnect(handleCertificateError);

            // revoked certificate might not be reported as invalid by chromium and the load will silently succeed
            const failed = view.loadStatus == WebEngineView.LoadFailedStatus, hasError = Boolean(error)
            compare(hasError, failed)
            if (failed) {
                verify(!error.overridable);
                // Fatal certificate errors are implicitly rejected. But second call should not cause crash.
                error.rejectCertificate();
            }
        }
    }
}