summaryrefslogtreecommitdiff
path: root/tests/unit/utils/test_version.py
diff options
context:
space:
mode:
Diffstat (limited to 'tests/unit/utils/test_version.py')
-rw-r--r--tests/unit/utils/test_version.py76
1 files changed, 52 insertions, 24 deletions
diff --git a/tests/unit/utils/test_version.py b/tests/unit/utils/test_version.py
index f846c91ac..879f84a1f 100644
--- a/tests/unit/utils/test_version.py
+++ b/tests/unit/utils/test_version.py
@@ -357,14 +357,14 @@ class TestGitStr:
@pytest.fixture
def commit_file_mock(self, mocker):
- """Fixture providing a mock for utils.read_file for git-commit-id.
+ """Fixture providing a mock for resources.read_file for git-commit-id.
On fixture teardown, it makes sure it got called with git-commit-id as
argument.
"""
mocker.patch('qutebrowser.utils.version.subprocess',
side_effect=AssertionError)
- m = mocker.patch('qutebrowser.utils.version.utils.read_file')
+ m = mocker.patch('qutebrowser.utils.version.resources.read_file')
yield m
m.assert_called_with('git-commit-id')
@@ -413,7 +413,7 @@ class TestGitStr:
"""Test with things raising OSError."""
m = mocker.patch('qutebrowser.utils.version.os')
m.path.join.side_effect = OSError
- mocker.patch('qutebrowser.utils.version.utils.read_file',
+ mocker.patch('qutebrowser.utils.version.resources.read_file',
side_effect=OSError)
with caplog.at_level(logging.ERROR, 'misc'):
assert version._git_str() is None
@@ -956,10 +956,13 @@ class TestWebEngineVersions:
('5.14.2', '77.0.3865.129'),
('5.15.1', '80.0.3987.163'),
('5.15.2', '83.0.4103.122'),
+ ('5.15.3', '87.0.4280.144'),
+ ('5.15.4', '87.0.4280.144'),
+ ('5.15.5', '87.0.4280.144'),
])
def test_from_pyqt(self, qt_version, chromium_version):
expected = version.WebEngineVersions(
- webengine=utils.parse_version(qt_version),
+ webengine=utils.VersionNumber.parse(qt_version),
chromium=chromium_version,
source='PyQt',
)
@@ -982,15 +985,9 @@ class TestWebEngineVersions:
versions = version.WebEngineVersions.from_pyqt(pyqt_webengine_version)
- if pyqt_webengine_version == '5.15.3':
- # Transient situation - we expect to get QtWebEngine 5.15.3 soon,
- # so this will line up again.
- assert versions.chromium == '87.0.4280.144'
- pytest.xfail("Transient situation")
- else:
- from qutebrowser.browser.webengine import webenginesettings
- webenginesettings.init_user_agent()
- expected = webenginesettings.parsed_user_agent.upstream_browser_version
+ from qutebrowser.browser.webengine import webenginesettings
+ webenginesettings.init_user_agent()
+ expected = webenginesettings.parsed_user_agent.upstream_browser_version
assert versions.chromium == expected
@@ -1079,18 +1076,34 @@ class TestChromiumVersion:
import_fake.patch()
@pytest.fixture
- def patch_importlib_no_package(self, monkeypatch):
- """Simulate importlib not finding PyQtWebEngine-Qt."""
- try:
- import importlib.metadata as importlib_metadata
- except ImportError:
- importlib_metadata = pytest.importorskip("importlib_metadata")
-
- def _fake_version(name):
- assert name == 'PyQtWebEngine-Qt'
- raise importlib_metadata.PackageNotFoundError(name)
+ def importlib_patcher(self, monkeypatch):
+ """Patch the importlib module."""
+ def _patch(*, qt, qt5):
+ try:
+ import importlib.metadata as importlib_metadata
+ except ImportError:
+ importlib_metadata = pytest.importorskip("importlib_metadata")
+
+ def _fake_version(name):
+ if name == 'PyQtWebEngine-Qt':
+ outcome = qt
+ elif name == 'PyQtWebEngine-Qt5':
+ outcome = qt5
+ else:
+ raise utils.Unreachable(outcome)
+
+ if outcome is None:
+ raise importlib_metadata.PackageNotFoundError(name)
+ return outcome
+
+ monkeypatch.setattr(importlib_metadata, 'version', _fake_version)
+
+ return _patch
- monkeypatch.setattr(importlib_metadata, 'version', _fake_version)
+ @pytest.fixture
+ def patch_importlib_no_package(self, importlib_patcher):
+ """Simulate importlib not finding PyQtWebEngine-Qt[5]."""
+ importlib_patcher(qt=None, qt5=None)
@pytest.mark.parametrize('patches, sources', [
(['elf_fail'], ['importlib', 'PyQt', 'Qt']),
@@ -1114,6 +1127,21 @@ class TestChromiumVersion:
versions = version.qtwebengine_versions(avoid_init=True)
assert versions.source in sources
+ @pytest.mark.parametrize('qt, qt5, expected', [
+ (None, '5.15.4', utils.VersionNumber(5, 15, 4)),
+ ('5.15.3', None, utils.VersionNumber(5, 15, 3)),
+ ('5.15.3', '5.15.4', utils.VersionNumber(5, 15, 4)), # -Qt5 takes precedence
+ ])
+ def test_importlib(self, qt, qt5, expected, patch_elf_fail, importlib_patcher):
+ """Test the importlib version logic with different Qt packages.
+
+ With PyQtWebEngine 5.15.4, PyQtWebEngine-Qt was renamed to PyQtWebEngine-Qt5.
+ """
+ importlib_patcher(qt=qt, qt5=qt5)
+ versions = version.qtwebengine_versions(avoid_init=True)
+ assert versions.source == 'importlib'
+ assert versions.webengine == expected
+
@dataclasses.dataclass
class VersionParams: