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

feat(node): Rework ANR to use worker script via an integration #9945

Merged
merged 38 commits into from
Dec 21, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
38 commits
Select commit Hold shift + click to select a range
ed4a316
feat(node): Use worker thread for ANR detection
timfish Dec 9, 2023
14fe3a5
Remove utility
timfish Dec 11, 2023
e5c82dd
PR feedback
timfish Dec 12, 2023
d246581
Merge branch 'develop' into fix/anr-worker-thread
timfish Dec 12, 2023
dce3684
remove outdated comments
timfish Dec 12, 2023
2ca69ca
Merge remote-tracking branch 'origin/fix/anr-worker-thread' into fix/…
timfish Dec 12, 2023
3042553
use getWorkerThreads
timfish Dec 12, 2023
dad68a1
Merge branch 'develop' into fix/anr-worker-thread
timfish Dec 13, 2023
61dd30f
Merge branch 'develop' into fix/anr-worker-thread
timfish Dec 13, 2023
33e1ce0
feat(node): Rework ANR to use worker script via an integration
timfish Dec 13, 2023
97b09bb
Bodge the build and add platform
timfish Dec 13, 2023
b2a1907
also build before test
timfish Dec 13, 2023
8b6289f
Work on build
timfish Dec 13, 2023
0486f12
Merge branch 'develop' into anr-worker-from-base64-script
timfish Dec 13, 2023
91c19b9
Only node 16 😢
timfish Dec 13, 2023
26b4ebe
Merge remote-tracking branch 'origin/anr-worker-from-base64-script' i…
timfish Dec 13, 2023
d098a53
a few worker simplifications
timfish Dec 14, 2023
27ebe02
PR review comments
timfish Dec 17, 2023
624f097
Merge remote-tracking branch 'upstream/develop' into anr-worker-from-…
timfish Dec 18, 2023
94af9ec
Only test node >= 16
timfish Dec 18, 2023
40f25d2
Include and test the old deprecated API
timfish Dec 18, 2023
7ef8050
Merge branch 'develop' into anr-worker-from-base64-script
timfish Dec 18, 2023
0c71dcc
Linting
timfish Dec 18, 2023
930969b
Merge remote-tracking branch 'origin/anr-worker-from-base64-script' i…
timfish Dec 18, 2023
3de4144
Merge remote-tracking branch 'upstream/develop' into anr-worker-from-…
timfish Dec 18, 2023
b2d4b66
Merge remote-tracking branch 'upstream/develop' into anr-worker-from-…
timfish Dec 19, 2023
f0ac67e
remove isAnrChildProcess usage
timfish Dec 19, 2023
41cc61d
Include `parentSpanId` in trace context
timfish Dec 19, 2023
4a7c4fc
Ensure we get app/device/os/culture context with ANR events
timfish Dec 19, 2023
6271c85
Fix test
timfish Dec 19, 2023
cbec922
Write worker build output to `build/*`
timfish Dec 20, 2023
cb347d7
Merge branch 'develop' into anr-worker-from-base64-script
timfish Dec 20, 2023
ca749df
Merge branch 'develop' into anr-worker-from-base64-script
timfish Dec 20, 2023
90efe24
A couple of merge mistakes
timfish Dec 20, 2023
b2e317c
Fix build
timfish Dec 20, 2023
7c962d9
format
timfish Dec 20, 2023
38c9e8d
Fix floating promises
timfish Dec 20, 2023
f8e022f
Merge branch 'develop' into anr-worker-from-base64-script
timfish Dec 20, 2023
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
2 changes: 1 addition & 1 deletion packages/core/src/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ export type { ServerRuntimeClientOptions } from './server-runtime-client';
export type { RequestDataIntegrationOptions } from './integrations/requestdata';

