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

doc: document node-api version process #47972

Merged
merged 2 commits into from
May 19, 2023
Merged
Changes from 1 commit
Commits
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
186 changes: 186 additions & 0 deletions doc/contributing/releases-node-api.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,186 @@
# Node.js Node-API version release process

This document describes the technical aspects of the Node.js Node-API version
release process.

## Table of contents

* [How to create a release](#how-to-create-a-release)
* [0. Pre-release steps](#0-pre-release-steps)
* [1. Update the main branch](#1-update-the-main-branch)
* [2. Create a new branch for the release](#2-create-a-new-branch-for-the-release)
* [3. Update `NAPI_VERSION`](#3-update-napi_version)
* [4. Update version guards](#4-update-version-guards)
* [5. Create release commit](#5-create-release-commit)
* [6. Propose release on GitHub](#6-propose-release-on-github)
* [7. Ensure that the release branch is stable](#7-ensure-that-the-release-branch-is-stable)
* [8. Land the release](#8-land-the-release)

## How to create a release

Notes:

* Version strings are listed below as _"vx"_ or _"x"_. Substitute for
the release version.
* Examples will use the integer release version `10`.

### 0. Pre-release steps

Before preparing a Node.js Node-API version release, the Node-API Working Group
must be notified at least one business day in advance of the expected release.

Node-API Working Group can be contacted best by opening up an issue on the
[abi-stable-node issue tracker][].

### 1. Update the main Branch

Checkout the staging branch locally.

```console
$ git remote update
$ git checkout main
$ git reset --hard upstream/main
```

If the staging branch is not up to date relative to `main`, bring the
appropriate PRs and commits into it.

### 2. Create a new branch for the release

Create a new branch named `node-api-x-proposal`, off the main branch.

```console
$ git checkout -b node-api-10-proposal upstream/main
```

### 3. Update `NAPI_VERSION`

Set the version for the proposed release using the following macros, which are
already defined in `src/node_version.h`:

```c
#define NAPI_VERSION x
```

> Note: Do not update the `NAPI_VERSION` defined in `src/js_native_api.h`. It
> is a fixed constant baseline version of Node-API.

### 4. Update version guards

#### Step 1. Update define version guards

If this release includes new Node-APIs that were first released in this
version. The relevant commits should already include the `NAPI_EXPERIMENTAL`
legendecas marked this conversation as resolved.
Show resolved Hide resolved
define guards on the declaration of the new Node-API. Check for these guards
with:

```console
grep NAPI_EXPERIMENTAL src/js_native_api{_types,}.h src/node_api{_types,}.h
```

and update the define version guards with the release version:

```diff
- #ifdef NAPI_EXPERIMENTAL
+ #if NAPI_VERSION >= 10

NAPI_EXTERN napi_status NAPI_CDECL
node_api_function(napi_env env);

- #endif // NAPI_EXPERIMENTAL
+ #endif // NAPI_VERSION >= 10
```

Also, update the Node-API version value of the `napi_get_version` test in
`test/js-native-api/test_general/test.js` with the release version `x`:

```diff
// Test version management functions
- assert.strictEqual(test_general.testGetVersion(), 9);
+ assert.strictEqual(test_general.testGetVersion(), 10);
```

#### Step 2. Update runtime version guards

If this release includes runtime behavior version guards, the relevant commits
should already include `NAPI_EXPERIMENTAL` guard for the change. Check for
legendecas marked this conversation as resolved.
Show resolved Hide resolved
these guards with:

```console
grep NAPI_EXPERIMENTAL src/js_native_api_v8* src/node_api.cc
legendecas marked this conversation as resolved.
Show resolved Hide resolved
```

and substitute this guard version with the release version `x`.

#### Step 4. Update test version guards
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
#### Step 4. Update test version guards
#### Step 3. Update test version guards

The next step is step 4.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks, updated!


If this release includes add-on tests for the new Node-APIs, the relevant
commits should already include `NAPI_EXPERIMENTAL` definition for the tests.
Check for these definitions with:

```console
grep NAPI_EXPERIMENTAL test/node-api/*/*.{h,c} test/js-native-api/*/*.{h,c}
legendecas marked this conversation as resolved.
Show resolved Hide resolved
```

and substitute the `NAPI_EXPERIMENTAL` with the release version
`NAPI_VERSION x`;

```diff
- #define NAPI_EXPERIMENTAL
+ #define NAPI_VERSION 10
```

#### Step 4. Update document

If this release includes new Node-APIs that were first released in this
version and necessary to document, the relevant commits should already
legendecas marked this conversation as resolved.
Show resolved Hide resolved
documented the new Node-API.
legendecas marked this conversation as resolved.
Show resolved Hide resolved
legendecas marked this conversation as resolved.
Show resolved Hide resolved

For each Node-API functions and types with define guards updated in Step 1,
legendecas marked this conversation as resolved.
Show resolved Hide resolved
in `doc/api/n-api.md`, add the `napiVersion: x` metadata to the Node-API types
and functions that are released in the version, and remove the experimental
stability banner:

```diff
#### node_api_function
<!-- YAML
added:
- v1.2.3
+ napiVersion: 10
-->

- > Stability: 1 - Experimental
```

legendecas marked this conversation as resolved.
Show resolved Hide resolved
### 5. Create release commit

When committing these to git, use the following message format:

```text
node-api: define version x
```

### 6. Propose release on GitHub

Create a pull request targeting the `main` branch. These PRs should be left
open for at least 24 hours, and can be updated as new commits land.

If you need any additional information about any of the commits, this PR is a
good place to @-mention the relevant contributors.

Tag the PR with label `notable-change`, and @-mention the GitHub team
legendecas marked this conversation as resolved.
Show resolved Hide resolved
@nodejs/node-api and @nodejs/node-api-implementer.

### 7. Ensure that the release branch is stable

Run a **[`node-test-pull-request`](https://ci.nodejs.org/job/node-test-pull-request/)**
test run to ensure that the build is stable and the HEAD commit is ready for
release.

### 8. Land the release

See the steps documented in [Collaborator Guide - Landing a PR][] to land the
PR.

legendecas marked this conversation as resolved.
Show resolved Hide resolved
[Collaborator Guide - Landing a PR]: ./collaborator-guide.md#landing-pull-requests
[abi-stable-node issue tracker]: https://github.com/nodejs/abi-stable-node/issues