qutebrowser/tests/integration/features/conftest.py

78 lines
2.4 KiB
Python
Raw Normal View History

import re
2015-11-01 22:10:48 +01:00
import logging
2015-10-11 13:53:59 +02:00
import yaml
2015-11-02 20:32:15 +01:00
import pytest_bdd as bdd
2015-10-11 13:53:59 +02:00
from helpers import utils
2015-10-11 13:53:59 +02:00
@bdd.given(bdd.parsers.parse("I set {sect} -> {opt} to {value}"))
def set_setting(quteproc, sect, opt, value):
quteproc.set_setting(sect, opt, value)
@bdd.given(bdd.parsers.parse("I open {path}"))
def open_path(quteproc, path):
2015-10-13 07:14:32 +02:00
quteproc.open_path(path, new_tab=True)
2015-10-11 13:53:59 +02:00
@bdd.when(bdd.parsers.parse("I open {path}"))
def open_path_when(quteproc, path):
quteproc.open_path(path)
@bdd.when(bdd.parsers.parse("I run {command}"))
def run_command(quteproc, command):
quteproc.send_cmd(command)
@bdd.when(bdd.parsers.parse("I reload"))
2015-10-27 08:07:16 +01:00
def reload(qtbot, httpbin, quteproc, command):
with qtbot.waitSignal(httpbin.new_request, raising=True):
quteproc.send_cmd(':reload')
2015-10-11 13:53:59 +02:00
@bdd.then(bdd.parsers.parse("{path} should be loaded"))
def path_should_be_loaded(httpbin, path):
requests = httpbin.get_requests()
assert requests[-1] == httpbin.Request('GET', '/' + path)
2015-10-11 13:53:59 +02:00
@bdd.then(bdd.parsers.parse("The requests should be:\n{pages}"))
2015-10-27 08:07:16 +01:00
def list_of_loaded_pages(httpbin, pages):
requests = [httpbin.Request('GET', '/' + path.strip())
for path in pages.split('\n')]
2015-10-11 13:53:59 +02:00
assert httpbin.get_requests() == requests
2015-10-22 06:44:05 +02:00
2015-11-02 07:43:37 +01:00
@bdd.then(bdd.parsers.re(r'the (?P<category>error|message) "(?P<message>.*)" '
r'should be shown.'))
def expect_error(quteproc, httpbin, category, message):
category_to_loglevel = {
'message': logging.INFO,
'error': logging.ERROR,
}
message = message.replace('(port)', str(httpbin.port))
quteproc.mark_expected(category='message',
loglevel=category_to_loglevel[category],
2015-11-01 22:10:48 +01:00
message=message)
@bdd.then(bdd.parsers.parse("The session should look like:\n{expected}"))
def compare_session(quteproc, tmpdir, expected):
session = tmpdir / 'session.yml'
quteproc.send_cmd(':session-save "{}"'.format(session))
quteproc.wait_for(category='message', loglevel=logging.INFO,
message='Saved session {}.'.format(session))
# Translate ... to ellipsis in YAML.
loader = yaml.SafeLoader(expected)
loader.add_constructor('!ellipsis', lambda loader, node: ...)
loader.add_implicit_resolver('!ellipsis', re.compile('\.\.\.'), None)
data = yaml.load(session.read())
expected = loader.get_data()
assert utils.partial_compare(data, expected)