sentry-arroyo 2.31.0__tar.gz → 2.31.1__tar.gz
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- {sentry_arroyo-2.31.0/sentry_arroyo.egg-info → sentry_arroyo-2.31.1}/PKG-INFO +1 -1
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/arroyo/backends/kafka/consumer.py +6 -1
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1/sentry_arroyo.egg-info}/PKG-INFO +1 -1
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/setup.py +1 -1
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/tests/backends/test_confluent_producer.py +16 -4
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/LICENSE +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/MANIFEST.in +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/README.md +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/arroyo/__init__.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/arroyo/backends/__init__.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/arroyo/backends/abstract.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/arroyo/backends/kafka/__init__.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/arroyo/backends/kafka/commit.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/arroyo/backends/kafka/configuration.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/arroyo/backends/local/__init__.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/arroyo/backends/local/backend.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/arroyo/backends/local/storages/__init__.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/arroyo/backends/local/storages/abstract.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/arroyo/backends/local/storages/memory.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/arroyo/commit.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/arroyo/dlq.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/arroyo/errors.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/arroyo/processing/__init__.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/arroyo/processing/processor.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/arroyo/processing/strategies/__init__.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/arroyo/processing/strategies/abstract.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/arroyo/processing/strategies/batching.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/arroyo/processing/strategies/buffer.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/arroyo/processing/strategies/commit.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/arroyo/processing/strategies/filter.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/arroyo/processing/strategies/guard.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/arroyo/processing/strategies/healthcheck.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/arroyo/processing/strategies/noop.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/arroyo/processing/strategies/produce.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/arroyo/processing/strategies/reduce.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/arroyo/processing/strategies/run_task.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/arroyo/processing/strategies/run_task_in_threads.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/arroyo/processing/strategies/run_task_with_multiprocessing.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/arroyo/processing/strategies/unfold.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/arroyo/py.typed +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/arroyo/types.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/arroyo/utils/__init__.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/arroyo/utils/clock.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/arroyo/utils/codecs.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/arroyo/utils/concurrent.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/arroyo/utils/logging.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/arroyo/utils/metricDefs.json +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/arroyo/utils/metric_defs.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/arroyo/utils/metrics.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/arroyo/utils/profiler.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/arroyo/utils/retries.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/examples/transform_and_produce/__init__.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/examples/transform_and_produce/batched.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/examples/transform_and_produce/script.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/examples/transform_and_produce/simple.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/requirements.txt +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/sentry_arroyo.egg-info/SOURCES.txt +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/sentry_arroyo.egg-info/dependency_links.txt +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/sentry_arroyo.egg-info/not-zip-safe +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/sentry_arroyo.egg-info/requires.txt +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/sentry_arroyo.egg-info/top_level.txt +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/setup.cfg +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/tests/backends/__init__.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/tests/backends/mixins.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/tests/backends/test_commit.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/tests/backends/test_kafka.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/tests/backends/test_kafka_producer.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/tests/backends/test_local.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/tests/processing/__init__.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/tests/processing/strategies/__init__.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/tests/processing/strategies/test_all.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/tests/processing/strategies/test_batching.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/tests/processing/strategies/test_buffer.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/tests/processing/strategies/test_commit.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/tests/processing/strategies/test_filter.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/tests/processing/strategies/test_guard.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/tests/processing/strategies/test_noop.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/tests/processing/strategies/test_produce.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/tests/processing/strategies/test_reduce.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/tests/processing/strategies/test_run_task.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/tests/processing/strategies/test_run_task_in_threads.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/tests/processing/strategies/test_run_task_with_multiprocessing.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/tests/processing/strategies/test_unfold.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/tests/processing/test_processor.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/tests/test_commit.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/tests/test_dlq.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/tests/test_kip848_e2e.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/tests/test_types.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/tests/utils/__init__.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/tests/utils/test_concurrent.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/tests/utils/test_metrics.py +0 -0
- {sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/tests/utils/test_retries.py +0 -0
|
@@ -757,6 +757,7 @@ class ConfluentProducer(ConfluentKafkaProducer): # type: ignore[misc]
|
|
|
757
757
|
def __init__(self, configuration: Mapping[str, Any]) -> None:
|
|
758
758
|
super().__init__(configuration)
|
|
759
759
|
self.__metrics = get_metrics()
|
|
760
|
+
self.producer_name = configuration.get("client.id") or None
|
|
760
761
|
|
|
761
762
|
def __metrics_delivery_callback(
|
|
762
763
|
self,
|
|
@@ -768,10 +769,14 @@ class ConfluentProducer(ConfluentKafkaProducer): # type: ignore[misc]
|
|
|
768
769
|
else:
|
|
769
770
|
status = "success"
|
|
770
771
|
|
|
772
|
+
tags = {"status": status}
|
|
773
|
+
if self.producer_name:
|
|
774
|
+
tags["producer_name"] = self.producer_name
|
|
775
|
+
|
|
771
776
|
self.__metrics.increment(
|
|
772
777
|
"arroyo.producer.produce_status",
|
|
773
778
|
1,
|
|
774
|
-
tags=
|
|
779
|
+
tags=tags,
|
|
775
780
|
)
|
|
776
781
|
|
|
777
782
|
def __delivery_callback(
|
|
@@ -24,11 +24,17 @@ class TestConfluentProducer:
|
|
|
24
24
|
|
|
25
25
|
def test_metrics_callback_records_success(self) -> None:
|
|
26
26
|
"""Test that the metrics callback records success metric"""
|
|
27
|
-
producer = ConfluentProducer(
|
|
27
|
+
producer = ConfluentProducer(
|
|
28
|
+
{"bootstrap.servers": "fake:9092", "client.id": "test-producer-name"}
|
|
29
|
+
)
|
|
28
30
|
mock_message = mock.Mock(spec=ConfluentMessage)
|
|
29
31
|
producer._ConfluentProducer__metrics_delivery_callback(None, mock_message)
|
|
30
32
|
assert (
|
|
31
|
-
Increment(
|
|
33
|
+
Increment(
|
|
34
|
+
"arroyo.producer.produce_status",
|
|
35
|
+
1,
|
|
36
|
+
{"status": "success", "producer_name": "test-producer-name"},
|
|
37
|
+
)
|
|
32
38
|
in TestingMetricsBackend.calls
|
|
33
39
|
)
|
|
34
40
|
|
|
@@ -45,7 +51,9 @@ class TestConfluentProducer:
|
|
|
45
51
|
|
|
46
52
|
def test_delivery_callback_wraps_user_callback(self) -> None:
|
|
47
53
|
"""Test that the delivery callback wrapper calls both metrics and user callbacks"""
|
|
48
|
-
producer = ConfluentProducer(
|
|
54
|
+
producer = ConfluentProducer(
|
|
55
|
+
{"bootstrap.servers": "fake:9092", "client.id": "test-producer-name"}
|
|
56
|
+
)
|
|
49
57
|
user_callback_invoked = []
|
|
50
58
|
|
|
51
59
|
def user_callback(
|
|
@@ -57,7 +65,11 @@ class TestConfluentProducer:
|
|
|
57
65
|
mock_message = mock.Mock(spec=ConfluentMessage)
|
|
58
66
|
wrapped(None, mock_message)
|
|
59
67
|
assert (
|
|
60
|
-
Increment(
|
|
68
|
+
Increment(
|
|
69
|
+
"arroyo.producer.produce_status",
|
|
70
|
+
1,
|
|
71
|
+
{"status": "success", "producer_name": "test-producer-name"},
|
|
72
|
+
)
|
|
61
73
|
in TestingMetricsBackend.calls
|
|
62
74
|
)
|
|
63
75
|
assert len(user_callback_invoked) == 1
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{sentry_arroyo-2.31.0 → sentry_arroyo-2.31.1}/arroyo/processing/strategies/run_task_in_threads.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|