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

@sentry/cloudflare not sending debugIds ? #14841

Open
6 of 8 tasks
bhanuka-yd opened this issue Dec 27, 2024 · 10 comments
Open
6 of 8 tasks

@sentry/cloudflare not sending debugIds ? #14841

bhanuka-yd opened this issue Dec 27, 2024 · 10 comments
Labels
Package: cloudflare Issues related to the Sentry Cloudflare Workers SDK

Comments

@bhanuka-yd
Copy link

Is there an existing issue for this?

How do you use Sentry?

Sentry Saas (sentry.io)

Which SDK are you using?

@sentry/cloudflare

SDK Version

8.47.0

Framework Version

wrangler: 3.99.0

Link to Sentry event

https://hyperbyte.sentry.io/issues/15388878/events/6faf01ca3f04449081bf9dab43025a33/

Reproduction Example/SDK Setup

index.js

export default Sentry.withSentry(
	(env: Env) => ({
		dsn: env.SENTRY_DSN,
		// Set tracesSampleRate to 1.0 to capture 100% of spans for tracing.
		tracesSampleRate: env.SENTRY_TRACES_SAMPLE_RATE,
		environment: 'production'
	}),
	{
		async fetch(request: Request, env, ctx): Promise<Response> {

			const configParse = configSchema.safeParse(env);
			if (!configParse.success) {
				return configErr(configParse.error, env);
			} else {
				env = configParse.data;
			}

			globalThis.env = env;
			// globalThis.prisma = prismaFactory(env.DATABASE_URL);
			globalThis.db = getDB(env.DATABASE_URL);

			return fetchRequestHandler({
				endpoint: '/trpc',
				req: request,
				router: appRouter,
				createContext
			});
		}
	} satisfies ExportedHandler<Env>
);

error-generating-file.js

Sentry.captureException(result.error);

rollup.config.js

    import resolve from '@rollup/plugin-node-resolve';
    import commonjs from '@rollup/plugin-commonjs';
    import typescript from '@rollup/plugin-typescript';
    import terser from '@rollup/plugin-terser';
    import json from '@rollup/plugin-json';
    import { sentryRollupPlugin } from '@sentry/rollup-plugin';
    
    export default {
    	input: 'src/index.ts',  // Path to your main entry file,
    	output: {
    		file: 'dist/worker.js',  // Output path for your bundled worker
    		format: 'es',  // Cloudflare Workers support ES Modules
    		sourcemap: true,
    		inlineDynamicImports: true
    	},
    	plugins: [
    		resolve(),  // Resolve node modules
    		commonjs(),
    		json(),
    		typescript({
    			tsconfig: './tsconfig.json'
    		}),
    		terser(),   // Minify the output (optional)
    		sentryRollupPlugin({
    			authToken: process.env.SENTRY_AUTH_TOKEN,
    			org: '------',
    			project: '--------'
    		})
    
    	]
    };

wrangler.toml

upload_source_maps = true

[build]
#custom build command
command = "npm run build"

Steps to Reproduce

  1. Add sentry @sentry/cloudflare
  2. Setup init
  3. Test using Sentry.captureException()
  4. Setup rollup

Expected Result

  • Compiled code includes e._sentryDebugIds=e._sentryDebugIds||{}
  • Issue reported to sentry
  • Issue Stack-trace visible
  • Issue Stack-trace un-minified
  • event json does not include debug_meta

Actual Result

  • Compiled code includes e._sentryDebugIds=e._sentryDebugIds||{}
  • Issue reported to sentry
  • Issue Stack-trace visible
  • Issue Stack-trace un-minified
  • event json does not include debug_meta

shows that
Image

i have checked the event json and it does not contain debug_meta

@getsantry getsantry bot moved this to Waiting for: Product Owner in GitHub Issues with 👀 3 Dec 27, 2024
@github-actions github-actions bot added the Package: cloudflare Issues related to the Sentry Cloudflare Workers SDK label Dec 27, 2024
@andreiborza
Copy link
Member

Hi @bhanuka-yd, thanks for writing in.

Could you please set debug: true in the rollup plugin and paste some build logs?

@bhanuka-yd
Copy link
Author

bhanuka-yd commented Dec 27, 2024

Hi @andreiborza, sure here's the output.

rollup -c rollup.config.mjs

[sentry-rollup-plugin] Info: Using environment variables configured in ".env.sentry-build-plugin".

src/index.ts → dist/worker.js...
[sentry-rollup-plugin] Info: Sending telemetry data on issues and performance to Sentry. To disable telemetry, set options.telemetry to false.
[sentry-rollup-plugin] Debug: No sourcemaps.assets option provided, falling back to uploading detected build artifacts.

Found 2 files
Analyzing 2 sources
Analyzing completed in 0.032s
Adding source map references
Bundling completed in 0.19s
Bundled 2 files for upload
Bundle ID: 759fb507-c679-513f-8436-8fcd080c42ea
Optimizing completed in 0.006s
Uploading completed in 4.478s
Uploaded files to Sentry
Processing completed in 1.459s
File upload complete (processing pending on server)
Organization: ------------
Project: ---------------
Release: 69e8d6aa31b6a806ea9388d59583069411fbf4d3
Dist: None
Upload type: artifact bundle

