From 52e633048e7b87ec423949f55fae1fbb07786405 Mon Sep 17 00:00:00 2001 From: Ran Nozik Date: Mon, 20 Dec 2021 17:51:47 +0200 Subject: [PATCH] take version from pika --- .../instrumentation/pika/pika_instrumentor.py | 32 ++++++++----------- .../tests/test_pika_instrumentation.py | 4 +-- 2 files changed, 16 insertions(+), 20 deletions(-) diff --git a/instrumentation/opentelemetry-instrumentation-pika/src/opentelemetry/instrumentation/pika/pika_instrumentor.py b/instrumentation/opentelemetry-instrumentation-pika/src/opentelemetry/instrumentation/pika/pika_instrumentor.py index 879ad0609d..0168cf0d47 100644 --- a/instrumentation/opentelemetry-instrumentation-pika/src/opentelemetry/instrumentation/pika/pika_instrumentor.py +++ b/instrumentation/opentelemetry-instrumentation-pika/src/opentelemetry/instrumentation/pika/pika_instrumentor.py @@ -14,9 +14,9 @@ from logging import getLogger from typing import Any, Collection, Dict, Optional -import pkg_resources import wrapt from packaging import version +import pika from pika.adapters import BlockingConnection from pika.adapters.blocking_connection import BlockingChannel @@ -34,7 +34,18 @@ _FUNCTIONS_TO_UNINSTRUMENT = ["basic_publish"] +def _consumer_callback_attribute_name() -> str: + pika_version = version.parse(pika.__version__) + return ( + "on_message_callback" + if pika_version >= version.parse("1.0.0") + else "consumer_cb" + ) + + class PikaInstrumentor(BaseInstrumentor): # type: ignore + CONSUMER_CALLBACK_ATTR = _consumer_callback_attribute_name() + # pylint: disable=attribute-defined-outside-init @staticmethod def _instrument_blocking_channel_consumers( @@ -43,9 +54,7 @@ def _instrument_blocking_channel_consumers( consume_hook: utils.HookT = utils.dummy_callback, ) -> Any: for consumer_tag, consumer_info in channel._consumer_infos.items(): - callback_attr = ( - PikaInstrumentor._consumer_callback_attribute_name() - ) + callback_attr = PikaInstrumentor.CONSUMER_CALLBACK_ATTR consumer_callback = getattr(consumer_info, callback_attr) decorated_callback = utils._decorate_callback( consumer_callback, @@ -132,9 +141,7 @@ def uninstrument_channel(channel: BlockingChannel) -> None: return for consumers_tag, client_info in channel._consumer_infos.items(): - callback_attr = ( - PikaInstrumentor._consumer_callback_attribute_name() - ) + callback_attr = PikaInstrumentor.CONSUMER_CALLBACK_ATTR consumer_callback = getattr(client_info, callback_attr) if hasattr(consumer_callback, "_original_callback"): channel._consumer_infos[ @@ -142,17 +149,6 @@ def uninstrument_channel(channel: BlockingChannel) -> None: ] = consumer_callback._original_callback PikaInstrumentor._uninstrument_channel_functions(channel) - @staticmethod - def _consumer_callback_attribute_name() -> str: - pika_version = version.parse( - pkg_resources.get_distribution("pika").version - ) - return ( - "on_message_callback" - if pika_version >= version.parse("1.0.0") - else "consumer_cb" - ) - def _decorate_channel_function( self, tracer_provider: Optional[TracerProvider], diff --git a/instrumentation/opentelemetry-instrumentation-pika/tests/test_pika_instrumentation.py b/instrumentation/opentelemetry-instrumentation-pika/tests/test_pika_instrumentation.py index 3e949c43ab..3c176f21d0 100644 --- a/instrumentation/opentelemetry-instrumentation-pika/tests/test_pika_instrumentation.py +++ b/instrumentation/opentelemetry-instrumentation-pika/tests/test_pika_instrumentation.py @@ -26,7 +26,7 @@ class TestPika(TestCase): def setUp(self) -> None: self.channel = mock.MagicMock(spec=Channel) consumer_info = mock.MagicMock() - callback_attr = PikaInstrumentor._consumer_callback_attribute_name() + callback_attr = PikaInstrumentor.CONSUMER_CALLBACK_ATTR setattr(consumer_info, callback_attr, mock.MagicMock()) self.channel._consumer_infos = {"consumer-tag": consumer_info} self.mock_callback = mock.MagicMock() @@ -73,7 +73,7 @@ def test_instrument_consumers( self, decorate_callback: mock.MagicMock ) -> None: tracer = mock.MagicMock(spec=Tracer) - callback_attr = PikaInstrumentor._consumer_callback_attribute_name() + callback_attr = PikaInstrumentor.CONSUMER_CALLBACK_ATTR expected_decoration_calls = [ mock.call( getattr(value, callback_attr), tracer, key, dummy_callback