Make a now fixture to hold time of test.

This commit is contained in:
Imran Sobir 2017-03-02 23:14:36 +05:00
parent 96e81f595f
commit 907d94591d

View File

@ -75,11 +75,12 @@ class TestHistoryHandler:
"""Test the qute://history endpoint.""" """Test the qute://history endpoint."""
# Current time @pytest.fixture(scope="module")
now = time.time() def now(self):
return int(time.time())
@pytest.fixture @pytest.fixture
def entries(self): def entries(self, now):
"""Create fake history entries.""" """Create fake history entries."""
# create 12 history items spaced 6 hours apart, starting from now # create 12 history items spaced 6 hours apart, starting from now
entry_count = 12 entry_count = 12
@ -87,7 +88,7 @@ class TestHistoryHandler:
items = [] items = []
for i in range(entry_count): for i in range(entry_count):
entry_atime = int(self.now - i * interval) entry_atime = now - i * interval
entry = history.Entry(atime=str(entry_atime), entry = history.Entry(atime=str(entry_atime),
url=QUrl("www.x.com/" + str(i)), title="Page " + str(i)) url=QUrl("www.x.com/" + str(i)), title="Page " + str(i))
items.insert(0, entry) items.insert(0, entry)
@ -115,9 +116,10 @@ class TestHistoryHandler:
(48*60*60, 4), (48*60*60, 4),
(72*60*60, 0) (72*60*60, 0)
]) ])
def test_qutehistory_data(self, start_time_offset, expected_item_count): def test_qutehistory_data(self, start_time_offset, expected_item_count,
now):
"""Ensure qute://history/data returns correct items.""" """Ensure qute://history/data returns correct items."""
start_time = int(self.now) - start_time_offset start_time = now - start_time_offset
url = QUrl("qute://history/data?start_time=" + str(start_time)) url = QUrl("qute://history/data?start_time=" + str(start_time))
_mimetype, data = qutescheme.qute_history(url) _mimetype, data = qutescheme.qute_history(url)
items = json.loads(data) items = json.loads(data)
@ -137,26 +139,27 @@ class TestHistoryHandler:
(48*60*60, -1), (48*60*60, -1),
(72*60*60, -1) (72*60*60, -1)
]) ])
def test_qutehistory_next(self, start_time_offset, next_time): def test_qutehistory_next(self, start_time_offset, next_time, now):
"""Ensure qute://history/data returns correct items.""" """Ensure qute://history/data returns correct items."""
start_time = int(self.now) - start_time_offset start_time = now - start_time_offset
url = QUrl("qute://history/data?start_time=" + str(start_time)) url = QUrl("qute://history/data?start_time=" + str(start_time))
_mimetype, data = qutescheme.qute_history(url) _mimetype, data = qutescheme.qute_history(url)
items = json.loads(data) items = json.loads(data)
items = [item for item in items if 'next' in item] # 'next' items items = [item for item in items if 'next' in item] # 'next' items
assert len(items) == 1
if next_time == -1: if next_time == -1:
assert items[-1]["next"] == -1 assert items[0]["next"] == -1
else: else:
assert items[-1]["next"] == int(self.now) - next_time assert items[0]["next"] == now - next_time
def test_qute_history_benchmark(self, fake_web_history, benchmark): def test_qute_history_benchmark(self, fake_web_history, benchmark, now):
for t in range(100000): # one history per second for t in range(100000): # one history per second
entry = history.Entry( entry = history.Entry(
atime=str(self.now - t), atime=str(now - t),
url=QUrl('www.x.com/{}'.format(t)), url=QUrl('www.x.com/{}'.format(t)),
title='x at {}'.format(t)) title='x at {}'.format(t))
fake_web_history._add_entry(entry) fake_web_history._add_entry(entry)
url = QUrl("qute://history/data?start_time={}".format(self.now)) url = QUrl("qute://history/data?start_time={}".format(now))
_mimetype, _data = benchmark(qutescheme.qute_history, url) _mimetype, _data = benchmark(qutescheme.qute_history, url)