From c0023d56443ab56343dbf1cc251aba63c2698648 Mon Sep 17 00:00:00 2001 From: Will Shanks Date: Tue, 26 Mar 2024 13:42:14 -0400 Subject: [PATCH] Handle invalid version strings --- qiskit_experiments/framework/package_deps.py | 20 +++++++++++++++++--- 1 file changed, 17 insertions(+), 3 deletions(-) diff --git a/qiskit_experiments/framework/package_deps.py b/qiskit_experiments/framework/package_deps.py index 50c05ca7b3..cdd6190fc5 100644 --- a/qiskit_experiments/framework/package_deps.py +++ b/qiskit_experiments/framework/package_deps.py @@ -15,10 +15,11 @@ from __future__ import annotations +import warnings from functools import lru_cache from importlib.metadata import version as metadata_version -from packaging.version import Version +from packaging.version import InvalidVersion, Version from qiskit.utils.lazy_tester import LazyImportTester @@ -61,11 +62,24 @@ def version_is_at_least(package: str, version: str) -> bool: evaluate as less than ``0.5.0``). Returns: - True if installed version greater than ``version``. False if it is less. + True if installed version greater than ``version``. False if it is less + or if the installed version of ``package`` can not be parsed using the + specifications of PEP440. Raises: PackageNotFoundError: If ``package`` is not installed. """ - installed_version = Version(metadata_version(package)) + raw_installed_version = metadata_version(package) + try: + installed_version = Version(raw_installed_version) + except InvalidVersion: + warnings.warn( + ( + f"Version string of installed {package} does not match PyPA " + f"specification. Treating as less than {version}." + ), + RuntimeWarning, + ) + return False return installed_version > Version(f"{version}.dev0")