Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions sentry_sdk/consts.py
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@
"ignore_errors": [],
"request_bodies": "medium",
"before_send": None,
"before_breadcrumb": None,
"debug": False,
}

Expand Down
11 changes: 11 additions & 0 deletions sentry_sdk/hub.py
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
import sys
import copy
from datetime import datetime
from contextlib import contextmanager

from ._compat import with_metaclass
Expand Down Expand Up @@ -158,6 +159,16 @@ def add_breadcrumb(self, *args, **kwargs):
crumb = args[0]()
else:
crumb = dict(*args, **kwargs)
if crumb is None:
return

if crumb.get("timestamp") is None:
crumb["timestamp"] = datetime.utcnow()
if crumb.get("type") is None:
crumb["type"] = "default"

if client.options["before_breadcrumb"] is not None:
crumb = client.options["before_breadcrumb"](crumb)

if crumb is not None:
scope._breadcrumbs.append(crumb)
Expand Down
48 changes: 47 additions & 1 deletion tests/test_basics.py
Original file line number Diff line number Diff line change
@@ -1,4 +1,10 @@
from sentry_sdk import configure_scope, capture_exception, last_event_id, Hub
from sentry_sdk import (
configure_scope,
capture_exception,
add_breadcrumb,
last_event_id,
Hub,
)


def test_processors(sentry_init, capture_events):
Expand Down Expand Up @@ -38,3 +44,43 @@ def test_event_id(sentry_init, capture_events):
assert event["event_id"] == event_id
assert last_event_id() == event_id
assert Hub.current.last_event_id() == event_id


def test_option_callback(sentry_init, capture_events):
drop_events = False
drop_breadcrumbs = False

def before_send(event):
if not drop_events:
event["extra"] = {"foo": "bar"}
return event

def before_breadcrumb(crumb):
if not drop_breadcrumbs:
crumb["data"] = {"foo": "bar"}
return crumb

sentry_init(before_send=before_send, before_breadcrumb=before_breadcrumb)
events = capture_events()

def do_this():
add_breadcrumb(message="Hello")
try:
raise ValueError("aha!")
except Exception:
capture_exception()

do_this()
drop_breadcrumbs = True
do_this()
drop_events = True
do_this()

normal, no_crumbs = events

assert normal["exception"]["values"][0]["type"] == "ValueError"
crumb, = normal["breadcrumbs"]
assert "timestamp" in crumb
assert crumb["message"] == "Hello"
assert crumb["data"] == {"foo": "bar"}
assert crumb["type"] == "default"