2015-12-08 17:15:47 +01:00
|
|
|
# vim: ft=python fileencoding=utf-8 sts=4 sw=4 et:
|
|
|
|
|
|
|
|
# Copyright 2015 Daniel Schadt
|
|
|
|
#
|
|
|
|
# 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/>.
|
|
|
|
|
2018-09-06 00:57:14 +02:00
|
|
|
import textwrap
|
|
|
|
|
2015-12-08 17:15:47 +01:00
|
|
|
import pytest
|
2018-09-06 00:57:14 +02:00
|
|
|
from PyQt5.QtCore import QUrl
|
2015-12-08 17:15:47 +01:00
|
|
|
|
|
|
|
from qutebrowser.browser import pdfjs
|
|
|
|
|
|
|
|
|
2018-09-06 00:52:52 +02:00
|
|
|
# Note that we got double protection, once because we use QUrl.FullyEncoded and
|
|
|
|
# because we use qutebrowser.utils.javascript.string_escape. Characters
|
|
|
|
# like " are already replaced by QUrl.
|
|
|
|
@pytest.mark.parametrize('url, expected', [
|
|
|
|
('http://foo.bar', "http://foo.bar"),
|
|
|
|
('http://"', ''),
|
|
|
|
('\0', '%00'),
|
|
|
|
('http://foobar/");alert("attack!");',
|
|
|
|
'http://foobar/%22);alert(%22attack!%22);'),
|
|
|
|
])
|
|
|
|
def test_generate_pdfjs_script(url, expected):
|
|
|
|
expected_open = 'open("{}");'.format(expected)
|
|
|
|
url = QUrl(url)
|
|
|
|
actual = pdfjs._generate_pdfjs_script(url)
|
|
|
|
assert expected_open in actual
|
|
|
|
assert 'PDFView' in actual
|
|
|
|
|
|
|
|
|
|
|
|
def test_fix_urls():
|
|
|
|
page = textwrap.dedent("""
|
|
|
|
<html>
|
|
|
|
<script src="viewer.js"></script>
|
|
|
|
<link href="viewer.css">
|
|
|
|
<script src="unrelated.js"></script>
|
|
|
|
</html>
|
|
|
|
""").strip()
|
|
|
|
|
|
|
|
expected = textwrap.dedent("""
|
|
|
|
<html>
|
|
|
|
<script src="qute://pdfjs/web/viewer.js"></script>
|
|
|
|
<link href="qute://pdfjs/web/viewer.css">
|
|
|
|
<script src="unrelated.js"></script>
|
|
|
|
</html>
|
|
|
|
""").strip()
|
|
|
|
|
|
|
|
actual = pdfjs.fix_urls(page)
|
|
|
|
assert actual == expected
|
|
|
|
|
|
|
|
|
2015-12-08 17:15:47 +01:00
|
|
|
@pytest.mark.parametrize('path, expected', [
|
|
|
|
('web/viewer.js', 'viewer.js'),
|
|
|
|
('build/locale/foo.bar', 'locale/foo.bar'),
|
|
|
|
('viewer.js', 'viewer.js'),
|
|
|
|
('foo/viewer.css', 'foo/viewer.css'),
|
|
|
|
])
|
|
|
|
def test_remove_prefix(path, expected):
|
|
|
|
assert pdfjs._remove_prefix(path) == expected
|