# vim: ft=python fileencoding=utf-8 sts=4 sw=4 et: # Copyright 2014-2019 Florian Bruhin (The Compiler) # # 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 . """Tests for qutebrowser.browser.webkit.http. Note that tests for parse_content_disposition are in their own test_content_disposition.py file. """ import pytest from PyQt5.QtCore import QUrl from qutebrowser.browser.webkit import http @pytest.mark.parametrize('url, expected', [ # Filename in the URL ('http://example.com/path', 'path'), ('http://example.com/foo/path', 'path'), # No filename at all ('http://example.com', 'qutebrowser-download'), ('http://example.com/', 'qutebrowser-download'), ]) def test_no_content_disposition(stubs, url, expected): reply = stubs.FakeNetworkReply(url=QUrl(url)) inline, filename = http.parse_content_disposition(reply) assert inline assert filename == expected @pytest.mark.parametrize('content_type, expected_mimetype, expected_rest', [ (None, None, None), ('image/example', 'image/example', None), ('', '', None), ('image/example; encoding=UTF-8', 'image/example', ' encoding=UTF-8'), ]) def test_parse_content_type(stubs, content_type, expected_mimetype, expected_rest): if content_type is None: reply = stubs.FakeNetworkReply() else: reply = stubs.FakeNetworkReply(headers={'Content-Type': content_type}) mimetype, rest = http.parse_content_type(reply) assert mimetype == expected_mimetype assert rest == expected_rest