Skip to content

Commit

Permalink
Iterate on docs
Browse files Browse the repository at this point in the history
  • Loading branch information
psrpinto committed Dec 6, 2024
1 parent f6b1abd commit 09076ae
Showing 1 changed file with 43 additions and 10 deletions.
53 changes: 43 additions & 10 deletions packages/docs/site/docs/main/contributing/code.md
Original file line number Diff line number Diff line change
Expand Up @@ -87,13 +87,38 @@ Playground consists of a number of packages, some of which are published to npmj

Additionally, it's possible to test-publish packages to a local registry, so that changes can be tested without publishing the package to npmjs.com.

### How it works
The release process is automated through [lerna](https://lerna.js.org).

### Versioning strategy

Playground's versioning strategy is to use the same version for all packages, **but** only packages that need to be released are bumped to the new version. As an example, lets consider the following scenario:

- All packages are currently at `v1.0.0`
- The following packages have changes since `v1.0.0`: `@wp-playground/cli` and `@wp-playground/remote`

When we issue a new release, only `@wp-playground/cli` and `@wp-playground/remote` will be bumped to `v1.0.1`, and all other packages will remain at `v1.0.0`.

### Authenticating with npmjs.com

TODO

### Issuing a new release

Normally, packages are automatically published through a [GitHub Action](https://github.com/WordPress/wordpress-playground/actions/workflows/publish-npm-packages.yml), but if you so wish, you can release from your machine as well.

The release process is automated through [lerna](https://lerna.js.org), which automatically figures out which packages need to be released, and what the new version should be. To issue a new release, you call `lerna` through the following script:

> Please note that the following command **will publish packages to npmjs.com** (provided that you are authenticated with an account that has permissions to do so).
```shell
npm run release
```

### Publishing to a local registry

Instead of publishing to npmjs.com, you can publish packages to a local registry that is running in your machine. This local registry is provided by [verdaccio](https://verdaccio.org).
Instead of publishing to npmjs.com, you can publish packages to a local registry that is running in your machine. This local registry is provided by [verdaccio](https://verdaccio.org). The sections below describe how to do this.

### Enabling the local registry

Start the local registry with:

Expand All @@ -103,26 +128,34 @@ npm run local-registry:start

> You should now be able to access the local registry's UI at [http://localhost:4873](http://localhost:4873)
Now that the local registry is running, we want `npm` commands to go to it instead of npmjs.com. You can switch the target registry of `npm` with the following command:
To switch the target registry of `npm` so that it uses the local registry instead of npmjs.com, you can use the following command:

```shell
npm run local-registry:enable
```

At this point, all `npm` commands will target the local registry, so you can publish packages as you would normally, but they will be published to the local registry instead.
### Releasing to the local registry

To make `npm` talk to npmjs.com again, you need to disable the local-registry:
At this point, the local registry is running and all `npm` commands will target it, so you can publish packages as you normally would, but they will be published to the local registry instead:

```shell
npm run local-registry:disable
# Note that we're using `release:no-push` instead of `release` because we don't
# want commits or tags to be created, as we're just test-publishing.
npm run release:no-push
```

To clear all data of the local registry (useful if, for example, you have test-published a package and want to test-publish it again), you can use the following script:
Once the above command has ran, packages have been published to the local registry, and should be visible (and downloadable) from the local registry's UI at [http://localhost:4873](http://localhost:4873).

### Disabling the local registry

To disable the local registry, and make `npm` talk to npmjs.com again, you can:

```shell
npm run local-registry:clear
npm run local-registry:disable
```

### Publishing to npmjs.com
To clear all data of the local registry (useful if, for example, you have test-published a package and want to test-publish it again), you can use the following:

TODO
```shell
npm run local-registry:clear
```

0 comments on commit 09076ae

Please sign in to comment.