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

Tweak in_app rules for events from Python SDK #79482

Open
sentrivana opened this issue Oct 22, 2024 · 2 comments
Open

Tweak in_app rules for events from Python SDK #79482

sentrivana opened this issue Oct 22, 2024 · 2 comments

Comments

@sentrivana
Copy link
Contributor

sentrivana commented Oct 22, 2024

When viewing a stacktrace in Sentry, frames are marked as either in_app or not in_app. Non-in-app frames are collapsed by default. The original in_app decision comes from the SDK; however, at the moment Sentry can't rely on the in_app decision from the SDK and has rules for overriding it.

Two things we can do about this:

  1. On the Sentry side, remove the redundant checks that set a frame as not in-app if the package is coming from site-packages or dist-packages. We already check this on the SDK side. Having this rule on the server side means that it sometimes overrides a higher prio decision (e.g., the user explicitly set their in_app_include to include the module).
  2. On the SDK side, look into frames with unexpected in_app values and fix the underlying issues. Tracked here: Improve in_app detection sentry-python#3682
@armenzg
Copy link
Member

armenzg commented Oct 22, 2024

Given the current event [1] we want to end up with this:

               "abs_path": "/app/python/site-packages/foo/bar.py",
-              "in_app": false,
-              "data": {
-                "orig_in_app": 1
+              "in_app": true
              }

[1]

{
  "exception": {
    "values": [
      {
        "stacktrace": {
          "frames": [
            {
              "abs_path": "/app/python/site-packages/foo/__main__.py",
              "in_app": false
            },
            {
              "abs_path": "/app/python/site-packages/click/core.py",
              "in_app": false
            },
            {
              "abs_path": "/app/python/site-packages/foo/bar.py",
              "in_app": false,
              "data": {
                "orig_in_app": 1
              }
            }
          ]
        }
      }
    ]
  }
}

@armenzg
Copy link
Member

armenzg commented Oct 22, 2024

We need to skip applying the rule if in_app is already set to True since the rules were only added a year ago (PR).

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants