# Copyright 2015-2016 Florian Bruhin (The Compiler) # vim: ft=python fileencoding=utf-8 sts=4 sw=4 et: # 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 . """Tests for qutebrowser.utils.error.""" import sys import logging import pytest from qutebrowser.utils import error from qutebrowser.misc import ipc from PyQt5.QtCore import QTimer from PyQt5.QtWidgets import QMessageBox class Error(Exception): pass @pytest.mark.parametrize('exc, name, exc_text', [ # "builtins." stripped (ValueError('exception'), 'ValueError', 'exception'), (ValueError, 'ValueError', 'none'), # "qutebrowser." stripped (ipc.Error, 'misc.ipc.Error', 'none'), (Error, 'test_error.Error', 'none'), ]) def test_no_err_windows(caplog, exc, name, exc_text, fake_args): """Test handle_fatal_exc with no_err_windows = True.""" fake_args.no_err_windows = True try: raise exc except Exception as e: with caplog.at_level(logging.ERROR): error.handle_fatal_exc(e, fake_args, 'title', pre_text='pre', post_text='post') assert len(caplog.records) == 1 expected = [ 'Handling fatal {} with --no-err-windows!'.format(name), '', 'title: title', 'pre_text: pre', 'post_text: post', 'exception text: {}'.format(exc_text), ] assert caplog.records[0].msg == '\n'.join(expected) # This happens on Xvfb for some reason # See https://github.com/The-Compiler/qutebrowser/issues/984 @pytest.mark.qt_log_ignore(r'^QXcbConnection: XCB error: 8 \(BadMatch\), ' r'sequence: \d+, resource id: \d+, major code: 42 ' r'\(SetInputFocus\), minor code: 0$', r'^QIODevice::write: device not open') @pytest.mark.parametrize('pre_text, post_text, expected', [ ('', '', 'exception'), ('foo', '', 'foo: exception'), ('foo', 'bar', 'foo: exception\n\nbar'), ('', 'bar', 'exception\n\nbar'), ], ids=repr) def test_err_windows(qtbot, qapp, fake_args, pre_text, post_text, expected): def err_window_check(): w = qapp.activeModalWidget() try: qtbot.add_widget(w) if sys.platform != 'darwin': assert w.windowTitle() == 'title' assert w.icon() == QMessageBox.Critical assert w.standardButtons() == QMessageBox.Ok assert w.text() == expected finally: w.close() fake_args.no_err_windows = False QTimer.singleShot(0, err_window_check) error.handle_fatal_exc(ValueError("exception"), fake_args, 'title', pre_text=pre_text, post_text=post_text)