export * from './tracing';
export { createEventEnvelope } from './envelope';
export { createEventEnvelope, createSessionEnvelope } from './envelope';
export {
addBreadcrumb,
captureCheckIn,
Expand Down
8 changes: 3 additions & 5 deletions packages/node-experimental/src/sdk/init.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,6 @@ import {
defaultIntegrations as defaultNodeIntegrations,
defaultStackParser,
getSentryRelease,
isAnrChildProcess,
makeNodeTransport,
} from '@sentry/node';
import type { Integration } from '@sentry/types';
Expand Down Expand Up @@ -113,15 +112,14 @@ function getClientOptions(options: NodeExperimentalOptions): NodeExperimentalCli

const release = getRelease(options.release);

// If there is no release, or we are in an ANR child process, we disable autoSessionTracking by default
const autoSessionTracking =
typeof release !== 'string' || isAnrChildProcess()
typeof release !== 'string'
? false
: options.autoSessionTracking === undefined
? true
: options.autoSessionTracking;
// We enforce tracesSampleRate = 0 in ANR child processes
const tracesSampleRate = isAnrChildProcess() ? 0 : getTracesSampleRate(options.tracesSampleRate);

const tracesSampleRate = getTracesSampleRate(options.tracesSampleRate);

const baseOptions = dropUndefinedKeys({
transport: makeNodeTransport,
Expand Down
29 changes: 13 additions & 16 deletions packages/node-integration-tests/suites/anr/basic-session.js
Original file line number Diff line number Diff line change
@@ -1,31 +1,28 @@
const crypto = require('crypto');
const assert = require('assert');

const Sentry = require('@sentry/node');

const { transport } = require('./test-transport.js');

// close both processes after 5 seconds
setTimeout(() => {
process.exit();
}, 5000);
}, 10000);

Sentry.init({
dsn: 'https://public@dsn.ingest.sentry.io/1337',
release: '1.0',
debug: true,
transport,
integrations: [new Sentry.Integrations.Anr({ captureStackTrace: true, anrThreshold: 200 })],
});

Sentry.enableAnrDetection({ captureStackTrace: true, anrThreshold: 200 }).then(() => {
function longWork() {
for (let i = 0; i < 100; i++) {
const salt = crypto.randomBytes(128).toString('base64');
// eslint-disable-next-line no-unused-vars
const hash = crypto.pbkdf2Sync('myPassword', salt, 10000, 512, 'sha512');
}
function longWork() {
for (let i = 0; i < 100; i++) {
const salt = crypto.randomBytes(128).toString('base64');
// eslint-disable-next-line no-unused-vars
const hash = crypto.pbkdf2Sync('myPassword', salt, 10000, 512, 'sha512');
assert.ok(hash);
}
}

setTimeout(() => {
longWork();
}, 1000);
});
setTimeout(() => {
longWork();
}, 1000);
29 changes: 13 additions & 16 deletions packages/node-integration-tests/suites/anr/basic.js
Original file line number Diff line number Diff line change
@@ -1,32 +1,29 @@
const crypto = require('crypto');
const assert = require('assert');

const Sentry = require('@sentry/node');

const { transport } = require('./test-transport.js');

// close both processes after 5 seconds
setTimeout(() => {
process.exit();
}, 5000);
}, 10000);

Sentry.init({
dsn: 'https://public@dsn.ingest.sentry.io/1337',
release: '1.0',
debug: true,
autoSessionTracking: false,
transport,
integrations: [new Sentry.Integrations.Anr({ captureStackTrace: true, anrThreshold: 200 })],
});

