Skip to content
Merged
Show file tree
Hide file tree
Changes from 14 commits
Commits
Show all changes
27 commits
Select commit Hold shift + click to select a range
455d77a
new package
timfish Jun 10, 2025
b5b0027
Merge branch 'develop' into timfish/feat/new-anr
timfish Jun 14, 2025
59b6bff
Mostly working
timfish Jun 18, 2025
b49f3f5
Lint 🤦🏻‍♂️
timfish Jun 23, 2025
7a306e4
Merge branch 'develop' into timfish/feat/new-anr
timfish Jun 23, 2025
aa69600
Update Sentry deps
timfish Jun 23, 2025
156f67b
Better thread names
timfish Jun 24, 2025
7dfdd7a
Merge branch 'develop' into timfish/feat/new-anr
timfish Jun 24, 2025
327fa55
yarn.lock changes
timfish Jun 24, 2025
6fa63af
Add to verdaccio config
timfish Jun 24, 2025
0745a20
Fix tests
timfish Jun 24, 2025
3f83db2
rename package export
timfish Jun 24, 2025
c4a718c
Fix flakey worker thread test
timfish Jun 24, 2025
a487e50
Merge remote-tracking branch 'upstream/develop' into timfish/feat/new…
timfish Jun 24, 2025
ad4693a
Apply suggestions from code review
timfish Jun 24, 2025
8443d33
PR review
timfish Jun 24, 2025
1ac4549
Merge branch 'timfish/feat/new-anr' of github.com:getsentry/sentry-ja…
timfish Jun 24, 2025
66e6aa5
Add rate limits
timfish Jun 24, 2025
487e667
PR review
timfish Jun 25, 2025
3dfd01b
Merge branch 'develop' into timfish/feat/new-anr
timfish Jun 25, 2025
7fb37dc
Remove `disableBlockedDetectionForCallback` for now
timfish Jun 26, 2025
5289d11
Merge branch 'timfish/feat/new-anr' of github.com:getsentry/sentry-ja…
timfish Jun 26, 2025
a346e4c
Merge remote-tracking branch 'upstream/develop' into timfish/feat/new…
timfish Jun 26, 2025
c3b9780
remove unused tests
timfish Jun 28, 2025
47edf1c
Merge branch 'develop' into timfish/feat/new-anr
timfish Jun 28, 2025
b7f3df6
Merge branch 'develop' into timfish/feat/new-anr
timfish Jul 1, 2025
6379967
Merge branch 'develop' into timfish/feat/new-anr
timfish Jul 2, 2025
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
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
import * as Sentry from '@sentry/node';
import { threadBlockedIntegration } from '@sentry/node-native';
import * as path from 'path';
import * as url from 'url';
import { longWork } from './long-work.js';

global._sentryDebugIds = { [new Error().stack]: 'aaaaaaaa-aaaa-4aaa-aaaa-aaaaaaaaaa' };

const __dirname = path.dirname(url.fileURLToPath(import.meta.url));

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

Sentry.init({
dsn: process.env.SENTRY_DSN,
release: '1.0',
integrations: [threadBlockedIntegration({ blockedThreshold: 100, appRootPath: __dirname })],
});

setTimeout(() => {
longWork();
}, 1000);
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
import * as Sentry from '@sentry/node';
import { threadBlockedIntegration } from '@sentry/node-native';
import { longWork } from './long-work.js';

global._sentryDebugIds = { [new Error().stack]: 'aaaaaaaa-aaaa-4aaa-aaaa-aaaaaaaaaa' };

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

Sentry.init({
dsn: process.env.SENTRY_DSN,
release: '1.0',
integrations: [threadBlockedIntegration({ blockedThreshold: 100, maxBlockedEvents: 2 })],
});

setTimeout(() => {
longWork();
}, 1000);

setTimeout(() => {
longWork();
}, 4000);
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
const Sentry = require('@sentry/node');
const { threadBlockedIntegration } = require('@sentry/node-native');
const { longWork } = require('./long-work.js');

global._sentryDebugIds = { [new Error().stack]: 'aaaaaaaa-aaaa-4aaa-aaaa-aaaaaaaaaa' };

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

