Source code for quantify_scheduler.backends.qblox.driver_version_check

# Repository: https://gitlab.com/quantify-os/quantify-scheduler
# Licensed according to the LICENCE file on the main branch
"""Helper functions to perform the version check for qblox_instruments."""

from __future__ import annotations

import logging

[docs] logger = logging.getLogger(__name__)
try: from qblox_instruments.build import __version__ as driver_version except ImportError:
[docs] driver_version = None # Prior to v0.3.2 __version__ was not there
[docs] SUPPORTED_DRIVER_VERSIONS: tuple[str, ...] = ("0.14", "0.15")
"""Tuple containing all the version supported by this version of the backend."""
[docs] raise_on_version_mismatch: bool = True
"""Can be set to false to override version check."""
[docs] class DriverVersionError(Exception): """Raise when the installed driver version is not supported."""
[docs] def verify_qblox_instruments_version(version: str | None = driver_version) -> None: """ Verifies whether the installed version is supported by the qblox_backend. Parameters ---------- version The Qblox driver versions (``qblox-instruments`` python package). Raises ------ DriverVersionError When an incorrect or no installation of qblox-instruments was found. """ if not raise_on_version_mismatch: logger.warning( f"Qblox driver version check skipped with " f"{__name__}.raise_on_version_mismatch={raise_on_version_mismatch}." ) return if version is None: raise DriverVersionError( "Version check for Qblox driver (qblox-instruments) could not be " "performed. Either the package is not installed correctly or a version " "<0.3.2 was found." ) major, minor, patch = version.split(".") if f"{major}.{minor}" not in SUPPORTED_DRIVER_VERSIONS: raise DriverVersionError( f"The installed Qblox driver (qblox-instruments) version {version} is not " "supported by backend. Please install one of the supported versions " f"({'; '.join(SUPPORTED_DRIVER_VERSIONS)}) in order to use this backend." ) if f"{major}.{minor}" != SUPPORTED_DRIVER_VERSIONS[-1]: logger.info( "A newer version of Qblox driver (qblox-instruments) which is supported by " "the backend is available." )