2019-02-23 06:34:17 +01:00
|
|
|
# Copyright 2014-2019 Florian Bruhin (The Compiler) <mail@qutebrowser.org>
|
2014-10-02 06:22:06 +02:00
|
|
|
# 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 <http://www.gnu.org/licenses/>.
|
|
|
|
|
|
|
|
"""Tests for qutebrowser.utils.jinja."""
|
|
|
|
|
2015-09-25 18:51:07 +02:00
|
|
|
import os
|
2014-10-14 08:18:06 +02:00
|
|
|
import os.path
|
2017-05-17 20:20:12 +02:00
|
|
|
import logging
|
2014-10-02 06:22:06 +02:00
|
|
|
|
2018-03-05 09:03:58 +01:00
|
|
|
import jinja2.exceptions
|
2015-04-09 00:46:48 +02:00
|
|
|
import pytest
|
2015-09-25 14:31:04 +02:00
|
|
|
from PyQt5.QtCore import QUrl
|
2015-04-09 00:46:48 +02:00
|
|
|
|
2016-03-25 23:57:29 +01:00
|
|
|
from qutebrowser.utils import utils, jinja
|
2014-10-02 06:22:06 +02:00
|
|
|
|
|
|
|
|
2015-04-09 00:46:48 +02:00
|
|
|
@pytest.fixture(autouse=True)
|
|
|
|
def patch_read_file(monkeypatch):
|
2015-04-09 06:53:21 +02:00
|
|
|
"""pytest fixture to patch utils.read_file."""
|
2016-11-10 08:37:12 +01:00
|
|
|
real_resource_filename = utils.resource_filename
|
2016-03-26 00:24:54 +01:00
|
|
|
|
2016-11-10 08:37:12 +01:00
|
|
|
def _read_file(path, binary=False):
|
2015-04-09 06:53:21 +02:00
|
|
|
"""A read_file which returns a simple template if the path is right."""
|
2015-04-09 00:46:48 +02:00
|
|
|
if path == os.path.join('html', 'test.html'):
|
2016-11-10 08:37:12 +01:00
|
|
|
assert not binary
|
2015-04-09 00:46:48 +02:00
|
|
|
return """Hello {{var}}"""
|
2016-11-10 07:51:19 +01:00
|
|
|
elif path == os.path.join('html', 'test2.html'):
|
2016-11-10 08:37:12 +01:00
|
|
|
assert not binary
|
2016-11-10 07:51:19 +01:00
|
|
|
return """{{ resource_url('utils/testfile') }}"""
|
2016-11-10 08:37:12 +01:00
|
|
|
elif path == os.path.join('html', 'test3.html'):
|
|
|
|
assert not binary
|
|
|
|
return """{{ data_url('testfile.txt') }}"""
|
|
|
|
elif path == 'testfile.txt':
|
|
|
|
assert binary
|
|
|
|
return b'foo'
|
2016-03-25 23:57:29 +01:00
|
|
|
elif path == os.path.join('html', 'undef.html'):
|
2016-11-10 08:37:12 +01:00
|
|
|
assert not binary
|
2016-03-25 23:57:29 +01:00
|
|
|
return """{{ does_not_exist() }}"""
|
2017-06-13 16:02:56 +02:00
|
|
|
elif path == os.path.join('html', 'attributeerror.html'):
|
|
|
|
assert not binary
|
|
|
|
return """{{ obj.foobar }}"""
|
2015-04-09 00:46:48 +02:00
|
|
|
else:
|
2015-08-12 06:25:05 +02:00
|
|
|
raise IOError("Invalid path {}!".format(path))
|
2015-04-09 00:46:48 +02:00
|
|
|
|
2016-11-10 08:37:12 +01:00
|
|
|
def _resource_filename(path):
|
|
|
|
if path == 'utils/testfile':
|
|
|
|
return real_resource_filename(path)
|
|
|
|
elif path == 'testfile.txt':
|
|
|
|
return path
|
|
|
|
else:
|
|
|
|
raise IOError("Invalid path {}!".format(path))
|
|
|
|
|
2017-03-01 11:33:41 +01:00
|
|
|
monkeypatch.setattr(jinja.utils, 'read_file', _read_file)
|
|
|
|
monkeypatch.setattr(jinja.utils, 'resource_filename', _resource_filename)
|
2014-10-02 06:22:06 +02:00
|
|
|
|
|
|
|
|
2015-04-09 00:46:48 +02:00
|
|
|
def test_simple_template():
|
2015-04-09 00:38:57 +02:00
|
|
|
"""Test with a simple template."""
|
2016-03-25 14:29:30 +01:00
|
|
|
data = jinja.render('test.html', var='World')
|
2015-04-09 00:38:57 +02:00
|
|
|
assert data == "Hello World"
|
|
|
|
|
|
|
|
|
2015-09-25 14:31:04 +02:00
|
|
|
def test_resource_url():
|
|
|
|
"""Test resource_url() which can be used from templates."""
|
2016-11-10 07:51:19 +01:00
|
|
|
data = jinja.render('test2.html')
|
2015-09-25 14:31:04 +02:00
|
|
|
print(data)
|
|
|
|
url = QUrl(data)
|
|
|
|
assert url.isValid()
|
|
|
|
assert url.scheme() == 'file'
|
2015-09-25 18:51:07 +02:00
|
|
|
|
|
|
|
path = url.path()
|
|
|
|
|
2017-09-20 10:39:39 +02:00
|
|
|
if utils.is_windows:
|
2015-10-17 18:43:14 +02:00
|
|
|
path = path.lstrip('/')
|
|
|
|
path = path.replace('/', os.sep)
|
2015-09-25 18:51:07 +02:00
|
|
|
|
|
|
|
with open(path, 'r', encoding='utf-8') as f:
|
2015-09-25 14:31:04 +02:00
|
|
|
assert f.read().splitlines()[0] == "Hello World!"
|
|
|
|
|
|
|
|
|
2016-11-10 08:37:12 +01:00
|
|
|
def test_data_url():
|
|
|
|
"""Test data_url() which can be used from templates."""
|
|
|
|
data = jinja.render('test3.html')
|
|
|
|
print(data)
|
|
|
|
url = QUrl(data)
|
|
|
|
assert url.isValid()
|
2016-11-15 22:25:51 +01:00
|
|
|
assert data == 'data:text/plain;base64,Zm9v' # 'foo'
|
2016-11-10 08:37:12 +01:00
|
|
|
|
|
|
|
|
2016-12-28 22:11:34 +01:00
|
|
|
def test_not_found(caplog):
|
2015-08-12 06:25:05 +02:00
|
|
|
"""Test with a template which does not exist."""
|
2016-12-28 22:11:34 +01:00
|
|
|
with caplog.at_level(logging.ERROR):
|
|
|
|
data = jinja.render('does_not_exist.html')
|
|
|
|
assert "The does_not_exist.html template could not be found!" in data
|
|
|
|
|
2018-10-24 10:49:26 +02:00
|
|
|
assert caplog.messages[0].startswith("The does_not_exist.html template"
|
|
|
|
" could not be loaded from")
|
2015-08-12 06:25:05 +02:00
|
|
|
|
|
|
|
|
2015-04-09 00:46:48 +02:00
|
|
|
def test_utf8():
|
2015-04-09 00:38:57 +02:00
|
|
|
"""Test rendering with an UTF8 template.
|
|
|
|
|
|
|
|
This was an attempt to get a failing test case for #127 but it seems
|
|
|
|
the issue is elsewhere.
|
|
|
|
|
2017-02-05 00:13:11 +01:00
|
|
|
https://github.com/qutebrowser/qutebrowser/issues/127
|
2015-04-09 00:38:57 +02:00
|
|
|
"""
|
2016-03-25 14:29:30 +01:00
|
|
|
data = jinja.render('test.html', var='\u2603')
|
2015-04-09 00:38:57 +02:00
|
|
|
assert data == "Hello \u2603"
|
2015-08-12 06:25:05 +02:00
|
|
|
|
|
|
|
|
2016-03-25 23:57:29 +01:00
|
|
|
def test_undefined_function(caplog):
|
2018-03-05 09:03:58 +01:00
|
|
|
"""Make sure undefined attributes crash since we preload resources.."""
|
|
|
|
with pytest.raises(jinja2.exceptions.UndefinedError):
|
|
|
|
jinja.render('undef.html')
|
2016-03-25 23:57:29 +01:00
|
|
|
|
|
|
|
|
2017-06-13 16:02:56 +02:00
|
|
|
def test_attribute_error():
|
|
|
|
"""Make sure accessing an unknown attribute fails."""
|
|
|
|
with pytest.raises(AttributeError):
|
|
|
|
jinja.render('attributeerror.html', obj=object())
|
|
|
|
|
|
|
|
|
2017-09-16 08:30:19 +02:00
|
|
|
@pytest.mark.parametrize('escape', [True, False])
|
|
|
|
def test_autoescape(escape):
|
|
|
|
if not escape:
|
|
|
|
with jinja.environment.no_autoescape():
|
|
|
|
template = jinja.environment.from_string("{{ v }}")
|
|
|
|
assert template.render(v='<foo') == '<foo'
|
|
|
|
|
|
|
|
template = jinja.environment.from_string("{{ v }}")
|
|
|
|
assert template.render(v='<foo') == '<foo'
|