code-server/docs/MAINTAINING.md
Olivier Benz fc6064dcd3
Update Code to 1.94.2 (#7026)
* Update Code to 1.94.2

* Convert from yarn to npm

This is to match VS Code.  We were already partially using npm for the
releases so this is some nice alignment.

* Update caniuse-lite

This was complaining on every unit test.

* Update eslint

I was having a bunch of dependency conflicts and eslint seemed to be the
culprit so I just removed it and set it up again, since it seems things
have changed quite a bit.

* Update test dependencies

I was getting oom when running the unit tests...updating seems to work.

* Remove package.json `scripts` property in release

The new pre-install script was being included, which is dev-only.

This was always the intent; did not realize jq's merge was recursive.

* Remove jest and devDependencies in release as well

* Update test extension dependencies

This appears to be conflicting with the root dependencies.

* Fix playwright exec

npm does not let you run binaries like yarn does, as far as I know.

* Fix import of server-main.js

* Fix several tests by waiting for selectors
2024-10-17 20:32:21 -08:00

4.6 KiB

Maintaining

We keep code-server up to date with VS Code releases (there are usually two or three a month) but we are not generally actively developing code-server aside from fixing regressions.

Most of the work is keeping on top of issues and discussions.

Releasing

  1. Check that the changelog lists all the important changes.
  2. Make sure the changelog entry lists the current version of VS Code.
  3. Update the changelog with the release date.
  4. Go to GitHub Actions > Draft release > Run workflow on the commit you want to release. Make sure CI has finished the build workflow on that commit or this will fail. For the version we match VS Code's minor and patch version. The patch number may become temporarily out of sync if we need to put out a patch, but if we make our own minor change then we will not release it until the next minor VS Code release.
  5. CI will automatically grab the build artifact on that commit (which is why CI has to have completed), inject the provided version into the package.json, put together platform-specific packages, and upload those packages to a draft release.
  6. Update the resulting draft release with the changelog contents.
  7. Publish the draft release after validating it.
  8. Bump the Helm chart version once the Docker images have published.

Release Candidates

We prefer to do release candidates so the community can test things before a full-blown release. To do this follow the same steps as above but:

  1. Add a -rc.<number> suffix to the version.
  2. When you publish the release select "pre-release". CI will not automatically publish pre-releases.
  3. Do not update the chart version or merge in the changelog until the final release.

AUR

We publish to AUR as a package here. This process is manual and can be done by following the steps in this repo.

Docker

We publish code-server as a Docker image here, tagging it both with the version and latest.

This is currently automated with the release process.

Homebrew

We publish code-server on Homebrew here.

This is currently automated with the release process (but may fail occasionally). If it does, run this locally:

# Replace VERSION with version
brew bump-formula-pr --version="${VERSION}" code-server --no-browse --no-audit

nixpkgs

We publish code-server in nixpkgs but it must be updated manually.

npm

We publish code-server as a npm package here.

This is currently automated with the release process.

Testing

Our testing structure is laid out under our Contributing docs.

If you're ever looking to add more tests, here are a few ways to get started:

  • run npm run test:unit and look at the coverage chart. You'll see all the uncovered lines. This is a good place to start.
  • look at test/scripts to see which scripts are tested. We can always use more tests there.
  • look at test/e2e. We can always use more end-to-end tests.

Otherwise, talk to a current maintainer and ask which part of the codebase is lacking most when it comes to tests.

Documentation

Troubleshooting

Our docs are hosted on Vercel. Vercel only shows logs in realtime, which means you need to have the logs open in one tab and reproduce your error in another tab. Since our logs are private to Coder the organization, you can only follow these steps if you're a Coder employee. Ask a maintainer for help if you need it.

Taking a real scenario, let's say you wanted to troubleshoot this docs change. Here is how you would do it:

  1. Go to https://vercel.com/codercom/codercom
  2. Click "View Function Logs"
  3. In a separate tab, open the preview link from github-actions-bot
  4. Now look at the function logs and see if there are errors in the logs