From 69866bed73c9a4625391b4d17c2813fd5bd40e85 Mon Sep 17 00:00:00 2001 From: Daniel Szoke Date: Mon, 31 Jul 2023 10:34:10 +0200 Subject: [PATCH] Always sample checkin regardless of sample_rate (#2279) * Always sample checkin regardless of sample_rate * Added test case for cron check-in * Test for sample rate affecting errors --- sentry_sdk/client.py | 8 ++++++-- tests/test_crons.py | 12 ++++++++++++ tests/tracing/test_sampling.py | 14 +++++++++++++- 3 files changed, 31 insertions(+), 3 deletions(-) diff --git a/sentry_sdk/client.py b/sentry_sdk/client.py index 9dd541658d..02006e9439 100644 --- a/sentry_sdk/client.py +++ b/sentry_sdk/client.py @@ -530,12 +530,16 @@ def capture_event( self._update_session_from_event(session, event) is_transaction = event_opt.get("type") == "transaction" + is_checkin = event_opt.get("type") == "check_in" - if not is_transaction and not self._should_sample_error(event): + if ( + not is_transaction + and not is_checkin + and not self._should_sample_error(event) + ): return None tracing_enabled = has_tracing_enabled(self.options) - is_checkin = event_opt.get("type") == "check_in" attachments = hint.get("attachments") trace_context = event_opt.get("contexts", {}).get("trace") or {} diff --git a/tests/test_crons.py b/tests/test_crons.py index 7688ac8a72..5bdeb6ce5e 100644 --- a/tests/test_crons.py +++ b/tests/test_crons.py @@ -81,6 +81,18 @@ def test_capture_checkin_simple(sentry_init): assert check_in_id == "112233" +def test_sample_rate_doesnt_affect_crons(sentry_init, capture_envelopes): + sentry_init(sample_rate=0) + envelopes = capture_envelopes() + + capture_checkin(check_in_id="112233") + + assert len(envelopes) == 1 + + check_in = envelopes[0].items[0].payload.json + assert check_in["check_in_id"] == "112233" + + def test_capture_checkin_new_id(sentry_init): sentry_init() diff --git a/tests/tracing/test_sampling.py b/tests/tracing/test_sampling.py index 376a4e09dc..6101a948ef 100644 --- a/tests/tracing/test_sampling.py +++ b/tests/tracing/test_sampling.py @@ -2,7 +2,7 @@ import pytest -from sentry_sdk import Hub, start_span, start_transaction +from sentry_sdk import Hub, start_span, start_transaction, capture_exception from sentry_sdk.tracing import Transaction from sentry_sdk.utils import logger @@ -226,6 +226,18 @@ def test_passes_custom_samling_context_from_start_transaction_to_traces_sampler( ) +def test_sample_rate_affects_errors(sentry_init, capture_events): + sentry_init(sample_rate=0) + events = capture_events() + + try: + 1 / 0 + except Exception: + capture_exception() + + assert len(events) == 0 + + @pytest.mark.parametrize( "traces_sampler_return_value", [