Sentry.enableAnrDetection({ captureStackTrace: true, anrThreshold: 200 }).then(() => {
function longWork() {
for (let i = 0; i < 100; i++) {
const salt = crypto.randomBytes(128).toString('base64');
// eslint-disable-next-line no-unused-vars
const hash = crypto.pbkdf2Sync('myPassword', salt, 10000, 512, 'sha512');
}
function longWork() {
for (let i = 0; i < 100; i++) {
const salt = crypto.randomBytes(128).toString('base64');
// eslint-disable-next-line no-unused-vars
const hash = crypto.pbkdf2Sync('myPassword', salt, 10000, 512, 'sha512');
assert.ok(hash);
}
}

setTimeout(() => {
longWork();
}, 1000);
});
setTimeout(() => {
longWork();
}, 1000);
11 changes: 4 additions & 7 deletions packages/node-integration-tests/suites/anr/basic.mjs
Original file line number Diff line number Diff line change
@@ -1,29 +1,26 @@
import * as assert from 'assert';
import * as crypto from 'crypto';

import * as Sentry from '@sentry/node';

const { transport } = await import('./test-transport.js');

// close both processes after 5 seconds
setTimeout(() => {
process.exit();
}, 5000);
}, 10000);

Sentry.init({
dsn: 'https://public@dsn.ingest.sentry.io/1337',
release: '1.0',
debug: true,
autoSessionTracking: false,
transport,
integrations: [new Sentry.Integrations.Anr({ captureStackTrace: true, anrThreshold: 200 })],
});

await Sentry.enableAnrDetection({ captureStackTrace: true, anrThreshold: 200 });

function longWork() {
for (let i = 0; i < 100; i++) {
const salt = crypto.randomBytes(128).toString('base64');
// eslint-disable-next-line no-unused-vars
const hash = crypto.pbkdf2Sync('myPassword', salt, 10000, 512, 'sha512');
assert.ok(hash);
}
}

Expand Down
29 changes: 13 additions & 16 deletions packages/node-integration-tests/suites/anr/forked.js
Original file line number Diff line number Diff line change
@@ -1,32 +1,29 @@
const crypto = require('crypto');
const assert = require('assert');

const Sentry = require('@sentry/node');

const { transport } = require('./test-transport.js');

// close both processes after 5 seconds
setTimeout(() => {
process.exit();
}, 5000);
}, 10000);

Sentry.init({
dsn: 'https://public@dsn.ingest.sentry.io/1337',
release: '1.0',
debug: true,
autoSessionTracking: false,
transport,
integrations: [new Sentry.Integrations.Anr({ captureStackTrace: true, anrThreshold: 200 })],
});

Sentry.enableAnrDetection({ captureStackTrace: true, anrThreshold: 200 }).then(() => {
function longWork() {
for (let i = 0; i < 100; i++) {
const salt = crypto.randomBytes(128).toString('base64');
// eslint-disable-next-line no-unused-vars
const hash = crypto.pbkdf2Sync('myPassword', salt, 10000, 512, 'sha512');
}
function longWork() {
for (let i = 0; i < 100; i++) {
const salt = crypto.randomBytes(128).toString('base64');
// eslint-disable-next-line no-unused-vars
const hash = crypto.pbkdf2Sync('myPassword', salt, 10000, 512, 'sha512');
assert.ok(hash);
}
}

setTimeout(() => {
longWork();
}, 1000);
});
setTimeout(() => {
longWork();
}, 1000);
31 changes: 31 additions & 0 deletions packages/node-integration-tests/suites/anr/legacy.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
const crypto = require('crypto');
const assert = require('assert');

const Sentry = require('@sentry/node');

setTimeout(() => {
process.exit();
}, 10000);

Sentry.init({
dsn: 'https://public@dsn.ingest.sentry.io/1337',
release: '1.0',
debug: true,
autoSessionTracking: false,
});

// eslint-disable-next-line deprecation/deprecation
Sentry.enableAnrDetection({ captureStackTrace: true, anrThreshold: 200 }).then(() => {
function longWork() {
for (let i = 0; i < 100; i++) {
const salt = crypto.randomBytes(128).toString('base64');
// eslint-disable-next-line no-unused-vars
const hash = crypto.pbkdf2Sync('myPassword', salt, 10000, 512, 'sha512');
assert.ok(hash);
}
}

setTimeout(() => {
longWork();
}, 1000);
});
17 changes: 0 additions & 17 deletions packages/node-integration-tests/suites/anr/test-transport.js

This file was deleted.

Loading