Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Configure stack trace rules for Unreal Engine #669

Open
tustanivsky opened this issue Oct 30, 2024 · 2 comments · May be fixed by getsentry/sentry#83813 or #744
Open

Configure stack trace rules for Unreal Engine #669

tustanivsky opened this issue Oct 30, 2024 · 2 comments · May be fixed by getsentry/sentry#83813 or #744

Comments

@tustanivsky
Copy link
Collaborator

tustanivsky commented Oct 30, 2024

Currently, we're cutting off some redundant stack frames within the SDK to resolve #489 and #514. Enhancing configs here should help us to avoid modifying callstack on Unreal's side of things entirely and mark these frames as such that have to be excluded automatically.

For instance, before #537 the callstack for assertion events on Windows looked like this:

Image

The five topmost frames in the above example (event link 1) reflect a part of UE error processing flow and are always the same for all assertions which lead to invalid issue grouping.

Here's a similar example for Android.

Additionally, capturing simple events (event link 2) via the plugin's API introduces similar problem however this time the topmost frames belong to Sentry SDK itself (i.e. USentrySubsystem, USentrySubsystemDesktop and others):

Image

@tustanivsky
Copy link
Collaborator Author

With the following issue grouping rules we can remove the client-side logic for cutting off redundant callstack frames while preserving the ability to group Unreal events properly:

# remove all frames related to Unreal assertion handling
stack.function:FDebug::CheckVerifyFailedImpl* ^-app -app v+app ^-group -group v+group

# remove all frames related to Unreal ensure handling
stack.function:UE::Assert::Private::ExecCheckImplInternal* ^-app -app v+app ^-group -group v+group

# remove all frames related to USentrySubsystem event capturing
stack.function:USentrySubsystem::CaptureMessage* ^-app -app v+app ^-group -group v+group
stack.function:USentrySubsystem::CaptureMessageWithScope* ^-app -app v+app ^-group -group v+group
stack.function:USentrySubsystem::CaptureEvent* ^-app -app v+app ^-group -group v+group
stack.function:USentrySubsystem::CaptureEventWithScope* ^-app -app v+app ^-group -group v+group
stack.function:USentrySubsystem::*execCapture* ^-app -app v+app ^-group -group v+group

@tustanivsky
Copy link
Collaborator Author

Here's a PR that sets the above rules as default at Sentry - getsentry/sentry#83813

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
Status: No status
1 participant