Source Map Upload Report
Scripts
~/167414e4-08a0-4d95-a51f-9efdaa05e16a-0.js (sourcemap at worker.js.map, debug id 167414e4-08a0-4d95-a51f-9efdaa05e16a)
Source Maps
~/167414e4-08a0-4d95-a51f-9efdaa05e16a-0.js.map (debug id 167414e4-08a0-4d95-a51f-9efdaa05e16a)
[sentry-rollup-plugin] Info: Successfully uploaded source maps to Sentry
(!) Circular dependencies
node_modules/@smithy/util-stream/dist-es/blob/Uint8ArrayBlobAdapter.js -> node_modules/@smithy/util-stream/dist-es/blob/transforms.js -> node_modules/@smithy/util-stream/dist-es/blob/Uint8ArrayBlobAdapter.js
node_modules/@aws-crypto/crc32c/build/module/index.js -> node_modules/@aws-crypto/crc32c/build/module/aws_crc32c.js -> node_modules/@aws-crypto/crc32c/build/module/index.js
node_modules/@aws-crypto/crc32/build/module/index.js -> node_modules/@aws-crypto/crc32/build/module/aws_crc32.js -> node_modules/@aws-crypto/crc32/build/module/index.js
...and 7 more
created dist/worker.js in 23.1s
Total Upload: 1716.87 KiB / gzip: 320.36 KiB
Worker Startup Time: 82 ms

@Lms24
Copy link
Member

Lms24 commented Jan 2, 2025

Hi @bhanuka-yd, I didn't find anything yet that would prohibit debug ids from being applied to error events. Before we dig into this deeper: Can you confirm that the files where debug ids were injected correctly are the exact same files that get deployed to cloudflare? The debug_meta field in the event JSON can only be populated, if the deployed files contain the e._sentryDebugIds snippet.

If this is the case, we need to dive deeper into SDK internals to understand what's going on. If you can, please provide a minimal reproduction, for example in the form of a GH repo, zip file or whatever else works for you.

If you can't, please console.log some things:

  • in beforeSend, please log out event and event.exception.values so that we can check what the SDK sends exactly. Sometimes, the event JSON in the Sentry UI already contains slight changes.
  • in beforeSend, please also log out globalThis._sentryDebugIds so that we can check if the SDK could even pick up debug ids.

Side-note: I did find a bug in our debug id application logic but it's rather an edge case, where debug ids were not correctly applied to events containing multiple errors. However I don't think this has anything to do with your problem. Anyway, the found bug will be fixed via #14881.

@bhanuka-yd
Copy link
Author

hi, @Lms24, been a bit busy past few days. I will try to setup a GH repo this week. I have searched the files and debugids are present in the deployed files. see the image below.

Image

Thanks.

@getsantry getsantry bot moved this from Waiting for: Community to Waiting for: Product Owner in GitHub Issues with 👀 3 Jan 6, 2025
@Lms24
Copy link
Member

Lms24 commented Jan 7, 2025

Thanks, will wait for the reproduction then.

@getsantry getsantry bot removed the status in GitHub Issues with 👀 3 Jan 7, 2025
@getsantry getsantry bot moved this to Waiting for: Community in GitHub Issues with 👀 3 Jan 7, 2025
Lms24 added a commit that referenced this issue Jan 7, 2025
…14881)

While investigating
#14841, I noticed
that we had some brittle non-null assertions in our `applyDebugIds`
function which would cause the debug id application logic to terminate
early, in case we'd encounter an `event.exception.values` item without a
stack trace. The added regression test illustrates the scenario in which
debug ids would not have been applied to the second exception prior to
this fix.
@bhanuka-yd
Copy link
Author

hi @Lms24 , here is a simple reproduction.

https://github.com/bhanuka-yd/sentry-cf-workers-error-reproduction

@getsantry getsantry bot moved this from Waiting for: Community to Waiting for: Product Owner in GitHub Issues with 👀 3 Jan 17, 2025
@Lms24
Copy link
Member

Lms24 commented Jan 20, 2025

Hey @bhanuka-yd thanks for the great reproduction! I deployed it to my CF account and I can indeed reproduce this. I asked our resident CF expert @AbhiPrasad to also take a look.

However, I know why debug ids are not injected. It seems like wrangler indeed creates another build into .wrangler/tmp/[random-id] during npm run deploy. This code does not contain the Sentry-injected values and hence there's no debug id available to add to the stack frames when the SDK catches the error. Now we need to find out how to fix this.

@AbhiPrasad
Copy link
Member

Although wrangler is outputting to another folder, it should respect whatever is getting generated by rollup. Not sure why it's re-writing stuff here.

We should ask the cloudflare team what is going on here.

@jbergstroem
Copy link

jbergstroem commented Jan 24, 2025

Once there is a solution in place, it'd be great if the @sentry/wizard -i sourcemaps config tool detected a cloudflare/wrangler project and configured it for the user.

Edit: @sentry/sourcemaps -> @sentry/wizard -i sourcemaps

@getsantry getsantry bot moved this to Waiting for: Product Owner in GitHub Issues with 👀 3 Jan 24, 2025
@Lms24
Copy link
Member

Lms24 commented Jan 24, 2025

it'd be great if the @sentry/sourcemaps config tool

Do you mean @sentry/wizard -i sourcemaps? Sure, once we know if/what needs to be done, we can add a CF-specific sourcemaps config flow. Just depends on the solution.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Package: cloudflare Issues related to the Sentry Cloudflare Workers SDK
Projects
Status: No status
Development

No branches or pull requests

5 participants