2014-06-23 19:44:21 +02:00
|
|
|
# vim: ft=python fileencoding=utf-8 sts=4 sw=4 et:
|
|
|
|
|
2016-01-04 07:12:39 +01:00
|
|
|
# Copyright 2014-2016 Florian Bruhin (The Compiler) <mail@qutebrowser.org>
|
2014-06-23 19:44:21 +02:00
|
|
|
#
|
|
|
|
# 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 <http://www.gnu.org/licenses/>.
|
|
|
|
|
|
|
|
# pylint: disable=invalid-name
|
|
|
|
|
|
|
|
"""Fake objects/stubs."""
|
2015-04-05 20:30:31 +02:00
|
|
|
|
2016-06-16 05:41:14 +02:00
|
|
|
import collections
|
2014-08-26 19:10:14 +02:00
|
|
|
from unittest import mock
|
2014-06-23 19:44:21 +02:00
|
|
|
|
2015-03-01 21:29:27 +01:00
|
|
|
from PyQt5.QtCore import pyqtSignal, QPoint, QProcess, QObject
|
2015-08-30 23:11:23 +02:00
|
|
|
from PyQt5.QtNetwork import (QNetworkRequest, QAbstractNetworkCache,
|
|
|
|
QNetworkCacheMetaData)
|
2016-07-04 05:06:36 +02:00
|
|
|
from PyQt5.QtWidgets import QCommonStyle, QWidget, QLineEdit
|
2014-06-23 19:44:21 +02:00
|
|
|
|
2016-06-30 13:17:24 +02:00
|
|
|
from qutebrowser.browser.webkit import webview, history
|
2015-07-20 11:23:34 +02:00
|
|
|
from qutebrowser.config import configexc
|
2016-06-17 05:12:21 +02:00
|
|
|
from qutebrowser.mainwindow import mainwindow
|
2015-07-20 11:23:34 +02:00
|
|
|
|
2014-06-23 19:44:21 +02:00
|
|
|
|
2015-08-30 23:11:23 +02:00
|
|
|
class FakeNetworkCache(QAbstractNetworkCache):
|
|
|
|
|
2015-08-31 08:00:21 +02:00
|
|
|
"""Fake cache with no data."""
|
|
|
|
|
2015-08-30 23:11:23 +02:00
|
|
|
def cacheSize(self):
|
|
|
|
return 0
|
|
|
|
|
|
|
|
def data(self, _url):
|
|
|
|
return None
|
|
|
|
|
|
|
|
def insert(self, _dev):
|
|
|
|
pass
|
|
|
|
|
|
|
|
def metaData(self, _url):
|
|
|
|
return QNetworkCacheMetaData()
|
|
|
|
|
|
|
|
def prepare(self, _metadata):
|
|
|
|
return None
|
|
|
|
|
|
|
|
def remove(self, _url):
|
|
|
|
return False
|
|
|
|
|
|
|
|
def updateMetaData(self, _url):
|
|
|
|
pass
|
|
|
|
|
|
|
|
|
2014-06-23 19:44:21 +02:00
|
|
|
class FakeKeyEvent:
|
|
|
|
|
|
|
|
"""Fake QKeyPressEvent stub."""
|
|
|
|
|
|
|
|
def __init__(self, key, modifiers=0, text=''):
|
2014-08-26 19:10:14 +02:00
|
|
|
self.key = mock.Mock(return_value=key)
|
|
|
|
self.text = mock.Mock(return_value=text)
|
|
|
|
self.modifiers = mock.Mock(return_value=modifiers)
|
2014-06-23 19:44:21 +02:00
|
|
|
|
|
|
|
|
|
|
|
class FakeWebFrame:
|
|
|
|
|
2015-08-10 19:37:16 +02:00
|
|
|
"""A stub for QWebFrame.
|
|
|
|
|
|
|
|
Attributes:
|
|
|
|
focus_elem: The 'focused' element.
|
|
|
|
"""
|
2014-06-23 19:44:21 +02:00
|
|
|
|
2015-12-21 08:26:02 +01:00
|
|
|
def __init__(self, geometry=None, *, scroll=None, plaintext=None,
|
2016-06-06 11:56:15 +02:00
|
|
|
html=None, parent=None, zoom=1.0):
|
2014-06-23 19:44:21 +02:00
|
|
|
"""Constructor.
|
|
|
|
|
|
|
|
Args:
|
|
|
|
geometry: The geometry of the frame as QRect.
|
|
|
|
scroll: The scroll position as QPoint.
|
2015-12-21 08:26:02 +01:00
|
|
|
plaintext: Return value of toPlainText
|
|
|
|
html: Return value of tohtml.
|
2016-06-06 11:56:15 +02:00
|
|
|
zoom: The zoom factor.
|
2014-06-23 19:44:21 +02:00
|
|
|
parent: The parent frame.
|
|
|
|
"""
|
|
|
|
if scroll is None:
|
|
|
|
scroll = QPoint(0, 0)
|
2014-08-26 19:10:14 +02:00
|
|
|
self.geometry = mock.Mock(return_value=geometry)
|
|
|
|
self.scrollPosition = mock.Mock(return_value=scroll)
|
|
|
|
self.parentFrame = mock.Mock(return_value=parent)
|
2015-08-10 19:37:16 +02:00
|
|
|
self.focus_elem = None
|
2015-12-21 08:26:02 +01:00
|
|
|
self.toPlainText = mock.Mock(return_value=plaintext)
|
|
|
|
self.toHtml = mock.Mock(return_value=html)
|
2016-06-06 11:56:15 +02:00
|
|
|
self.zoomFactor = mock.Mock(return_value=zoom)
|
2015-08-10 19:37:16 +02:00
|
|
|
|
|
|
|
def findFirstElement(self, selector):
|
|
|
|
if selector == '*:focus':
|
|
|
|
if self.focus_elem is not None:
|
|
|
|
return self.focus_elem
|
|
|
|
else:
|
|
|
|
raise Exception("Trying to get focus element but it's unset!")
|
|
|
|
else:
|
|
|
|
raise Exception("Unknown selector {!r}!".format(selector))
|
2014-06-23 19:44:21 +02:00
|
|
|
|
|
|
|
|
|
|
|
class FakeChildrenFrame:
|
|
|
|
|
|
|
|
"""A stub for QWebFrame to test get_child_frames."""
|
|
|
|
|
|
|
|
def __init__(self, children=None):
|
|
|
|
if children is None:
|
|
|
|
children = []
|
2014-08-26 19:10:14 +02:00
|
|
|
self.childFrames = mock.Mock(return_value=children)
|
2014-06-23 19:44:21 +02:00
|
|
|
|
|
|
|
|
|
|
|
class FakeQApplication:
|
|
|
|
|
|
|
|
"""Stub to insert as QApplication module."""
|
|
|
|
|
2015-08-23 21:55:25 +02:00
|
|
|
def __init__(self, style=None, all_widgets=None, active_window=None):
|
2014-08-26 19:10:14 +02:00
|
|
|
self.instance = mock.Mock(return_value=self)
|
2015-08-11 18:08:11 +02:00
|
|
|
|
2015-06-26 22:37:00 +02:00
|
|
|
self.style = mock.Mock(spec=QCommonStyle)
|
|
|
|
self.style().metaObject().className.return_value = style
|
2014-06-23 19:44:21 +02:00
|
|
|
|
2015-08-11 18:08:11 +02:00
|
|
|
self.allWidgets = lambda: all_widgets
|
2015-08-23 21:55:25 +02:00
|
|
|
self.activeWindow = lambda: active_window
|
2015-08-11 18:08:11 +02:00
|
|
|
|
2014-06-23 19:44:21 +02:00
|
|
|
|
|
|
|
class FakeUrl:
|
|
|
|
|
2016-06-10 20:45:36 +02:00
|
|
|
"""QUrl stub which provides .path(), isValid() and host()."""
|
2014-06-23 19:44:21 +02:00
|
|
|
|
2016-06-10 20:45:36 +02:00
|
|
|
def __init__(self, path=None, valid=True, host=None):
|
2014-08-26 19:10:14 +02:00
|
|
|
self.path = mock.Mock(return_value=path)
|
2016-06-10 20:45:36 +02:00
|
|
|
self.isValid = mock.Mock(returl_value=valid)
|
|
|
|
self.host = mock.Mock(returl_value=host)
|
2014-06-23 19:44:21 +02:00
|
|
|
|
|
|
|
|
|
|
|
class FakeNetworkReply:
|
|
|
|
|
|
|
|
"""QNetworkReply stub which provides a Content-Disposition header."""
|
|
|
|
|
2014-08-12 09:03:38 +02:00
|
|
|
KNOWN_HEADERS = {
|
|
|
|
QNetworkRequest.ContentTypeHeader: 'Content-Type',
|
|
|
|
}
|
|
|
|
|
|
|
|
def __init__(self, headers=None, url=None):
|
2014-06-23 19:44:21 +02:00
|
|
|
if url is None:
|
|
|
|
url = FakeUrl()
|
2014-08-12 09:03:38 +02:00
|
|
|
if headers is None:
|
|
|
|
self.headers = {}
|
|
|
|
else:
|
|
|
|
self.headers = headers
|
2014-08-26 19:10:14 +02:00
|
|
|
self.url = mock.Mock(return_value=url)
|
2014-06-23 19:44:21 +02:00
|
|
|
|
|
|
|
def hasRawHeader(self, name):
|
|
|
|
"""Check if the reply has a certain header.
|
|
|
|
|
|
|
|
Args:
|
2015-02-05 07:12:36 +01:00
|
|
|
name: The name of the header as ISO-8859-1 encoded bytes object.
|
2014-06-23 19:44:21 +02:00
|
|
|
|
|
|
|
Return:
|
|
|
|
True if the header is present, False if not.
|
|
|
|
"""
|
2015-02-05 07:12:36 +01:00
|
|
|
return name.decode('iso-8859-1') in self.headers
|
2014-06-23 19:44:21 +02:00
|
|
|
|
|
|
|
def rawHeader(self, name):
|
|
|
|
"""Get the raw header data of a header.
|
|
|
|
|
|
|
|
Args:
|
2015-02-05 07:12:36 +01:00
|
|
|
name: The name of the header as ISO-8859-1 encoded bytes object.
|
2014-06-23 19:44:21 +02:00
|
|
|
|
|
|
|
Return:
|
|
|
|
The header data, as ISO-8859-1 encoded bytes() object.
|
2014-08-12 09:03:38 +02:00
|
|
|
"""
|
2015-02-05 07:12:36 +01:00
|
|
|
name = name.decode('iso-8859-1')
|
2014-08-12 09:03:38 +02:00
|
|
|
return self.headers[name].encode('iso-8859-1')
|
2014-06-23 19:44:21 +02:00
|
|
|
|
2014-08-12 09:03:38 +02:00
|
|
|
def header(self, known_header):
|
|
|
|
"""Get a known header.
|
|
|
|
|
|
|
|
Args:
|
|
|
|
known_header: A QNetworkRequest::KnownHeaders member.
|
|
|
|
"""
|
|
|
|
key = self.KNOWN_HEADERS[known_header]
|
|
|
|
try:
|
|
|
|
return self.headers[key]
|
|
|
|
except KeyError:
|
|
|
|
return None
|
|
|
|
|
|
|
|
def setHeader(self, known_header, value):
|
|
|
|
"""Set a known header.
|
|
|
|
|
|
|
|
Args:
|
|
|
|
known_header: A QNetworkRequest::KnownHeaders member.
|
|
|
|
value: The value to set.
|
2014-06-23 19:44:21 +02:00
|
|
|
"""
|
2014-08-12 09:03:38 +02:00
|
|
|
key = self.KNOWN_HEADERS[known_header]
|
|
|
|
self.headers[key] = value
|
2014-06-23 19:44:21 +02:00
|
|
|
|
|
|
|
|
2015-06-11 23:02:18 +02:00
|
|
|
def fake_qprocess():
|
|
|
|
"""Factory for a QProcess mock which has the QProcess enum values."""
|
|
|
|
m = mock.Mock(spec=QProcess)
|
|
|
|
for attr in ['NormalExit', 'CrashExit', 'FailedToStart', 'Crashed',
|
|
|
|
'Timedout', 'WriteError', 'ReadError', 'UnknownError']:
|
|
|
|
setattr(m, attr, getattr(QProcess, attr))
|
|
|
|
return m
|
2014-06-23 19:44:21 +02:00
|
|
|
|
|
|
|
|
2015-10-23 14:01:22 +02:00
|
|
|
class FakeWebView(QWidget):
|
|
|
|
|
|
|
|
"""Fake WebView which can be added to a tab."""
|
|
|
|
|
2016-06-17 05:12:21 +02:00
|
|
|
url_text_changed = pyqtSignal(str)
|
|
|
|
shutting_down = pyqtSignal()
|
|
|
|
|
|
|
|
def __init__(self, url=FakeUrl(), title='', tab_id=0):
|
2015-10-23 14:01:22 +02:00
|
|
|
super().__init__()
|
|
|
|
self.progress = 0
|
|
|
|
self.scroll_pos = (-1, -1)
|
|
|
|
self.load_status = webview.LoadStatus.none
|
2016-06-17 05:12:21 +02:00
|
|
|
self.tab_id = tab_id
|
|
|
|
self.cur_url = url
|
|
|
|
self.title = title
|
|
|
|
|
|
|
|
def url(self):
|
|
|
|
return self.cur_url
|
2015-10-23 14:01:22 +02:00
|
|
|
|
|
|
|
|
2014-06-23 19:44:21 +02:00
|
|
|
class FakeSignal:
|
|
|
|
|
2015-09-02 20:40:19 +02:00
|
|
|
"""Fake pyqtSignal stub which does nothing.
|
2014-06-23 19:44:21 +02:00
|
|
|
|
2015-09-02 20:40:19 +02:00
|
|
|
Attributes:
|
|
|
|
signal: The name of the signal, like pyqtSignal.
|
|
|
|
_func: The function to be invoked when the signal gets called.
|
|
|
|
"""
|
|
|
|
|
|
|
|
def __init__(self, name='fake', func=None):
|
2014-06-23 19:44:21 +02:00
|
|
|
self.signal = '2{}(int, int)'.format(name)
|
2015-09-02 20:40:19 +02:00
|
|
|
self._func = func
|
|
|
|
|
|
|
|
def __call__(self):
|
|
|
|
if self._func is None:
|
|
|
|
raise TypeError("'FakeSignal' object is not callable")
|
|
|
|
else:
|
|
|
|
return self._func()
|
2014-08-05 14:14:16 +02:00
|
|
|
|
2015-05-07 07:58:22 +02:00
|
|
|
def connect(self, slot):
|
|
|
|
"""Connect the signal to a slot.
|
|
|
|
|
|
|
|
Currently does nothing, but could be improved to do some sanity
|
|
|
|
checking on the slot.
|
|
|
|
"""
|
|
|
|
pass
|
|
|
|
|
|
|
|
def disconnect(self, slot=None):
|
|
|
|
"""Disconnect the signal from a slot.
|
|
|
|
|
|
|
|
Currently does nothing, but could be improved to do some sanity
|
|
|
|
checking on the slot and see if it actually got connected.
|
|
|
|
"""
|
|
|
|
pass
|
|
|
|
|
|
|
|
def emit(self, *args):
|
|
|
|
"""Emit the signal.
|
|
|
|
|
|
|
|
Currently does nothing, but could be improved to do type checking based
|
|
|
|
on a signature given to __init__.
|
|
|
|
"""
|
|
|
|
pass
|
|
|
|
|
2014-08-05 14:14:16 +02:00
|
|
|
|
|
|
|
class FakeCmdUtils:
|
|
|
|
|
|
|
|
"""Stub for cmdutils which provides a cmd_dict."""
|
|
|
|
|
|
|
|
def __init__(self, commands):
|
|
|
|
self.cmd_dict = commands
|
|
|
|
|
|
|
|
|
|
|
|
class FakeCommand:
|
|
|
|
|
|
|
|
"""A simple command stub which has a description."""
|
|
|
|
|
2016-06-11 18:43:37 +02:00
|
|
|
def __init__(self, name='', desc='', hide=False, debug=False,
|
2016-06-29 04:55:16 +02:00
|
|
|
deprecated=False, completion=None):
|
2014-08-05 14:14:16 +02:00
|
|
|
self.desc = desc
|
2016-06-11 18:43:37 +02:00
|
|
|
self.name = name
|
|
|
|
self.hide = hide
|
|
|
|
self.debug = debug
|
|
|
|
self.deprecated = deprecated
|
2016-06-29 04:55:16 +02:00
|
|
|
self.completion = completion
|
2015-02-27 12:43:54 +01:00
|
|
|
|
|
|
|
|
2015-03-01 21:29:27 +01:00
|
|
|
class FakeTimer(QObject):
|
2015-02-27 12:43:54 +01:00
|
|
|
|
|
|
|
"""Stub for a usertypes.Timer."""
|
|
|
|
|
2015-03-01 21:29:27 +01:00
|
|
|
timeout_signal = pyqtSignal()
|
|
|
|
|
2015-02-27 12:43:54 +01:00
|
|
|
def __init__(self, parent=None, name=None):
|
2015-03-01 21:29:27 +01:00
|
|
|
super().__init__(parent)
|
|
|
|
self.timeout = mock.Mock(spec=['connect', 'disconnect', 'emit'])
|
|
|
|
self.timeout.connect.side_effect = self.timeout_signal.connect
|
|
|
|
self.timeout.disconnect.side_effect = self.timeout_signal.disconnect
|
|
|
|
self.timeout.emit.side_effect = self._emit
|
|
|
|
self._started = False
|
|
|
|
self._singleshot = False
|
|
|
|
self._interval = 0
|
|
|
|
self._name = name
|
|
|
|
|
|
|
|
def __repr__(self):
|
|
|
|
return '<{} name={!r}>'.format(self.__class__.__name__, self._name)
|
|
|
|
|
|
|
|
def _emit(self):
|
|
|
|
"""Called when the timeout "signal" gets emitted."""
|
|
|
|
if self._singleshot:
|
|
|
|
self._started = False
|
|
|
|
self.timeout_signal.emit()
|
|
|
|
|
|
|
|
def setInterval(self, interval):
|
|
|
|
self._interval = interval
|
|
|
|
|
|
|
|
def interval(self):
|
|
|
|
return self._interval
|
|
|
|
|
|
|
|
def setSingleShot(self, singleshot):
|
|
|
|
self._singleshot = singleshot
|
|
|
|
|
2015-04-04 17:29:17 +02:00
|
|
|
def isSingleShot(self):
|
2015-03-01 21:29:27 +01:00
|
|
|
return self._singleshot
|
|
|
|
|
|
|
|
def start(self):
|
|
|
|
self._started = True
|
|
|
|
|
|
|
|
def stop(self):
|
|
|
|
self._started = False
|
|
|
|
|
|
|
|
def isActive(self):
|
|
|
|
return self._started
|
2015-04-04 18:24:26 +02:00
|
|
|
|
|
|
|
|
2016-06-20 05:15:09 +02:00
|
|
|
class FakeConfigType:
|
|
|
|
|
2016-07-01 02:12:44 +02:00
|
|
|
"""A stub to provide valid_values for typ attribute of a SettingValue."""
|
2016-06-20 05:15:09 +02:00
|
|
|
|
2016-07-01 02:12:44 +02:00
|
|
|
def __init__(self, *valid_values):
|
2016-06-20 05:15:09 +02:00
|
|
|
# normally valid_values would be a ValidValues, but for simplicity of
|
|
|
|
# testing this can be a simple list: [(val, desc), (val, desc), ...]
|
|
|
|
self.complete = lambda: [(val, '') for val in valid_values]
|
|
|
|
|
2016-06-14 04:20:25 +02:00
|
|
|
|
2016-07-04 05:06:36 +02:00
|
|
|
class FakeStatusbarCommand(QLineEdit):
|
2016-06-29 04:55:16 +02:00
|
|
|
|
|
|
|
"""Stub for the statusbar command prompt."""
|
|
|
|
|
|
|
|
got_cmd = pyqtSignal(str)
|
|
|
|
clear_completion_selection = pyqtSignal()
|
|
|
|
hide_completion = pyqtSignal()
|
|
|
|
update_completion = pyqtSignal()
|
|
|
|
show_cmd = pyqtSignal()
|
|
|
|
hide_cmd = pyqtSignal()
|
|
|
|
|
2016-07-04 05:06:36 +02:00
|
|
|
def __init__(self, parent=None):
|
2016-06-29 04:55:16 +02:00
|
|
|
super().__init__(parent)
|
2016-07-03 19:03:30 +02:00
|
|
|
|
|
|
|
def prefix(self):
|
2016-07-04 05:06:36 +02:00
|
|
|
return self.text()[0]
|
2016-06-29 04:55:16 +02:00
|
|
|
|
|
|
|
|
2015-08-19 19:37:19 +02:00
|
|
|
class ConfigStub(QObject):
|
2015-07-20 11:23:34 +02:00
|
|
|
|
|
|
|
"""Stub for the config module.
|
|
|
|
|
|
|
|
Attributes:
|
|
|
|
data: The config data to return.
|
|
|
|
"""
|
|
|
|
|
2015-08-19 19:37:19 +02:00
|
|
|
changed = pyqtSignal(str, str)
|
|
|
|
|
|
|
|
def __init__(self, parent=None):
|
2015-07-20 11:23:34 +02:00
|
|
|
"""Constructor.
|
|
|
|
|
|
|
|
Args:
|
|
|
|
signal: The signal to use for self.changed.
|
|
|
|
"""
|
2015-08-19 19:37:19 +02:00
|
|
|
super().__init__(parent)
|
2015-07-20 11:23:34 +02:00
|
|
|
self.data = {}
|
|
|
|
|
2015-08-19 20:39:48 +02:00
|
|
|
def __getitem__(self, name):
|
|
|
|
return self.section(name)
|
|
|
|
|
2015-07-20 11:23:34 +02:00
|
|
|
def section(self, name):
|
|
|
|
"""Get a section from the config.
|
|
|
|
|
|
|
|
Args:
|
|
|
|
name: The section name to get.
|
|
|
|
|
|
|
|
Return:
|
|
|
|
The section as dict.
|
|
|
|
"""
|
|
|
|
return self.data[name]
|
|
|
|
|
2016-06-18 12:55:17 +02:00
|
|
|
def get(self, sect, opt, raw=True):
|
2015-07-20 11:23:34 +02:00
|
|
|
"""Get a value from the config."""
|
|
|
|
data = self.data[sect]
|
|
|
|
try:
|
|
|
|
return data[opt]
|
|
|
|
except KeyError:
|
|
|
|
raise configexc.NoOptionError(opt, sect)
|
|
|
|
|
2015-09-03 18:17:39 +02:00
|
|
|
def set(self, sect, opt, value):
|
|
|
|
"""Set a value in the config."""
|
|
|
|
data = self.data[sect]
|
|
|
|
try:
|
|
|
|
data[opt] = value
|
|
|
|
self.changed.emit(sect, opt)
|
|
|
|
except KeyError:
|
|
|
|
raise configexc.NoOptionError(opt, sect)
|
|
|
|
|
2015-07-20 11:23:34 +02:00
|
|
|
|
|
|
|
class KeyConfigStub:
|
|
|
|
|
|
|
|
"""Stub for the key-config object."""
|
|
|
|
|
2016-05-16 04:18:16 +02:00
|
|
|
def __init__(self):
|
|
|
|
self.bindings = {}
|
|
|
|
|
|
|
|
def get_bindings_for(self, section):
|
|
|
|
return self.bindings.get(section)
|
|
|
|
|
|
|
|
def set_bindings_for(self, section, bindings):
|
|
|
|
self.bindings[section] = bindings
|
2015-07-20 11:23:34 +02:00
|
|
|
|
|
|
|
|
2016-06-16 05:41:14 +02:00
|
|
|
class UrlMarkManagerStub(QObject):
|
|
|
|
|
|
|
|
"""Stub for the quickmark-manager or bookmark-manager object."""
|
|
|
|
|
|
|
|
added = pyqtSignal(str, str)
|
|
|
|
removed = pyqtSignal(str)
|
|
|
|
|
|
|
|
def __init__(self, parent=None):
|
|
|
|
super().__init__(parent)
|
|
|
|
self.marks = {}
|
|
|
|
|
2016-06-22 05:04:03 +02:00
|
|
|
def delete(self, key):
|
|
|
|
del self.marks[key]
|
|
|
|
self.removed.emit(key)
|
|
|
|
|
|
|
|
|
|
|
|
class BookmarkManagerStub(UrlMarkManagerStub):
|
2016-06-22 05:23:24 +02:00
|
|
|
|
|
|
|
"""Stub for the bookmark-manager object."""
|
|
|
|
|
2016-06-22 05:04:03 +02:00
|
|
|
pass
|
|
|
|
|
|
|
|
|
|
|
|
class QuickmarkManagerStub(UrlMarkManagerStub):
|
2016-06-22 05:23:24 +02:00
|
|
|
|
|
|
|
"""Stub for the quickmark-manager object."""
|
|
|
|
|
2016-06-22 05:04:03 +02:00
|
|
|
def quickmark_del(self, key):
|
|
|
|
self.delete(key)
|
|
|
|
|
2016-06-16 05:41:14 +02:00
|
|
|
|
|
|
|
class WebHistoryStub(QObject):
|
|
|
|
|
|
|
|
"""Stub for the web-history object."""
|
|
|
|
|
2016-06-30 13:17:24 +02:00
|
|
|
add_completion_item = pyqtSignal(history.Entry)
|
2016-06-16 05:41:14 +02:00
|
|
|
cleared = pyqtSignal()
|
|
|
|
|
|
|
|
def __init__(self, parent=None):
|
|
|
|
super().__init__(parent)
|
|
|
|
self.history_dict = collections.OrderedDict()
|
|
|
|
|
|
|
|
def __iter__(self):
|
|
|
|
return iter(self.history_dict.values())
|
|
|
|
|
|
|
|
def __len__(self):
|
|
|
|
return len(self.history_dict)
|
|
|
|
|
|
|
|
|
2015-07-20 11:23:34 +02:00
|
|
|
class HostBlockerStub:
|
|
|
|
|
|
|
|
"""Stub for the host-blocker object."""
|
|
|
|
|
|
|
|
def __init__(self):
|
|
|
|
self.blocked_hosts = set()
|
2016-06-17 05:12:04 +02:00
|
|
|
|
|
|
|
|
|
|
|
class SessionManagerStub:
|
|
|
|
|
|
|
|
"""Stub for the session-manager object."""
|
|
|
|
|
|
|
|
def __init__(self):
|
|
|
|
self.sessions = []
|
|
|
|
|
|
|
|
def list_sessions(self):
|
|
|
|
return self.sessions
|
2016-06-17 05:12:21 +02:00
|
|
|
|
|
|
|
|
|
|
|
class TabbedBrowserStub(QObject):
|
|
|
|
|
|
|
|
"""Stub for the tabbed-browser object."""
|
|
|
|
|
|
|
|
new_tab = pyqtSignal(webview.WebView, int)
|
|
|
|
|
|
|
|
def __init__(self, parent=None):
|
|
|
|
super().__init__(parent)
|
|
|
|
self.tabs = []
|
|
|
|
self.shutting_down = False
|
|
|
|
|
|
|
|
def count(self):
|
|
|
|
return len(self.tabs)
|
|
|
|
|
|
|
|
def widget(self, i):
|
|
|
|
return self.tabs[i]
|
|
|
|
|
|
|
|
def page_title(self, i):
|
|
|
|
return self.tabs[i].title
|
|
|
|
|
2016-06-21 03:58:12 +02:00
|
|
|
def on_tab_close_requested(self, idx):
|
|
|
|
del self.tabs[idx]
|
|
|
|
|
2016-06-17 05:12:21 +02:00
|
|
|
|
|
|
|
class ApplicationStub(QObject):
|
|
|
|
|
|
|
|
"""Stub to insert as the app object in objreg."""
|
|
|
|
|
|
|
|
new_window = pyqtSignal(mainwindow.MainWindow)
|
|
|
|
|
|
|
|
def __init__(self):
|
|
|
|
super().__init__()
|