From a9fb55192d2d71f075209e6601cfbf58cf98f97e Mon Sep 17 00:00:00 2001 From: Will Shanks Date: Fri, 15 Nov 2024 15:46:54 -0500 Subject: [PATCH] Remove remaining references to Provider classes This chane is a follow up to 519bb534c134ca9a251f4f92f6abd39f56017341 to remove remaining references to the Provider base classes which were deprecated in Qiskit 1.1. Providers are now unspecified objects that generate backends. As a follow up, work is needed on the `ExperimentData` class to tighten up how it works with providers, especially since the main provider now is `QiskitRuntimeService` from qiskit-ibm-runtime, which already was not actually a `Provider`. --- .../framework/experiment_data.py | 11 +++++----- qiskit_experiments/test/fake_backend.py | 22 ++++++++++++++++--- qiskit_experiments/test/mock_iq_backend.py | 4 ++-- .../provider-removal-a132799ce755773f.yaml | 11 ++++++++++ 4 files changed, 37 insertions(+), 11 deletions(-) create mode 100644 releasenotes/notes/provider-removal-a132799ce755773f.yaml diff --git a/qiskit_experiments/framework/experiment_data.py b/qiskit_experiments/framework/experiment_data.py index a4cd953967..aa5f8695a2 100644 --- a/qiskit_experiments/framework/experiment_data.py +++ b/qiskit_experiments/framework/experiment_data.py @@ -76,7 +76,6 @@ # `TYPE_CHECKING` means that the import will never be resolved by an actual # interpreter, only static analysis. from . import BaseExperiment - from qiskit.providers import Provider LOG = logging.getLogger(__name__) @@ -173,7 +172,7 @@ def __init__( experiment: Optional["BaseExperiment"] = None, backend: Optional[Backend] = None, service: Optional[IBMExperimentService] = None, - provider: Optional[Provider] = None, + provider=None, parent_id: Optional[str] = None, job_ids: Optional[List[str]] = None, child_data: Optional[List[ExperimentData]] = None, @@ -261,7 +260,7 @@ def __init__( self._set_backend(backend, recursive=False) self.provider = provider if provider is None and backend is not None: - self.provider = backend.provider + self.provider = getattr(backend, "provider", None) self._service = service if self._service is None and self.provider is not None: self._service = self.get_service_from_provider(self.provider) @@ -675,7 +674,7 @@ def service(self, service: IBMExperimentService) -> None: self._set_service(service) @property - def provider(self) -> Optional[Provider]: + def provider(self) -> Any: """Return the backend provider. Returns: @@ -684,7 +683,7 @@ def provider(self) -> Optional[Provider]: return self._provider @provider.setter - def provider(self, provider: Provider) -> None: + def provider(self, provider: Any) -> None: """Set the provider to be used for obtaining job data Args: @@ -2369,7 +2368,7 @@ def load( cls, experiment_id: str, service: Optional[IBMExperimentService] = None, - provider: Optional[Provider] = None, + provider: Any = None, ) -> "ExperimentData": """Load a saved experiment data from a database service. diff --git a/qiskit_experiments/test/fake_backend.py b/qiskit_experiments/test/fake_backend.py index d67a259ab4..58b976f4e2 100644 --- a/qiskit_experiments/test/fake_backend.py +++ b/qiskit_experiments/test/fake_backend.py @@ -13,7 +13,7 @@ """Fake backend class for tests.""" import uuid from qiskit.circuit.library import Measure -from qiskit.providers import ProviderV1 +from qiskit.exceptions import QiskitError from qiskit.providers.backend import BackendV2 from qiskit.providers.options import Options from qiskit.transpiler import Target @@ -23,13 +23,29 @@ from qiskit_experiments.test.utils import FakeJob -class FakeProvider(ProviderV1): +class FakeProvider: """Fake provider with no backends for testing""" - def backends(self, name=None, **kwargs): + def backends(self, name=None, **kwargs): # pylint: disable=unused-argument """List of available backends. Empty in this case""" return [] + def get_backend(self, name=None, **kwargs): + """Return a single backend matching the specified filtering. + + Args: + name (str): name of the backend. + **kwargs: dict used for filtering. + + Returns: + Backend: a backend matching the filtering. + + Raises: + QiskitError: if no backend could be found or more than one backend + matches the filtering criteria. + """ + raise QiskitError("No backend matches the criteria") + class FakeBackend(BackendV2): """ diff --git a/qiskit_experiments/test/mock_iq_backend.py b/qiskit_experiments/test/mock_iq_backend.py index 02ea3bbde1..f613d39274 100644 --- a/qiskit_experiments/test/mock_iq_backend.py +++ b/qiskit_experiments/test/mock_iq_backend.py @@ -20,7 +20,7 @@ from qiskit import QuantumCircuit from qiskit.circuit.library import XGate, SXGate from qiskit.result import Result -from qiskit.providers import BackendV2, Provider, convert_to_target +from qiskit.providers import BackendV2, convert_to_target from qiskit.providers.fake_provider import FakeOpenPulse2Q from qiskit.qobj.utils import MeasLevel @@ -40,7 +40,7 @@ class FakeOpenPulse2QV2(BackendV2): def __init__( self, - provider: Provider = None, + provider=None, name: str = None, description: str = None, online_date: datetime.datetime = None, diff --git a/releasenotes/notes/provider-removal-a132799ce755773f.yaml b/releasenotes/notes/provider-removal-a132799ce755773f.yaml new file mode 100644 index 0000000000..b03138999a --- /dev/null +++ b/releasenotes/notes/provider-removal-a132799ce755773f.yaml @@ -0,0 +1,11 @@ +--- +fixes: + - | + All references to ``qiskit.providers.Provider`` have been removed the code + base. The provider base classes were deprecated in Qiskit 1.1 with planned + removal in Qiskit 2.0. Qiskit Experiments has some support code for working + with providers to retrieve job data, but it takes the provider object as + input. The only explicit references to the provider classes were in type + annotations and test support code under ``qiskit_experiments.test``. The + type annotations have been removed and the test code now uses its own class + without a parent.