Skip to content

Commit

Permalink
Merge pull request #12591 from getsentry/prepare-release/8.11.0
Browse files Browse the repository at this point in the history
meta: Update changelog for 8.11.0
  • Loading branch information
mydea authored Jun 21, 2024
2 parents bbbcc17 + 2331958 commit 11090b8
Show file tree
Hide file tree
Showing 25 changed files with 889 additions and 450 deletions.
2 changes: 1 addition & 1 deletion .github/workflows/build.yml
Original file line number Diff line number Diff line change
Expand Up @@ -235,7 +235,7 @@ jobs:
runs-on: ubuntu-20.04
if: |
github.event_name == 'pull_request'
&& (github.action == 'opened' || github.action == 'reopened')
&& (github.event.action == 'opened' || github.event.action == 'reopened')
&& github.event.pull_request.author_association != 'COLLABORATOR'
&& github.event.pull_request.author_association != 'MEMBER'
&& github.event.pull_request.author_association != 'OWNER'
Expand Down
26 changes: 26 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,32 @@

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

## 8.11.0

### Important Changes

- **feat(core): Add `parentSpan` option to `startSpan*` APIs (#12567)**

We've made it easier to create a span as a child of a specific span via the startSpan\* APIs. This should allow you to
explicitly manage the parent-child relationship of your spans better.

```js
Sentry.startSpan({ name: 'root' }, parent => {
const span = Sentry.startInactiveSpan({ name: 'xxx', parentSpan: parent });

Sentry.startSpan({ name: 'xxx', parentSpan: parent }, () => {});

Sentry.startSpanManual({ name: 'xxx', parentSpan: parent }, () => {});
});
```

### Other Changes

- feat(node): Detect release from more providers (#12529)
- fix(profiling-node): Use correct getGlobalScope import (#12564)
- fix(profiling-node) sample timestamps need to be in seconds (#12563)
- ref: Align `@sentry/node` exports from framework SDKs. (#12589)

## 8.10.0

### Important Changes
Expand Down
82 changes: 13 additions & 69 deletions CONTRIBUTING.md
Original file line number Diff line number Diff line change
Expand Up @@ -58,11 +58,9 @@ To test local versions of SDK packages, for instance in test projects, you have

**Any nontrivial fixes/features should include tests.** You'll find a `test` folder in each package.

Note that _for the `browser` package only_, if you add a new file to the
[integration test suite](https://github.com/getsentry/sentry-javascript/tree/master/packages/browser/test/integration/suites),
you also need to add it to
[the list in `shell.js`](https://github.com/getsentry/sentry-javascript/blob/b74e199254147fd984e7bb1ea24193aee70afa74/packages/browser/test/integration/suites/shell.js#L25)
as well. Adding tests to existing files will work out of the box in all packages.
For browser related changes, you may also add tests in `dev-packages/browser-integration-tests`. Similarly, for node
integration tests can be added in `dev-packages/node-integration-tests`. Finally, we also have E2E test apps in
`dev-packages/e2e-tests`.

## Running Tests

Expand Down Expand Up @@ -112,79 +110,25 @@ Similar to building and testing, linting can be done in the project root or in i

Note: you must run `yarn build` before `yarn lint` will work.

## Considerations Before Sending Your First PR
## External Contributors

When contributing to the codebase, please note:

- Make sure to follow the [Commit, Issue & PR guidelines](#commit-issue--pr-guidelines)
- Non-trivial PRs will not be accepted without tests (see above).
- Please do not bump version numbers yourself.
- [`raven-js`](https://github.com/getsentry/sentry-javascript/tree/3.x/packages/raven-js) and
[`raven-node`](https://github.com/getsentry/sentry-javascript/tree/3.x/packages/raven-node) are deprecated, and only
bug and security fix PRs will be accepted targeting the
[3.x branch](https://github.com/getsentry/sentry-javascript/tree/3.x). Any new features and improvements should be to
our new SDKs (`browser`, `node`, and framework-specific packages like `react` and `nextjs`) and the packages which
support them (`core`, `utils`, `integrations`, and the like).

## PR reviews

For feedback in PRs, we use the [LOGAF scale](https://blog.danlew.net/2020/04/15/the-logaf-scale/) to specify how
important a comment is:

- `l`: low - nitpick. You may address this comment, but you don't have to.
- `m`: medium - normal comment. Worth addressing and fixing.
- `h`: high - Very important. We must not merge this PR without addressing this issue.
We highly appreciate external contributions to the SDK. If you want to contribute something, you can just open a PR
against `develop`.

You only need one approval from a maintainer to be able to merge. For some PRs, asking specific or multiple people for
review might be adequate.
The SDK team will check out your PR shortly!

Our different types of reviews:
When contributing to the codebase, please note:

1. **LGTM without any comments.** You can merge immediately.
2. **LGTM with low and medium comments.** The reviewer trusts you to resolve these comments yourself, and you don't need
to wait for another approval.
3. **Only comments.** You must address all the comments and need another review until you merge.
4. **Request changes.** Only use if something critical is in the PR that absolutely must be addressed. We usually use
`h` comments for that. When someone requests changes, the same person must approve the changes to allow merging. Use
this sparingly.
- Make sure to follow the [Commit, Issue & PR guidelines](./docs/commit-issue-pr-guidelines.md)
- Non-trivial PRs will not be accepted without tests (see above).

## Commit, Issue & PR guidelines

### Commits

For commit messages, we use the format:

```
<type>(<scope>): <subject> (<github-id>)
```

For example: `feat(core): Set custom transaction source for event processors (#5722)`.

See [commit message format](https://develop.sentry.dev/commit-messages/#commit-message-format) for details.

The Github-ID can be left out until the PR is merged.

### Issues

Issues should at least be categorized by package, for example `package: Node`. Additional labels for categorization can
be added, and the Sentry SDK team may also add further labels as needed.

### Pull Requests (PRs)

PRs are merged via `Squash and merge`. This means that all commits on the branch will be squashed into a single commit,
and committed as such onto master.

- The PR name can generally follow the commit name (e.g.
`feat(core): Set custom transaction source for event processors`)
- Make sure to rebase the branch on `master` before squashing it
- Make sure to update the commit message of the squashed branch to follow the commit guidelines - including the PR
number

### Gitflow
See [Commit, Issue & PR guidelines](./docs/commit-issue-pr-guidelines.md).

We use [Gitflow](https://docs.github.com/en/get-started/quickstart/github-flow) as a branching model.
## PR Reviews

For more details, [see our Gitflow docs](./docs/gitflow.md).
See [PR Reviews](./docs/pr-reviews.md).

## Publishing a Release

Expand Down
17 changes: 12 additions & 5 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@ convenient interface and improved consistency between various JavaScript environ

## Contents

- [Contributing](https://github.com/getsentry/sentry-javascript/blob/master/CONTRIBUTING.md)
- [Contributing](https://github.com/getsentry/sentry-javascript/blob/develop/CONTRIBUTING.md)
- [Supported Platforms](#supported-platforms)
- [Installation and Usage](#installation-and-usage)
- [Other Packages](#other-packages)
Expand All @@ -40,7 +40,6 @@ For each major JavaScript platform, there is a specific high-level SDK that prov
package. Please refer to the README and instructions of those SDKs for more detailed information:

- [`@sentry/browser`](https://github.com/getsentry/sentry-javascript/tree/master/packages/browser): SDK for Browsers
- [`@sentry/bun`](https://github.com/getsentry/sentry-javascript/tree/master/packages/bun): SDK for Bun
- [`@sentry/node`](https://github.com/getsentry/sentry-javascript/tree/master/packages/node): SDK for Node including
integrations for Express
- [`@sentry/angular`](https://github.com/getsentry/sentry-javascript/tree/master/packages/angular): Browser SDK for
Expand All @@ -52,6 +51,7 @@ package. Please refer to the README and instructions of those SDKs for more deta
- [`@sentry/sveltekit`](https://github.com/getsentry/sentry-javascript/tree/master/packages/sveltekit): SDK for
SvelteKit
- [`@sentry/vue`](https://github.com/getsentry/sentry-javascript/tree/master/packages/vue): Browser SDK for Vue
- [`@sentry/solid`](https://github.com/getsentry/sentry-javascript/tree/master/packages/solid): Browser SDK for Solid
- [`@sentry/gatsby`](https://github.com/getsentry/sentry-javascript/tree/master/packages/gatsby): SDK for Gatsby
- [`@sentry/nextjs`](https://github.com/getsentry/sentry-javascript/tree/master/packages/nextjs): SDK for Next.js
- [`@sentry/remix`](https://github.com/getsentry/sentry-javascript/tree/master/packages/remix): SDK for Remix
Expand All @@ -64,6 +64,13 @@ package. Please refer to the README and instructions of those SDKs for more deta
native crashes
- [`@sentry/capacitor`](https://github.com/getsentry/sentry-capacitor): SDK for Capacitor Apps and Ionic with support
for native crashes
- [`@sentry/bun`](https://github.com/getsentry/sentry-javascript/tree/master/packages/bun): SDK for Bun
- [`@sentry/deno`](https://github.com/getsentry/sentry-javascript/tree/master/packages/deno): SDK for Deno

## Version Support Policy

The current version of the SDK is 8.x. Version 7.x of the SDK will continue to receive critical bugfixes until end
of 2024.

## Installation and Usage

Expand All @@ -77,14 +84,14 @@ yarn add @sentry/browser
Setup and usage of these SDKs always follows the same principle.

```javascript
import { init, captureMessage } from '@sentry/browser';
import * as Sentry from '@sentry/browser';

init({
Sentry.init({
dsn: '__DSN__',
// ...
});

captureMessage('Hello, world!');
Sentry.captureMessage('Hello, world!');
```

## Other Packages
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -7,4 +7,5 @@ Sentry.init({
dsn: process.env.E2E_TEST_DSN,
tunnel: 'http://localhost:3031/', // proxy server
autoInstrumentRemix: true, // auto instrument Remix
integrations: [Sentry.nativeNodeFetchIntegration()],
});
Original file line number Diff line number Diff line change
Expand Up @@ -122,7 +122,9 @@ test('Should record a transaction for route with parameters', async ({ request }
});
});

test('Should record spans from http instrumentation', async ({ request }) => {
// This fails https://github.com/getsentry/sentry-javascript/pull/12587#issuecomment-2181019422
// Skipping this for now so we don't block releases
test.skip('Should record spans from http instrumentation', async ({ request }) => {
const transactionEventPromise = waitForTransaction('node-express-esm-preload', transactionEvent => {
return transactionEvent.contexts?.trace?.data?.['http.target'] === '/http-req';
});
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ console.log('Running build using esbuild version', esbuild.version);

esbuild.buildSync({
platform: 'node',
entryPoints: ['./index.js'],
entryPoints: ['./index.ts'],
outdir: './dist',
target: 'esnext',
format: 'cjs',
Expand Down
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
const Sentry = require('@sentry/node');
const { nodeProfilingIntegration } = require('@sentry/profiling-node');

const wait = ms => new Promise(resolve => setTimeout(resolve, ms));
const wait = (ms: number) => new Promise(resolve => setTimeout(resolve, ms));

Sentry.init({
dsn: 'https://7fa19397baaf433f919fbe02228d5470@o1137848.ingest.sentry.io/6625302',
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,11 +3,11 @@
"version": "1.0.0",
"private": true,
"scripts": {
"typecheck": "tsc --noEmit",
"build": "node build.mjs",
"start": "node index.js",
"test": "node index.js && node build.mjs",
"test": "npm run build && node dist/index.js",
"clean": "npx rimraf node_modules",
"test:build": "npm run build",
"test:build": "npm run typecheck && npm run build",
"test:assert": "npm run test"
},
"dependencies": {
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
{
"compilerOptions": {
"types": ["node"],
"esModuleInterop": true,
"lib": ["es2018"],
"strict": true,
"outDir": "dist",
"target": "ESNext",
"moduleResolution": "node",
"skipLibCheck": true
},
"include": ["index.ts"]
}
40 changes: 40 additions & 0 deletions docs/commit-issue-pr-guidelines.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,40 @@
# Commit, Issue & PR guidelines

## Commits

For commit messages, we use the format:

```
<type>(<scope>): <subject> (<github-id>)
```

For example: `feat(core): Set custom transaction source for event processors (#5722)`.

See [commit message format](https://develop.sentry.dev/commit-messages/#commit-message-format) for details.

The Github-ID can be left out until the PR is merged.

## Issues

Issues should at least be categorized by package, for example `package: Node`. Additional labels for categorization can
be added, and the Sentry SDK team may also add further labels as needed.

## Pull Requests (PRs)

PRs are merged via `Squash and merge`. This means that all commits on the branch will be squashed into a single commit,
and committed as such onto `develop`.

- The PR name can generally follow the commit name (e.g.
`feat(core): Set custom transaction source for event processors`)
- Make sure to rebase the branch on `develop` before squashing it
- Make sure to update the commit message of the squashed branch to follow the commit guidelines - including the PR
number

Please note that we cannot _enforce_ Squash Merge due to the usage of Gitflow (see below). Github remembers the last
used merge method, so you'll need to make sure to double check that you are using "Squash and Merge" correctly.

## Gitflow

We use [Gitflow](https://docs.github.com/en/get-started/quickstart/github-flow) as a branching model.

For more details, [see our Gitflow docs](./gitflow.md).
42 changes: 42 additions & 0 deletions docs/pr-reviews.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,42 @@
# PR reviews

Make sure to open PRs against `develop` branch.

For feedback in PRs, we use the [LOGAF scale](https://blog.danlew.net/2020/04/15/the-logaf-scale/) to specify how
important a comment is:

- `l`: low - nitpick. You may address this comment, but you don't have to.
- `m`: medium - normal comment. Worth addressing and fixing.
- `h`: high - Very important. We must not merge this PR without addressing this issue.

You only need one approval from a maintainer to be able to merge. For some PRs, asking specific or multiple people for
review might be adequate. You can either assign SDK team members directly (e.g. if you have some people in mind who are
well suited to review a PR), or you can assign `getsentry/team-web-sdk-frontend`, which will randomly pick 2 people from
the team to assign.

Our different types of reviews:

1. **LGTM without any comments.** You can merge immediately.
2. **LGTM with low and medium comments.** The reviewer trusts you to resolve these comments yourself, and you don't need
to wait for another approval.
3. **Only comments.** You must address all the comments and need another review until you merge.
4. **Request changes.** Only use if something critical is in the PR that absolutely must be addressed. We usually use
`h` comments for that. When someone requests changes, the same person must approve the changes to allow merging. Use
this sparingly.

You show generally avoid to use "Auto merge". The reason is that we have some CI workflows which do not block merging
(e.g. flaky test detection, some optional E2E tests). If these fail, and you enabled Auto Merge, the PR will be merged
if though some workflow(s) failed. To avoid this, wait for CI to pass to merge the PR manually, or only enable "Auto
Merge" if you know that no optional workflow may fail. Another reason is that, as stated above in 2., reviewers may
leave comments and directly approve the PR. In this case, as PR author you should review the comments and choose which
to implement and which may be ignored for now. "Auto Merge" leads to the PR feedback not being taken into account.

## Reviewing a PR from an external contributor

1. Make sure to review PRs from external contributors in a timely fashion. These users spent their valuable time to
improve our SDK, so we should not leave them hanging with a review!
2. Make sure to click "Approve and Run" on the CI for the PR, if it does not seem malicious.
3. Provide feedback and guidance if the PR is not ready to be merged.
4. Assign the PR to yourself if you start reviewing it. You are then responsible for guiding the PR either to
completion, or to close it if it does not align with the goals of the SDK team.
5. Make sure to update the PR name to align with our commit name structure (see above)
Loading

0 comments on commit 11090b8

Please sign in to comment.