qutebrowser/tests/unit/browser/test_qutescheme.py

159 lines
5.3 KiB
Python
Raw Normal View History

2017-02-08 09:28:04 +01:00
# vim: ft=python fileencoding=utf-8 sts=4 sw=4 et:
# Copyright 2017 Imran Sobir
#
# 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/>.
2017-02-26 13:07:30 +01:00
import json
2017-02-27 18:37:24 +01:00
import os
2017-02-26 13:07:30 +01:00
import time
2017-02-09 11:44:51 +01:00
2017-02-08 09:28:04 +01:00
from PyQt5.QtCore import QUrl
2017-02-09 11:44:51 +01:00
import pytest
2017-02-08 09:28:04 +01:00
from qutebrowser.browser import history, qutescheme
from qutebrowser.utils import objreg
2017-02-27 18:37:24 +01:00
class TestJavascriptHandler:
"""Test the qute://javascript endpoint."""
# Tuples of fake JS files and their content.
js_files = [
('foo.js', "var a = 'foo';"),
('bar.js', "var a = 'bar';"),
]
@pytest.fixture(autouse=True)
def patch_read_file(self, monkeypatch):
"""Patch utils.read_file to return few fake JS files."""
def _read_file(path, binary=False):
"""Faked utils.read_file"""
assert not binary
for filename, content in self.js_files:
if path == os.path.join('javascript', filename):
return content
raise IOError("File not found {}!".format(path))
monkeypatch.setattr('qutebrowser.utils.utils.read_file', _read_file)
@pytest.mark.parametrize("filename, content", js_files)
def test_qutejavascript(self, filename, content):
url = QUrl("qute://javascript/{}".format(filename))
_mimetype, data = qutescheme.qute_javascript(url)
assert data == content
def test_qutejavascript_error(self):
url = QUrl("qute://javascript/404.js")
with pytest.raises(IOError):
qutescheme.qute_javascript(url)
def test_qutejavascript_empty_query(self):
url = QUrl("qute://javascript")
with pytest.raises(qutescheme.QuteSchemeError):
qutescheme.qute_javascript(url)
2017-02-08 09:28:04 +01:00
class TestHistoryHandler:
2017-02-09 11:44:51 +01:00
2017-02-08 09:28:04 +01:00
"""Test the qute://history endpoint."""
@pytest.fixture
2017-02-26 13:07:30 +01:00
def entries(self):
"""Create fake history entries."""
# create 12 history items spaced 6 hours apart, starting from now
entry_count = 12
interval = 6 * 60 * 60
self.now = time.time()
items = []
for i in range(entry_count):
entry_atime = int(self.now - i * interval)
entry = history.Entry(atime=str(entry_atime),
url=QUrl("www.x.com/" + str(i)), title="Page " + str(i))
items.insert(0, entry)
return items
2017-02-08 09:28:04 +01:00
2017-02-09 18:27:32 +01:00
@pytest.fixture
def fake_web_history(self, fake_save_manager, tmpdir):
"""Create a fake web-history and register it into objreg."""
web_history = history.WebHistory(tmpdir.dirname, 'fake-history')
objreg.register('web-history', web_history)
yield web_history
objreg.delete('web-history')
@pytest.fixture(autouse=True)
def fake_history(self, fake_web_history, entries):
2017-02-26 13:07:30 +01:00
"""Create fake history."""
for item in entries:
fake_web_history._add_entry(item)
fake_web_history.save()
2017-02-26 13:07:30 +01:00
@pytest.mark.parametrize("start_time_offset, expected_item_count", [
(0, 5),
(24*60*60, 5),
(48*60*60, 5),
(72*60*60, 1)
2017-02-26 13:07:30 +01:00
])
def test_qutehistory_data(self, start_time_offset, expected_item_count):
"""Ensure qute://history/data returns correct items."""
start_time = int(self.now) - start_time_offset
url = QUrl("qute://history/data?start_time=" + str(start_time))
2017-02-08 09:28:04 +01:00
_mimetype, data = qutescheme.qute_history(url)
2017-02-26 13:07:30 +01:00
items = json.loads(data)
2017-02-09 13:18:57 +01:00
2017-02-26 13:07:30 +01:00
assert len(items) == expected_item_count
2017-02-09 13:18:57 +01:00
# test times
2017-02-26 13:07:30 +01:00
end_time = start_time - 24*60*60
for item in items[:expected_item_count-1]:
2017-02-26 13:07:30 +01:00
assert item['time'] <= start_time
assert item['time'] > end_time
2017-02-09 21:56:06 +01:00
@pytest.mark.parametrize("start_time_offset, next_time", [
(0, 24*60*60),
(24*60*60, 48*60*60),
(48*60*60, -1),
(72*60*60, -1)
])
def test_qutehistory_next(self, start_time_offset, next_time):
"""Ensure qute://history/data returns correct items."""
start_time = int(self.now) - start_time_offset
url = QUrl("qute://history/data?start_time=" + str(start_time))
_mimetype, data = qutescheme.qute_history(url)
items = json.loads(data)
if next_time == -1:
assert items[-1]["next"] == -1
else:
assert items[-1]["next"] == int(self.now) - next_time
2017-02-26 13:07:30 +01:00
def test_qute_history_benchmark(self, fake_web_history, benchmark):
for t in range(100000): # one history per second
2017-02-09 21:56:06 +01:00
entry = history.Entry(
2017-02-26 13:07:30 +01:00
atime=str(self.now - t),
url=QUrl('www.x.com/{}'.format(t)),
title='x at {}'.format(t))
2017-02-09 21:56:06 +01:00
fake_web_history._add_entry(entry)
2017-02-26 13:07:30 +01:00
url = QUrl("qute://history/data?start_time={}".format(self.now))
2017-02-26 16:13:05 +01:00
_mimetype, _data = benchmark(qutescheme.qute_history, url)