Skip to content

meta(changelog): Update changelog for 9.13.0 #16078

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

Merged
merged 19 commits into from
Apr 16, 2025
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
19 commits
Select commit Hold shift + click to select a range
30591d4
Merge pull request #16013 from getsentry/master
github-actions[bot] Apr 8, 2025
56aac53
fix(node): Ensure late init works with all integrations (#16016)
mydea Apr 9, 2025
8046e14
fix(core): Run `beforeSendLog` after we process log (#16019)
AbhiPrasad Apr 9, 2025
d007407
feat(core): Move console integration into core and add to cloudflare/…
AbhiPrasad Apr 10, 2025
4c5f2fb
feat(core): Allow delayed sending with offline transport (#15937)
timfish Apr 11, 2025
1bbe0d9
fix(nextjs): Include patch version 0 for min supported 15.3.0 (#16026)
s1gr1d Apr 11, 2025
be737e4
feat(bun): Support new `Bun.serve` APIs (#16035)
AbhiPrasad Apr 11, 2025
f9383c7
fix(react-router): Pass `unstable_sentryVitePluginOptions` to cli ins…
chargome Apr 14, 2025
bd7205b
feat(browser): Warn on duplicate `browserTracingIntegration` (#16042)
mydea Apr 14, 2025
6eb7366
feat(core): Add `wrapMcpServerWithSentry` to instrument MCP servers f…
lforst Apr 14, 2025
458fa07
feat(vue): Apply stateTransformer to attachments in Pinia Plugin (#1…
s1gr1d Apr 14, 2025
cff47df
feat(node): Add support for winston logger (#15983)
AbhiPrasad Apr 14, 2025
217ac8d
build(deps): Bump @nestjs/common from 10.4.6 to 11.0.16 in /dev-packa…
dependabot[bot] Apr 15, 2025
d34e67e
feat(deps): Bump @sentry/webpack-plugin from 3.2.4 to 3.3.1 (#16057)
dependabot[bot] Apr 15, 2025
36be635
fix(nextjs): Don't show turbopack warning for newer Next.js canaries …
lforst Apr 15, 2025
6a3e7c1
ci: Update label automation to new package label style (#16053)
mydea Apr 16, 2025
f4cc3d2
fix(serverless-aws): Overwrite root span name with GraphQL if set (#1…
s1gr1d Apr 16, 2025
55cb92c
chore(dev-deps): Bump `amqlib` for node-integration-tests to 0.10.7 (…
mydea Apr 16, 2025
b839506
meta(changelog): Update changelog for 9.13.0
AbhiPrasad Apr 16, 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
7 changes: 7 additions & 0 deletions .github/ISSUE_TEMPLATE/bug.yml
Original file line number Diff line number Diff line change
Expand Up @@ -32,11 +32,17 @@ body:
options:
- '@sentry/browser'
- '@sentry/node'
- '@sentry/node - express'
- '@sentry/node - fastify'
- '@sentry/node - koa'
- '@sentry/node - hapi'
- '@sentry/node - connect'
- '@sentry/angular'
- '@sentry/astro'
- '@sentry/aws-serverless'
- '@sentry/bun'
- '@sentry/cloudflare'
- '@sentry/cloudflare - hono'
- '@sentry/deno'
- '@sentry/ember'
- '@sentry/gatsby'
Expand All @@ -45,6 +51,7 @@ body:
- '@sentry/nextjs'
- '@sentry/nuxt'
- '@sentry/react'
- '@sentry/react-router'
- '@sentry/remix'
- '@sentry/solid'
- '@sentry/solidstart'
Expand Down
74 changes: 49 additions & 25 deletions .github/workflows/issue-package-label.yml
Original file line number Diff line number Diff line change
Expand Up @@ -30,76 +30,100 @@ jobs:
map: |
{
"@sentry.angular": {
"label": "Package: angular"
"label": "Angular"
},
"@sentry.astro": {
"label": "Package: astro"
"label": "Astro"
},
"@sentry.aws-serverless": {
"label": "Package: aws-serverless"
"label": "AWS Lambda"
},
"@sentry.browser": {
"label": "Package: browser"
"label": "Browser"
},
"@sentry.bun": {
"label": "Package: bun"
"label": "Bun"
},
"@sentry.cloudflare - hono": {
"label": "Hono"
},
"@sentry.cloudflare": {
"label": "Package: cloudflare"
"label": "Cloudflare Workers"
},
"@sentry.deno": {
"label": "Package: deno"
"label": "Deno"
},
"@sentry.ember": {
"label": "Package: ember"
"label": "Ember"
},
"@sentry.gatsby": {
"label": "Package: gatbsy"
"label": "Gatbsy"
},
"@sentry.google-cloud-serverless": {
"label": "Package: google-cloud-serverless"
"label": "Google Cloud Functions"
},
"@sentry.nestjs": {
"label": "Package: nestjs"
"label": "Nest.js"
},
"@sentry.nextjs": {
"label": "Package: nextjs"
"label": "Next.js"
},
"@sentry.node - express": {
"label": "Express"
},
"@sentry.node - fastify": {
"label": "Fastify"
},
"@sentry.node - koa": {
"label": "Koa"
},
"@sentry.node - hapi": {
"label": "Hapi
},
"@sentry.node - connect": {
"label": "Connect
},
"@sentry.node": {
"label": "Package: node"
"label": "Node.js"
},
"@sentry.nuxt": {
"label": "Package: nuxt"
"label": "Nuxt"
},
"@sentry.react-router": {
"label": "React Router Framework "
},
"@sentry.react": {
"label": "Package: react"
"label": "React"
},
"@sentry.remix": {
"label": "Package: remix"
"label": "Remix"
},
"@sentry.solid": {
"label": "Package: solid"
"label": "Solid"
},
"@sentry.solid": {
"label": "Package: solidstart"
"@sentry.solidstart": {
"label": "SolidStart"
},
"@sentry.sveltekit": {
"label": "Package: sveltekit"
"label": "SvelteKit"
},
"@sentry.svelte": {
"label": "Package: svelte"
"label": "Svelte"
},
"@sentry.vue": {
"label": "Package: vue"
"label": "Vue"
},
"@sentry.tanstackstart-react": {
"label": "Tanstack Start React"
},
"@sentry.wasm": {
"label": "Package: wasm"
"label": "WASM"
},
"Sentry.Browser.Loader": {
"label": "Package-Meta: Loader"
"label": "Browser\nLoader Script"
},
"Sentry.Browser.CDN.bundle": {
"label": "Package-Meta: CDN"
"label": "Browser\nCDN Bundle"
}
}
export_to: output
Expand Down
2 changes: 1 addition & 1 deletion .size-limit.js
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@ module.exports = [
path: 'packages/browser/build/npm/esm/index.js',
import: createImport('init', 'browserTracingIntegration'),
gzip: true,
limit: '38 KB',
limit: '39 KB',
},
{
name: '@sentry/browser (incl. Tracing, Replay)',
Expand Down
59 changes: 59 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,65 @@

- "You miss 100 percent of the chances you don't take. — Wayne Gretzky" — Michael Scott

## 9.13.0

### Important Changes

- **feat(node): Add support for winston logger ([#15983](https://github.com/getsentry/sentry-javascript/pull/15983))**

Sentry is adding support for [structured logging](https://github.com/getsentry/sentry-javascript/discussions/15916). In this release we've added support for sending logs to Sentry via the [winston](https://github.com/winstonjs/winston) logger to the Sentry Node SDK (and SDKs that use the Node SDK under the hood like `@sentry/nestjs`). The Logging APIs in the Sentry SDK are still experimental and subject to change.

```js
const winston = require('winston');
const Transport = require('winston-transport');

const transport = Sentry.createSentryWinstonTransport(Transport);

const logger = winston.createLogger({
transports: [transport],
});
```

- **feat(core): Add `wrapMcpServerWithSentry` to instrument MCP servers from `@modelcontextprotocol/sdk` ([#16032](https://github.com/getsentry/sentry-javascript/pull/16032))**

The Sentry SDK now supports instrumenting MCP servers from the `@modelcontextprotocol/sdk` package. Compatible with versions `^1.9.0` of the `@modelcontextprotocol/sdk` package.

```js
import { McpServer } from '@modelcontextprotocol/sdk/server/mcp.js';

// Create an MCP server
const server = new McpServer({
name: 'Demo',
version: '1.0.0',
});

// Use the instrumented server in your application
const instrumentedServer = Sentry.wrapMcpServerWithSentry(server);
```

- **feat(core): Move console integration into core and add to cloudflare/vercel-edge ([#16024](https://github.com/getsentry/sentry-javascript/pull/16024))**

Console instrumentation has been added to `@sentry/cloudflare` and `@sentry/nextjs` Edge Runtime and is enabled by default. Now calls to the console object will be captured as breadcrumbs for those SDKs.

- **feat(bun): Support new `Bun.serve` APIs ([#16035](https://github.com/getsentry/sentry-javascript/pull/16035))**

Bun `1.2.6` and above have a new `Bun.serve` API, which the Bun SDK now supports. The SDK instruments the new routes object that can be used to define routes for the server.

Thanks to @Jarred-Sumner for helping us get this supported!

### Other Changes

- feat(browser): Warn on duplicate `browserTracingIntegration` ([#16042](https://github.com/getsentry/sentry-javascript/pull/16042))
- feat(core): Allow delayed sending with offline transport ([#15937](https://github.com/getsentry/sentry-javascript/pull/15937))
- feat(deps): Bump @sentry/webpack-plugin from 3.2.4 to 3.3.1 ([#16057](https://github.com/getsentry/sentry-javascript/pull/16057))
- feat(vue): Apply stateTransformer to attachments in Pinia Plugin ([#16034](https://github.com/getsentry/sentry-javascript/pull/16034))
- fix(core): Run `beforeSendLog` after we process log ([#16019](https://github.com/getsentry/sentry-javascript/pull/16019))
- fix(nextjs): Don't show turbopack warning for newer Next.js canaries ([#16065](https://github.com/getsentry/sentry-javascript/pull/16065))
- fix(nextjs): Include patch version 0 for min supported 15.3.0 ([#16026](https://github.com/getsentry/sentry-javascript/pull/16026))
- fix(node): Ensure late init works with all integrations ([#16016](https://github.com/getsentry/sentry-javascript/pull/16016))
- fix(react-router): Pass `unstable_sentryVitePluginOptions` to cli instance ([#16033](https://github.com/getsentry/sentry-javascript/pull/16033))
- fix(serverless-aws): Overwrite root span name with GraphQL if set ([#16010](https://github.com/getsentry/sentry-javascript/pull/16010))

## 9.12.0

### Important Changes
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
import * as Sentry from '@sentry/browser';

window.Sentry = Sentry;

Sentry.init({
dsn: 'https://[email protected]/1337',
integrations: [Sentry.browserTracingIntegration(), Sentry.browserTracingIntegration()],
tracesSampleRate: 1,
});
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
import { expect } from '@playwright/test';

import { sentryTest } from '../../../../utils/fixtures';
import { shouldSkipTracingTest } from '../../../../utils/helpers';

sentryTest('warns if multiple integrations are used', async ({ getLocalTestUrl, page }) => {
if (shouldSkipTracingTest()) {
sentryTest.skip();
}

const msgs: string[] = [];

page.on('console', msg => {
msgs.push(msg.text());
});

const url = await getLocalTestUrl({ testDir: __dirname });

await page.goto(url);

expect(msgs).toEqual(['Multiple browserTracingIntegration instances are not supported.']);
});
5 changes: 3 additions & 2 deletions dev-packages/node-integration-tests/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@
"dependencies": {
"@aws-sdk/client-s3": "^3.552.0",
"@hapi/hapi": "^21.3.10",
"@nestjs/common": "10.4.6",
"@nestjs/common": "11.0.16",
"@nestjs/core": "10.4.6",
"@nestjs/platform-express": "10.4.6",
"@sentry/aws-serverless": "9.12.0",
Expand All @@ -37,7 +37,7 @@
"@types/mysql": "^2.15.21",
"@types/pg": "^8.6.5",
"ai": "^4.0.6",
"amqplib": "^0.10.4",
"amqplib": "^0.10.7",
"apollo-server": "^3.11.1",
"axios": "^1.7.7",
"body-parser": "^1.20.3",
Expand Down Expand Up @@ -67,6 +67,7 @@
"reflect-metadata": "0.2.1",
"rxjs": "^7.8.1",
"tedious": "^18.6.1",
"winston": "^3.17.0",
"yargs": "^16.2.0"
},
"devDependencies": {
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
const { ApolloServer, gql } = require('apollo-server');
const Sentry = require('@sentry/aws-serverless');

module.exports = () => {
return Sentry.startSpan({ name: 'Test Server Start' }, () => {
return new ApolloServer({
typeDefs: gql`
type Query {
hello: String
world: String
}
type Mutation {
login(email: String): String
}
`,
resolvers: {
Query: {
hello: () => {
return 'Hello!';
},
world: () => {
return 'World!';
},
},
Mutation: {
login: async (_, { email }) => {
return `${email}--token`;
},
},
},
introspection: false,
debug: false,
});
});
};
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
const { loggingTransport } = require('@sentry-internal/node-integration-tests');
const Sentry = require('@sentry/aws-serverless');

Sentry.init({
dsn: 'https://[email protected]/1337',
tracesSampleRate: 1.0,
integrations: [Sentry.graphqlIntegration({ useOperationNameForRootSpan: true })],
transport: loggingTransport,
});

async function run() {
const apolloServer = require('./apollo-server')();

await Sentry.startSpan({ name: 'Test Transaction' }, async span => {
// Ref: https://www.apollographql.com/docs/apollo-server/testing/testing/#testing-using-executeoperation
await apolloServer.executeOperation({
query: 'query GetHello {hello}',
});

setTimeout(() => {
span.end();
apolloServer.stop();
}, 500);
});
}

run();
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
import { afterAll, describe, expect, test } from 'vitest';
import { cleanupChildProcesses, createRunner } from '../../../../utils/runner';

const EXPECTED_TRANSCATION = {
transaction: 'Test Transaction (query GetHello)',
spans: expect.arrayContaining([
expect.objectContaining({
description: 'query GetHello',
origin: 'auto.graphql.otel.graphql',
status: 'ok',
}),
]),
};

describe('graphqlIntegration', () => {
afterAll(() => {
cleanupChildProcesses();
});

test('should use GraphQL operation name for root span if useOperationNameForRootSpan is set', async () => {
await createRunner(__dirname, 'scenario.js')
.ignore('event')
.expect({ transaction: { transaction: 'Test Server Start (query IntrospectionQuery)' } })
.expect({ transaction: EXPECTED_TRANSCATION })
.start()
.completed();
});
});
Loading
Loading