Skip to content

Commit

Permalink
Adds breadcrumb origin field (#3727)
Browse files Browse the repository at this point in the history
* Adds breadcrumb origin field

* Updates api dump

* Updates test cases

* Updates serialisation tests

* Adds changelog

* Exclude testfairy from obfuscation

* Revert "Exclude testfairy from obfuscation"

This reverts commit 9900d1e.

* Exclude any testfairy touchlistener static fields from LeakCanary

---------

Co-authored-by: Markus Hintersteiner <[email protected]>
  • Loading branch information
antonis and markushi authored Oct 1, 2024
1 parent b11dc55 commit 7e57220
Show file tree
Hide file tree
Showing 13 changed files with 68 additions and 7 deletions.
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@
### Features

- Add support for `feedback` envelope header item type ([#3687](https://github.com/getsentry/sentry-java/pull/3687))
- Add breadcrumb.origin field ([#3727](https://github.com/getsentry/sentry-java/pull/3727))

### Fixes

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -179,14 +179,15 @@ class SdkInitTests : BaseUiTest() {
"com.saucelabs.rdcinjector.testfairy.TestFairyEventQueue",
"context"
)
),
IgnoredReferenceMatcher(
ReferencePattern.StaticFieldPattern(
"com.testfairy.modules.capture.TouchListener",
"k"
)
)
) + ('a'..'z').map { char ->
IgnoredReferenceMatcher(
ReferencePattern.StaticFieldPattern(
"com.testfairy.modules.capture.TouchListener",
"$char"
)
)
}
)

val activityScenario = launchActivity<ComposeActivity>()
Expand Down
3 changes: 3 additions & 0 deletions sentry/api/sentry.api
Original file line number Diff line number Diff line change
Expand Up @@ -109,6 +109,7 @@ public final class io/sentry/Breadcrumb : io/sentry/JsonSerializable, io/sentry/
public fun getData (Ljava/lang/String;)Ljava/lang/Object;
public fun getLevel ()Lio/sentry/SentryLevel;
public fun getMessage ()Ljava/lang/String;
public fun getOrigin ()Ljava/lang/String;
public fun getTimestamp ()Ljava/util/Date;
public fun getType ()Ljava/lang/String;
public fun getUnknown ()Ljava/util/Map;
Expand All @@ -127,6 +128,7 @@ public final class io/sentry/Breadcrumb : io/sentry/JsonSerializable, io/sentry/
public fun setData (Ljava/lang/String;Ljava/lang/Object;)V
public fun setLevel (Lio/sentry/SentryLevel;)V
public fun setMessage (Ljava/lang/String;)V
public fun setOrigin (Ljava/lang/String;)V
public fun setType (Ljava/lang/String;)V
public fun setUnknown (Ljava/util/Map;)V
public static fun transaction (Ljava/lang/String;)Lio/sentry/Breadcrumb;
Expand All @@ -148,6 +150,7 @@ public final class io/sentry/Breadcrumb$JsonKeys {
public static final field DATA Ljava/lang/String;
public static final field LEVEL Ljava/lang/String;
public static final field MESSAGE Ljava/lang/String;
public static final field ORIGIN Ljava/lang/String;
public static final field TIMESTAMP Ljava/lang/String;
public static final field TYPE Ljava/lang/String;
public fun <init> ()V
Expand Down
42 changes: 41 additions & 1 deletion sentry/src/main/java/io/sentry/Breadcrumb.java
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,12 @@ public final class Breadcrumb implements JsonUnknown, JsonSerializable {
/** Dotted strings that indicate what the crumb is or where it comes from. */
private @Nullable String category;

/**
* Origin of the breadcrumb that is used to identify source of the breadcrumb. For example hybrid
* SDKs can identify native breadcrumbs from JS or Flutter.
*/
private @Nullable String origin;

/** The level of the event. */
private @Nullable SentryLevel level;

Expand All @@ -54,6 +60,7 @@ public Breadcrumb(final @NotNull Date timestamp) {
this.message = breadcrumb.message;
this.type = breadcrumb.type;
this.category = breadcrumb.category;
this.origin = breadcrumb.origin;
final Map<String, Object> dataClone = CollectionUtils.newConcurrentHashMap(breadcrumb.data);
if (dataClone != null) {
this.data = dataClone;
Expand All @@ -78,6 +85,7 @@ public static Breadcrumb fromMap(
String type = null;
@NotNull Map<String, Object> data = new ConcurrentHashMap<>();
String category = null;
String origin = null;
SentryLevel level = null;
Map<String, Object> unknown = null;

Expand Down Expand Up @@ -116,6 +124,9 @@ public static Breadcrumb fromMap(
case JsonKeys.CATEGORY:
category = (value instanceof String) ? (String) value : null;
break;
case JsonKeys.ORIGIN:
origin = (value instanceof String) ? (String) value : null;
break;
case JsonKeys.LEVEL:
String levelString = (value instanceof String) ? (String) value : null;
if (levelString != null) {
Expand All @@ -140,6 +151,7 @@ public static Breadcrumb fromMap(
breadcrumb.type = type;
breadcrumb.data = data;
breadcrumb.category = category;
breadcrumb.origin = origin;
breadcrumb.level = level;

breadcrumb.setUnknown(unknown);
Expand Down Expand Up @@ -610,6 +622,24 @@ public void setCategory(@Nullable String category) {
this.category = category;
}

/**
* Returns the origin
*
* @return the origin
*/
public @Nullable String getOrigin() {
return origin;
}

/**
* Sets the origin
*
* @param origin the origin
*/
public void setOrigin(@Nullable String origin) {
this.origin = origin;
}

/**
* Returns the SentryLevel
*
Expand Down Expand Up @@ -638,12 +668,13 @@ public boolean equals(Object o) {
&& Objects.equals(message, that.message)
&& Objects.equals(type, that.type)
&& Objects.equals(category, that.category)
&& Objects.equals(origin, that.origin)
&& level == that.level;
}

@Override
public int hashCode() {
return Objects.hash(timestamp, message, type, category, level);
return Objects.hash(timestamp, message, type, category, origin, level);
}

// region json
Expand All @@ -665,6 +696,7 @@ public static final class JsonKeys {
public static final String TYPE = "type";
public static final String DATA = "data";
public static final String CATEGORY = "category";
public static final String ORIGIN = "origin";
public static final String LEVEL = "level";
}

Expand All @@ -683,6 +715,9 @@ public void serialize(final @NotNull ObjectWriter writer, final @NotNull ILogger
if (category != null) {
writer.name(JsonKeys.CATEGORY).value(category);
}
if (origin != null) {
writer.name(JsonKeys.ORIGIN).value(origin);
}
if (level != null) {
writer.name(JsonKeys.LEVEL).value(logger, level);
}
Expand All @@ -707,6 +742,7 @@ public static final class Deserializer implements JsonDeserializer<Breadcrumb> {
String type = null;
@NotNull Map<String, Object> data = new ConcurrentHashMap<>();
String category = null;
String origin = null;
SentryLevel level = null;

Map<String, Object> unknown = null;
Expand Down Expand Up @@ -736,6 +772,9 @@ public static final class Deserializer implements JsonDeserializer<Breadcrumb> {
case JsonKeys.CATEGORY:
category = reader.nextStringOrNull();
break;
case JsonKeys.ORIGIN:
origin = reader.nextStringOrNull();
break;
case JsonKeys.LEVEL:
try {
level = new SentryLevel.Deserializer().deserialize(reader, logger);
Expand All @@ -757,6 +796,7 @@ public static final class Deserializer implements JsonDeserializer<Breadcrumb> {
breadcrumb.type = type;
breadcrumb.data = data;
breadcrumb.category = category;
breadcrumb.origin = origin;
breadcrumb.level = level;

breadcrumb.setUnknown(unknown);
Expand Down
6 changes: 6 additions & 0 deletions sentry/src/test/java/io/sentry/BreadcrumbTest.kt
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@ class BreadcrumbTest {
val level = SentryLevel.DEBUG
breadcrumb.level = level
breadcrumb.category = "category"
breadcrumb.origin = "origin"

val clone = Breadcrumb(breadcrumb)

Expand All @@ -44,6 +45,7 @@ class BreadcrumbTest {
val level = SentryLevel.DEBUG
breadcrumb.level = level
breadcrumb.category = "category"
breadcrumb.origin = "origin"

val clone = Breadcrumb(breadcrumb)

Expand All @@ -53,6 +55,7 @@ class BreadcrumbTest {
assertEquals("type", clone.type)
assertEquals(SentryLevel.DEBUG, clone.level)
assertEquals("category", clone.category)
assertEquals("origin", clone.origin)
}

@Test
Expand All @@ -67,6 +70,7 @@ class BreadcrumbTest {
val level = SentryLevel.DEBUG
breadcrumb.level = level
breadcrumb.category = "category"
breadcrumb.origin = "origin"

val clone = Breadcrumb(breadcrumb)

Expand All @@ -77,6 +81,7 @@ class BreadcrumbTest {
breadcrumb.type = "newType"
breadcrumb.level = SentryLevel.FATAL
breadcrumb.category = "newCategory"
breadcrumb.origin = "newOrigin"

assertEquals("message", clone.message)
assertEquals("data", clone.data["data"])
Expand All @@ -86,6 +91,7 @@ class BreadcrumbTest {
assertEquals("type", clone.type)
assertEquals(SentryLevel.DEBUG, clone.level)
assertEquals("category", clone.category)
assertEquals("origin", clone.origin)
}

@Test
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,7 @@ class BreadcrumbSerializationTest {
type = "ace57e2e-305e-4048-abf0-6c8538ea7bf4"
setData("6607d106-d426-462b-af74-f29fce978e48", "149bb94a-1387-4484-90be-2df15d1322ab")
category = "b6eea851-5ae5-40ed-8fdd-5e1a655a879c"
origin = "4d8085ef-22fc-49d5-801e-55d509fd1a1c"
level = SentryLevel.DEBUG
}
}
Expand Down Expand Up @@ -59,6 +60,7 @@ class BreadcrumbSerializationTest {
"6607d106-d426-462b-af74-f29fce978e48" to "149bb94a-1387-4484-90be-2df15d1322ab"
),
"category" to "b6eea851-5ae5-40ed-8fdd-5e1a655a879c",
"origin" to "4d8085ef-22fc-49d5-801e-55d509fd1a1c",
"level" to "debug"
)
val actual = Breadcrumb.fromMap(map, SentryOptions())
Expand All @@ -69,6 +71,7 @@ class BreadcrumbSerializationTest {
assertEquals(expected.type, actual?.type)
assertEquals(expected.data, actual?.data)
assertEquals(expected.category, actual?.category)
assertEquals(expected.origin, actual?.origin)
assertEquals(expected.level, actual?.level)
}

Expand Down
1 change: 1 addition & 0 deletions sentry/src/test/resources/json/breadcrumb.json
Original file line number Diff line number Diff line change
Expand Up @@ -7,5 +7,6 @@
"6607d106-d426-462b-af74-f29fce978e48": "149bb94a-1387-4484-90be-2df15d1322ab"
},
"category": "b6eea851-5ae5-40ed-8fdd-5e1a655a879c",
"origin": "4d8085ef-22fc-49d5-801e-55d509fd1a1c",
"level": "debug"
}
1 change: 1 addition & 0 deletions sentry/src/test/resources/json/sentry_base_event.json
Original file line number Diff line number Diff line change
Expand Up @@ -207,6 +207,7 @@
"6607d106-d426-462b-af74-f29fce978e48": "149bb94a-1387-4484-90be-2df15d1322ab"
},
"category": "b6eea851-5ae5-40ed-8fdd-5e1a655a879c",
"origin": "4d8085ef-22fc-49d5-801e-55d509fd1a1c",
"level": "debug"
}
],
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -207,6 +207,7 @@
"6607d106-d426-462b-af74-f29fce978e48": "149bb94a-1387-4484-90be-2df15d1322ab"
},
"category": "b6eea851-5ae5-40ed-8fdd-5e1a655a879c",
"origin": "4d8085ef-22fc-49d5-801e-55d509fd1a1c",
"level": "debug"
}
],
Expand Down
1 change: 1 addition & 0 deletions sentry/src/test/resources/json/sentry_event.json
Original file line number Diff line number Diff line change
Expand Up @@ -342,6 +342,7 @@
"6607d106-d426-462b-af74-f29fce978e48": "149bb94a-1387-4484-90be-2df15d1322ab"
},
"category": "b6eea851-5ae5-40ed-8fdd-5e1a655a879c",
"origin": "4d8085ef-22fc-49d5-801e-55d509fd1a1c",
"level": "debug"
}
],
Expand Down
1 change: 1 addition & 0 deletions sentry/src/test/resources/json/sentry_transaction.json
Original file line number Diff line number Diff line change
Expand Up @@ -290,6 +290,7 @@
"6607d106-d426-462b-af74-f29fce978e48": "149bb94a-1387-4484-90be-2df15d1322ab"
},
"category": "b6eea851-5ae5-40ed-8fdd-5e1a655a879c",
"origin": "4d8085ef-22fc-49d5-801e-55d509fd1a1c",
"level": "debug"
}
],
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -290,6 +290,7 @@
"6607d106-d426-462b-af74-f29fce978e48": "149bb94a-1387-4484-90be-2df15d1322ab"
},
"category": "b6eea851-5ae5-40ed-8fdd-5e1a655a879c",
"origin": "4d8085ef-22fc-49d5-801e-55d509fd1a1c",
"level": "debug"
}
],
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -257,6 +257,7 @@
"6607d106-d426-462b-af74-f29fce978e48": "149bb94a-1387-4484-90be-2df15d1322ab"
},
"category": "b6eea851-5ae5-40ed-8fdd-5e1a655a879c",
"origin": "4d8085ef-22fc-49d5-801e-55d509fd1a1c",
"level": "debug"
}
],
Expand Down

0 comments on commit 7e57220

Please sign in to comment.