From 324e9c5cd6b1fb85336d90132932773815ddfd37 Mon Sep 17 00:00:00 2001 From: Jotheeswaran-Nandagopal <163156604+Jotheeswaran-Nandagopal@users.noreply.github.com> Date: Wed, 25 Sep 2024 19:58:26 +0530 Subject: [PATCH] Update Measurement Plug-In Generated Client to Resolve with the Corresponding Measurement Service Version (#925) * fix: update resolve service api and its dependencies * fix: formatting * fix: update resolve service * fix: add deployment_target * fix: update version of service * fix: update version and revert the unwanted changes * fix: revert unwanted change * fix: update poetry * fix: formatting * fix: update version of test measurements in service config (cherry picked from commit 90d3ab7504a30903c9ea574c5725e3749424abe1) --- .../client/__init__.py | 1 + .../measurement_plugin_client.py.mako | 4 ++- packages/generator/poetry.lock | 2 +- packages/generator/pyproject.toml | 2 +- .../non_streaming_data_measurement_client.py | 2 ++ .../void_measurement_client.py | 2 ++ .../NonStreamingDataMeasurement.serviceconfig | 1 + .../__init__.py | 1 - .../PinAwareMeasurement.serviceconfig | 1 + .../pin_aware_measurement/__init__.py | 1 - .../StreamingDataMeasurement.serviceconfig | 1 + .../streaming_data_measurement/__init__.py | 1 - .../VoidMeasurement.serviceconfig | 1 + .../measurements/void_measurement/__init__.py | 1 - packages/sdk/pyproject.toml | 2 +- .../discovery/_client.py | 16 ++++++++++-- packages/service/pyproject.toml | 2 +- .../tests/unit/test_discovery_client.py | 25 ++++++++++++++++++- 18 files changed, 54 insertions(+), 12 deletions(-) diff --git a/packages/generator/ni_measurement_plugin_sdk_generator/client/__init__.py b/packages/generator/ni_measurement_plugin_sdk_generator/client/__init__.py index ccf73dc1c..5f071d241 100644 --- a/packages/generator/ni_measurement_plugin_sdk_generator/client/__init__.py +++ b/packages/generator/ni_measurement_plugin_sdk_generator/client/__init__.py @@ -88,6 +88,7 @@ def _create_client( directory_out=directory_out, class_name=class_name, display_name=metadata.measurement_details.display_name, + version=metadata.measurement_details.version, configuration_metadata=configuration_metadata, output_metadata=output_metadata, service_class=measurement_service_class, diff --git a/packages/generator/ni_measurement_plugin_sdk_generator/client/templates/measurement_plugin_client.py.mako b/packages/generator/ni_measurement_plugin_sdk_generator/client/templates/measurement_plugin_client.py.mako index 5d4912e55..24d382dfc 100644 --- a/packages/generator/ni_measurement_plugin_sdk_generator/client/templates/measurement_plugin_client.py.mako +++ b/packages/generator/ni_measurement_plugin_sdk_generator/client/templates/measurement_plugin_client.py.mako @@ -3,7 +3,7 @@ import re from typing import Any %>\ \ -<%page args="class_name, display_name, configuration_metadata, output_metadata, service_class, configuration_parameters_with_type_and_default_values, measure_api_parameters, output_parameters_with_type, built_in_import_modules, custom_import_modules, enum_by_class_name, configuration_parameters_type_url"/>\ +<%page args="class_name, display_name, version, configuration_metadata, output_metadata, service_class, configuration_parameters_with_type_and_default_values, measure_api_parameters, output_parameters_with_type, built_in_import_modules, custom_import_modules, enum_by_class_name, configuration_parameters_type_url"/>\ \ <% def _format_default_value(value: Any) -> Any: @@ -107,6 +107,7 @@ class ${class_name}: """ self._initialization_lock = threading.RLock() self._service_class = ${service_class | repr} + self._version = ${version | repr} self._grpc_channel_pool = grpc_channel_pool self._discovery_client = discovery_client self._pin_map_client = pin_map_client @@ -188,6 +189,7 @@ class ${class_name}: service_location = self._get_discovery_client().resolve_service( provided_interface=_V2_MEASUREMENT_SERVICE_INTERFACE, service_class=self._service_class, + version=self._version, ) channel = self._get_grpc_channel_pool().get_channel(service_location.insecure_address) self._stub = v2_measurement_service_pb2_grpc.MeasurementServiceStub(channel) diff --git a/packages/generator/poetry.lock b/packages/generator/poetry.lock index cd3b753d6..726fa44b0 100644 --- a/packages/generator/poetry.lock +++ b/packages/generator/poetry.lock @@ -793,7 +793,7 @@ types-protobuf = ">=4.24" [[package]] name = "ni-measurement-plugin-sdk-service" -version = "2.1.0-dev0" +version = "2.1.0-dev2" description = "Measurement Plugin Support for Python" optional = false python-versions = "^3.8" diff --git a/packages/generator/pyproject.toml b/packages/generator/pyproject.toml index c87308533..625db288a 100644 --- a/packages/generator/pyproject.toml +++ b/packages/generator/pyproject.toml @@ -1,6 +1,6 @@ [tool.poetry] name = "ni_measurement_plugin_sdk_generator" -version = "2.1.0-dev1" +version = "2.1.0-dev2" description = "Measurement Plugin Code Generator for Python" authors = ["NI "] readme = "README.md" diff --git a/packages/generator/tests/test_assets/example_renders/measurement_plugin_client/non_streaming_data_measurement_client.py b/packages/generator/tests/test_assets/example_renders/measurement_plugin_client/non_streaming_data_measurement_client.py index cb429b653..f35b50ce8 100644 --- a/packages/generator/tests/test_assets/example_renders/measurement_plugin_client/non_streaming_data_measurement_client.py +++ b/packages/generator/tests/test_assets/example_renders/measurement_plugin_client/non_streaming_data_measurement_client.py @@ -95,6 +95,7 @@ def __init__( """ self._initialization_lock = threading.RLock() self._service_class = "ni.tests.NonStreamingDataMeasurement_Python" + self._version = "0.1.0.0" self._grpc_channel_pool = grpc_channel_pool self._discovery_client = discovery_client self._pin_map_client = pin_map_client @@ -458,6 +459,7 @@ def _get_stub(self) -> v2_measurement_service_pb2_grpc.MeasurementServiceStub: service_location = self._get_discovery_client().resolve_service( provided_interface=_V2_MEASUREMENT_SERVICE_INTERFACE, service_class=self._service_class, + version=self._version, ) channel = self._get_grpc_channel_pool().get_channel( service_location.insecure_address diff --git a/packages/generator/tests/test_assets/example_renders/measurement_plugin_client/void_measurement_client.py b/packages/generator/tests/test_assets/example_renders/measurement_plugin_client/void_measurement_client.py index 43c237c63..b789f982c 100644 --- a/packages/generator/tests/test_assets/example_renders/measurement_plugin_client/void_measurement_client.py +++ b/packages/generator/tests/test_assets/example_renders/measurement_plugin_client/void_measurement_client.py @@ -53,6 +53,7 @@ def __init__( """ self._initialization_lock = threading.RLock() self._service_class = "ni.tests.VoidMeasurement_Python" + self._version = "0.1.0.0" self._grpc_channel_pool = grpc_channel_pool self._discovery_client = discovery_client self._pin_map_client = pin_map_client @@ -111,6 +112,7 @@ def _get_stub(self) -> v2_measurement_service_pb2_grpc.MeasurementServiceStub: service_location = self._get_discovery_client().resolve_service( provided_interface=_V2_MEASUREMENT_SERVICE_INTERFACE, service_class=self._service_class, + version=self._version, ) channel = self._get_grpc_channel_pool().get_channel( service_location.insecure_address diff --git a/packages/generator/tests/utilities/measurements/non_streaming_data_measurement/NonStreamingDataMeasurement.serviceconfig b/packages/generator/tests/utilities/measurements/non_streaming_data_measurement/NonStreamingDataMeasurement.serviceconfig index a9c4276aa..3495e2ae4 100644 --- a/packages/generator/tests/utilities/measurements/non_streaming_data_measurement/NonStreamingDataMeasurement.serviceconfig +++ b/packages/generator/tests/utilities/measurements/non_streaming_data_measurement/NonStreamingDataMeasurement.serviceconfig @@ -2,6 +2,7 @@ "services": [ { "displayName": "Non-Streaming Data Measurement (Py)", + "version": "0.1.0.0", "serviceClass": "ni.tests.NonStreamingDataMeasurement_Python", "descriptionUrl": "", "providedInterfaces": [ diff --git a/packages/generator/tests/utilities/measurements/non_streaming_data_measurement/__init__.py b/packages/generator/tests/utilities/measurements/non_streaming_data_measurement/__init__.py index 943007092..bc742112c 100644 --- a/packages/generator/tests/utilities/measurements/non_streaming_data_measurement/__init__.py +++ b/packages/generator/tests/utilities/measurements/non_streaming_data_measurement/__init__.py @@ -13,7 +13,6 @@ service_directory = Path(__file__).resolve().parent measurement_service = nims.MeasurementService( service_config_path=service_directory / "NonStreamingDataMeasurement.serviceconfig", - version="0.1.0.0", ui_file_paths=[ service_directory, ], diff --git a/packages/generator/tests/utilities/measurements/pin_aware_measurement/PinAwareMeasurement.serviceconfig b/packages/generator/tests/utilities/measurements/pin_aware_measurement/PinAwareMeasurement.serviceconfig index 596293253..9c9049ffe 100644 --- a/packages/generator/tests/utilities/measurements/pin_aware_measurement/PinAwareMeasurement.serviceconfig +++ b/packages/generator/tests/utilities/measurements/pin_aware_measurement/PinAwareMeasurement.serviceconfig @@ -2,6 +2,7 @@ "services": [ { "displayName": "Pin Aware Measurement (Py)", + "version": "0.1.0.0", "serviceClass": "ni.tests.PinAwareMeasurement_Python", "descriptionUrl": "", "providedInterfaces": [ diff --git a/packages/generator/tests/utilities/measurements/pin_aware_measurement/__init__.py b/packages/generator/tests/utilities/measurements/pin_aware_measurement/__init__.py index aa8086b6d..152e2f60f 100644 --- a/packages/generator/tests/utilities/measurements/pin_aware_measurement/__init__.py +++ b/packages/generator/tests/utilities/measurements/pin_aware_measurement/__init__.py @@ -8,7 +8,6 @@ service_directory = pathlib.Path(__file__).resolve().parent measurement_service = nims.MeasurementService( service_config_path=service_directory / "PinAwareMeasurement.serviceconfig", - version="0.1.0.0", ui_file_paths=[ service_directory, ], diff --git a/packages/generator/tests/utilities/measurements/streaming_data_measurement/StreamingDataMeasurement.serviceconfig b/packages/generator/tests/utilities/measurements/streaming_data_measurement/StreamingDataMeasurement.serviceconfig index 73f621fbc..326eeabd0 100644 --- a/packages/generator/tests/utilities/measurements/streaming_data_measurement/StreamingDataMeasurement.serviceconfig +++ b/packages/generator/tests/utilities/measurements/streaming_data_measurement/StreamingDataMeasurement.serviceconfig @@ -2,6 +2,7 @@ "services": [ { "displayName": "Streaming Data Measurement (Py)", + "version": "0.1.0.0", "serviceClass": "ni.tests.StreamingDataMeasurement_Python", "descriptionUrl": "", "providedInterfaces": [ diff --git a/packages/generator/tests/utilities/measurements/streaming_data_measurement/__init__.py b/packages/generator/tests/utilities/measurements/streaming_data_measurement/__init__.py index 1180cb29b..ad35f7060 100644 --- a/packages/generator/tests/utilities/measurements/streaming_data_measurement/__init__.py +++ b/packages/generator/tests/utilities/measurements/streaming_data_measurement/__init__.py @@ -11,7 +11,6 @@ service_directory = pathlib.Path(__file__).resolve().parent measurement_service = nims.MeasurementService( service_config_path=service_directory / "StreamingDataMeasurement.serviceconfig", - version="0.1.0.0", ui_file_paths=[ service_directory, ], diff --git a/packages/generator/tests/utilities/measurements/void_measurement/VoidMeasurement.serviceconfig b/packages/generator/tests/utilities/measurements/void_measurement/VoidMeasurement.serviceconfig index aa9f6d38c..c23c1b602 100644 --- a/packages/generator/tests/utilities/measurements/void_measurement/VoidMeasurement.serviceconfig +++ b/packages/generator/tests/utilities/measurements/void_measurement/VoidMeasurement.serviceconfig @@ -2,6 +2,7 @@ "services": [ { "displayName": "Void Measurement (Py)", + "version": "0.1.0.0", "serviceClass": "ni.tests.VoidMeasurement_Python", "descriptionUrl": "", "providedInterfaces": [ diff --git a/packages/generator/tests/utilities/measurements/void_measurement/__init__.py b/packages/generator/tests/utilities/measurements/void_measurement/__init__.py index 8366f6b88..968460992 100644 --- a/packages/generator/tests/utilities/measurements/void_measurement/__init__.py +++ b/packages/generator/tests/utilities/measurements/void_measurement/__init__.py @@ -11,7 +11,6 @@ service_directory = Path(__file__).resolve().parent measurement_service = nims.MeasurementService( service_config_path=service_directory / "VoidMeasurement.serviceconfig", - version="0.1.0.0", ui_file_paths=[ service_directory, ], diff --git a/packages/sdk/pyproject.toml b/packages/sdk/pyproject.toml index b2bd3911a..3e988d8fc 100644 --- a/packages/sdk/pyproject.toml +++ b/packages/sdk/pyproject.toml @@ -1,6 +1,6 @@ [tool.poetry] name = "ni_measurement_plugin_sdk" -version = "2.1.0-dev1" +version = "2.1.0-dev2" description = "Measurement Plugin SDK for Python" authors = ["NI "] readme = "README.md" diff --git a/packages/service/ni_measurement_plugin_sdk_service/discovery/_client.py b/packages/service/ni_measurement_plugin_sdk_service/discovery/_client.py index 4fff624b3..e747798e3 100644 --- a/packages/service/ni_measurement_plugin_sdk_service/discovery/_client.py +++ b/packages/service/ni_measurement_plugin_sdk_service/discovery/_client.py @@ -206,7 +206,13 @@ def unregister_service(self, registration_id: str = "") -> bool: _logger.exception("Error in unregistering with discovery service.") raise - def resolve_service(self, provided_interface: str, service_class: str = "") -> ServiceLocation: + def resolve_service( + self, + provided_interface: str, + service_class: str = "", + deployment_target: str = "", + version: str = "", + ) -> ServiceLocation: """Resolve the location of a service. Given a description of a service, returns information that can be used to establish @@ -218,12 +224,18 @@ def resolve_service(self, provided_interface: str, service_class: str = "") -> S service_class: The service "class" that should be matched. If the value is not specified and there is more than one matching service registered, an error is returned. + deployment_target: The deployment target from which the service should be resolved. + version: The version of the service to resolve. If not specified, the latest version + will be resolved. Returns: The service location. """ request = discovery_service_pb2.ResolveServiceRequest( - provided_interface=provided_interface, service_class=service_class + provided_interface=provided_interface, + service_class=service_class, + deployment_target=deployment_target, + version=version, ) response = self._get_stub().ResolveService(request) diff --git a/packages/service/pyproject.toml b/packages/service/pyproject.toml index 41734ef7c..929d3312b 100644 --- a/packages/service/pyproject.toml +++ b/packages/service/pyproject.toml @@ -7,7 +7,7 @@ extend_exclude = '.tox/,*_pb2_grpc.py,*_pb2_grpc.pyi,*_pb2.py,*_pb2.pyi,ni_measu [tool.poetry] name = "ni_measurement_plugin_sdk_service" -version = "2.1.0-dev1" +version = "2.1.0-dev2" description = "Measurement Plugin Support for Python" authors = ["NI "] readme = "README.md" # apply the repo readme to the package as well diff --git a/packages/service/tests/unit/test_discovery_client.py b/packages/service/tests/unit/test_discovery_client.py index 6e2b4d651..4e52494cb 100644 --- a/packages/service/tests/unit/test_discovery_client.py +++ b/packages/service/tests/unit/test_discovery_client.py @@ -118,7 +118,7 @@ def test___service_registered___unregister_service___sends_request( assert unregistration_success_flag -def test___service_registered___resolve_service___sends_request( +def test___service_registered___resolve_service_without_version___sends_request( discovery_client: DiscoveryClient, discovery_service_stub: Mock ): discovery_service_stub.ResolveService.return_value = GrpcServiceLocation( @@ -138,6 +138,29 @@ def test___service_registered___resolve_service___sends_request( _assert_service_location_equal(_TEST_SERVICE_LOCATION, service_location) +def test___service_registered___resolve_service_with_version___sends_request( + discovery_client: DiscoveryClient, discovery_service_stub: Mock +): + discovery_service_stub.ResolveService.return_value = GrpcServiceLocation( + location=_TEST_SERVICE_LOCATION.location, + insecure_port=_TEST_SERVICE_LOCATION.insecure_port, + ssl_authenticated_port=_TEST_SERVICE_LOCATION.ssl_authenticated_port, + ) + + service_location = discovery_client.resolve_service( + provided_interface=_TEST_SERVICE_INFO.provided_interfaces[0], + service_class=_TEST_SERVICE_INFO.service_class, + version=_TEST_SERVICE_INFO.versions[0], + ) + + discovery_service_stub.ResolveService.assert_called_once() + request: ResolveServiceRequest = discovery_service_stub.ResolveService.call_args.args[0] + assert _TEST_SERVICE_INFO.provided_interfaces[0] == request.provided_interface + assert _TEST_SERVICE_INFO.service_class == request.service_class + assert _TEST_SERVICE_INFO.versions[0] == request.version + _assert_service_location_equal(_TEST_SERVICE_LOCATION, service_location) + + def test___service_not_registered___resolve_service___raises_not_found_error( discovery_client: DiscoveryClient, discovery_service_stub: Mock ):