Sentry.init({
dsn: process.env.SENTRY_DSN,
release: '1.0',
integrations: [threadBlockedIntegration({ blockedThreshold: 100 })],
});

setTimeout(() => {
longWork();
}, 2000);

// Ensure we only send one event even with multiple blocking events
setTimeout(() => {
longWork();
}, 5000);
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
import * as Sentry from '@sentry/node';
import { threadBlockedIntegration } from '@sentry/node-native';
import { longWork } from './long-work.js';

global._sentryDebugIds = { [new Error().stack]: 'aaaaaaaa-aaaa-4aaa-aaaa-aaaaaaaaaa' };

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

Sentry.init({
dsn: process.env.SENTRY_DSN,
release: '1.0',
integrations: [threadBlockedIntegration({ blockedThreshold: 100 })],
});

setTimeout(() => {
longWork();
}, 2000);

// Ensure we only send one event even with multiple blocking events
setTimeout(() => {
longWork();
}, 5000);
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
import * as Sentry from '@sentry/node';
import { threadBlockedIntegration } from '@sentry/node-native';
import * as assert from 'assert';
import * as crypto from 'crypto';

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

Sentry.init({
dsn: process.env.SENTRY_DSN,
release: '1.0',
integrations: [threadBlockedIntegration({ blockedThreshold: 100 })],
});

function longWork() {
// This loop will run almost indefinitely
for (let i = 0; i < 2000000000; i++) {
const salt = crypto.randomBytes(128).toString('base64');
const hash = crypto.pbkdf2Sync('myPassword', salt, 10000, 512, 'sha512');
assert.ok(hash);
}
}

setTimeout(() => {
longWork();
}, 1000);
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
import * as Sentry from '@sentry/node';
import { threadBlockedIntegration } from '@sentry/node-native';

Sentry.init({
debug: true,
dsn: process.env.SENTRY_DSN,
release: '1.0',
integrations: [threadBlockedIntegration({ blockedThreshold: 100 })],
});
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
const crypto = require('crypto');
const assert = require('assert');

function longWork() {
for (let i = 0; i < 20; i++) {
const salt = crypto.randomBytes(128).toString('base64');
const hash = crypto.pbkdf2Sync('myPassword', salt, 10000, 512, 'sha512');
assert.ok(hash);
}
}

exports.longWork = longWork;
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
const Sentry = require('@sentry/node');
const { threadBlockedIntegration } = require('@sentry/node-native');

function configureSentry() {
Sentry.init({
dsn: 'https://[email protected]/1337',
release: '1.0',
debug: true,
integrations: [threadBlockedIntegration()],
});
}

async function main() {
configureSentry();
await new Promise(resolve => setTimeout(resolve, 1000));
process.exit(0);
}

main();
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
const Sentry = require('@sentry/node');
const { threadBlockedIntegration } = require('@sentry/node-native');

function configureSentry() {
Sentry.init({
dsn: 'https://[email protected]/1337',
release: '1.0',
debug: true,
integrations: [threadBlockedIntegration()],
});
}

async function main() {
configureSentry();
await new Promise(resolve => setTimeout(resolve, 1000));
}

main();
Original file line number Diff line number Diff line change
@@ -0,0 +1,45 @@
const Sentry = require('@sentry/node');
const { threadBlockedIntegration } = require('@sentry/node-native');
const { longWork } = require('./long-work.js');
const crypto = require('crypto');
const assert = require('assert');

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

const threadBlocked = threadBlockedIntegration({ blockedThreshold: 100 });

Sentry.init({
dsn: process.env.SENTRY_DSN,
release: '1.0',
debug: true,
integrations: [threadBlocked],
});

Sentry.setUser({ email: '[email protected]' });
Sentry.addBreadcrumb({ message: 'important message!' });

function longWorkIgnored() {
for (let i = 0; i < 20; i++) {
const salt = crypto.randomBytes(128).toString('base64');
const hash = crypto.pbkdf2Sync('myPassword', salt, 10000, 512, 'sha512');
assert.ok(hash);
}
}

setTimeout(() => {
threadBlocked.stopWorker();

setTimeout(() => {
longWorkIgnored();

setTimeout(() => {
threadBlocked.startWorker();

setTimeout(() => {
longWork();
});
}, 2000);
}, 2000);
}, 2000);
Loading
Loading