2020-04-30 14:52:54 +03:00
# ci
This directory contains scripts used for code-server's continuous integration infrastructure.
2020-05-17 23:53:08 +03:00
Some of these scripts contain more detailed documentation and options
in header comments.
2020-04-30 14:52:54 +03:00
2020-05-17 23:53:08 +03:00
Any file or directory in this subdirectory should be documented here.
- [./ci/lib.sh ](./lib.sh )
- Contains code duplicated across these scripts.
2020-04-30 14:52:54 +03:00
2020-05-08 08:42:46 +03:00
## Publishing a release
2021-03-23 20:52:35 +03:00
1. Run `yarn release:prep` and type in the new version i.e. 3.8.1
2020-05-17 23:53:08 +03:00
2. GitHub actions will generate the `npm-package` , `release-packages` and `release-images` artifacts.
2020-09-03 09:16:57 +03:00
1. You do not have to wait for these.
2020-05-14 10:17:17 +03:00
3. Run `yarn release:github-draft` to create a GitHub draft release from the template with
2020-05-12 00:08:22 +03:00
the updated version.
1. Summarize the major changes in the release notes and link to the relevant issues.
2021-02-13 00:09:50 +03:00
2. Change the @ to target the version branch. Example: `v3.9.0 @ Target: v3.9.0`
2020-05-17 23:53:08 +03:00
4. Wait for the artifacts in step 2 to build.
2020-09-03 09:16:57 +03:00
5. Run `yarn release:github-assets` to download the `release-packages` artifact.
- It will upload them to the draft release.
2020-05-17 23:53:08 +03:00
6. Run some basic sanity tests on one of the released packages.
2020-09-03 09:16:57 +03:00
- Especially make sure the terminal works fine.
2020-06-04 23:31:01 +03:00
7. Make sure the github release tag is the commit with the artifacts. This is a bug in
`hub` where uploading assets in step 5 will break the tag.
2020-05-19 04:30:24 +03:00
8. Publish the release and merge the PR.
2020-05-17 23:53:08 +03:00
1. CI will automatically grab the artifacts and then:
1. Publish the NPM package from `npm-package` .
2. Publish the Docker Hub image from `release-images` .
2020-05-20 08:16:41 +03:00
9. Update the AUR package.
- Instructions on updating the AUR package are at [cdr/code-server-aur ](https://github.com/cdr/code-server-aur ).
10. Wait for the npm package to be published.
2021-02-24 22:23:44 +03:00
11. Update the [homebrew package ](https://github.com/Homebrew/homebrew-core/blob/master/Formula/code-server.rb ).
1. Install [homebrew ](https://brew.sh/ )
2. Run `brew bump-formula-pr --version=3.8.1 code-server` and update the version accordingly. This will bump the version and open a PR. Note: this will only work once the version is published on npm.
2020-05-08 08:42:46 +03:00
2021-01-25 20:34:51 +03:00
## Updating Code Coverage in README
Currently, we run a command to manually generate the code coverage shield. Follow these steps:
2021-03-10 02:35:25 +03:00
1. Run `yarn test:unit` and make sure all the tests are passing
2021-02-12 23:54:42 +03:00
2. Run `yarn badges`
3. Go into the README and change the color from `red` to `green` in this line:
2021-01-25 20:34:51 +03:00
```
![Lines ](https://img.shields.io/badge/Coverage-46.71%25-red.svg )
```
NOTE: we have to manually change the color because the default is red if coverage is less than 80. See code [here ](https://github.com/olavoparno/istanbul-badges-readme/blob/develop/src/editor.ts#L24-L33 ).
2020-04-30 14:52:54 +03:00
## dev
This directory contains scripts used for the development of code-server.
2020-06-03 19:09:01 +03:00
- [./ci/dev/image ](./dev/image )
2021-02-03 19:32:35 +03:00
- See [./docs/CONTRIBUTING.md ](../docs/CONTRIBUTING.md ) for docs on the development container.
2020-05-17 23:53:08 +03:00
- [./ci/dev/fmt.sh ](./dev/fmt.sh ) (`yarn fmt`)
- Runs formatters.
- [./ci/dev/lint.sh ](./dev/lint.sh ) (`yarn lint`)
- Runs linters.
2021-03-10 02:35:25 +03:00
- [./ci/dev/test-unit.sh ](./dev/test-unit.sh ) (`yarn test:unit`)
- Runs unit tests.
- [./ci/dev/test-e2e.sh ](./dev/test-e2e.sh ) (`yarn test:e2e`)
- Runs end-to-end tests.
2020-05-17 23:53:08 +03:00
- [./ci/dev/ci.sh ](./dev/ci.sh ) (`yarn ci`)
- Runs `yarn fmt` , `yarn lint` and `yarn test` .
- [./ci/dev/watch.ts ](./dev/watch.ts ) (`yarn watch`)
- Starts a process to build and launch code-server and restart on any code changes.
2021-02-03 19:32:35 +03:00
- Example usage in [./docs/CONTRIBUTING.md ](../docs/CONTRIBUTING.md ).
2020-12-01 03:11:26 +03:00
- [./ci/dev/gen_icons.sh ](./ci/dev/gen_icons.sh ) (`yarn icons`)
- Generates the various icons from a single `.svg` favicon in
`src/browser/media/favicon.svg` .
- Requires [imagemagick ](https://imagemagick.org/index.php )
2020-04-30 14:52:54 +03:00
## build
2020-05-12 00:08:22 +03:00
This directory contains the scripts used to build and release code-server.
2020-05-08 07:34:20 +03:00
You can disable minification by setting `MINIFY=` .
2020-04-30 14:52:54 +03:00
2020-05-17 23:53:08 +03:00
- [./ci/build/build-code-server.sh ](./build/build-code-server.sh ) (`yarn build`)
- Builds code-server into `./out` and bundles the frontend into `./dist` .
- [./ci/build/build-vscode.sh ](./build/build-vscode.sh ) (`yarn build:vscode`)
- Builds vscode into `./lib/vscode/out-vscode` .
- [./ci/build/build-release.sh ](./build/build-release.sh ) (`yarn release`)
2020-05-08 06:48:49 +03:00
- Bundles the output of the above two scripts into a single node module at `./release` .
2020-05-27 23:39:17 +03:00
- [./ci/build/build-standalone-release.sh ](./build/build-standalone-release.sh ) (`yarn release:standalone`)
2020-05-17 23:53:08 +03:00
- Requires a node module already built into `./release` with the above script.
2020-05-27 23:39:17 +03:00
- Will build a standalone release with node and node_modules bundled into `./release-standalone` .
2020-05-17 23:53:08 +03:00
- [./ci/build/clean.sh ](./build/clean.sh ) (`yarn clean`)
- Removes all build artifacts.
- Useful to do a clean build.
- [./ci/build/code-server.sh ](./build/code-server.sh )
2020-05-27 23:39:17 +03:00
- Copied into standalone releases to run code-server with the bundled node binary.
- [./ci/build/test-standalone-release.sh ](./build/test-standalone-release.sh ) (`yarn test:standalone-release`)
- Ensures code-server in the `./release-standalone` directory works by installing an extension.
2020-05-17 23:53:08 +03:00
- [./ci/build/build-packages.sh ](./build/build-packages.sh ) (`yarn package`)
2020-05-27 23:39:17 +03:00
- Packages `./release-standalone` into a `.tar.gz` archive in `./release-packages` .
2020-05-17 23:53:08 +03:00
- If on linux, [nfpm ](https://github.com/goreleaser/nfpm ) is used to generate `.deb` and `.rpm` .
- [./ci/build/nfpm.yaml ](./build/nfpm.yaml )
- Used to configure [nfpm ](https://github.com/goreleaser/nfpm ) to generate `.deb` and `.rpm` .
- [./ci/build/code-server-nfpm.sh ](./build/code-server-nfpm.sh )
2020-05-28 01:04:36 +03:00
- Entrypoint script for code-server for `.deb` and `.rpm` .
2020-05-17 23:53:08 +03:00
- [./ci/build/code-server.service ](./build/code-server.service )
- systemd user service packaged into the `.deb` and `.rpm` .
- [./ci/build/release-github-draft.sh ](./build/release-github-draft.sh ) (`yarn release:github-draft`)
- Uses [hub ](https://github.com/github/hub ) to create a draft release with a template description.
- [./ci/build/release-github-assets.sh ](./build/release-github-assets.sh ) (`yarn release:github-assets`)
- Downloads the release-package artifacts for the current commit from CI.
2020-05-12 00:08:22 +03:00
- Uses [hub ](https://github.com/github/hub ) to upload the artifacts to the release
2020-05-17 23:53:08 +03:00
specified in `package.json` .
- [./ci/build/npm-postinstall.sh ](./build/npm-postinstall.sh )
- Post install script for the npm package.
- Bundled by`yarn release`.
2020-04-30 14:52:54 +03:00
2020-06-03 19:07:42 +03:00
## release-image
2020-04-30 14:52:54 +03:00
2020-06-03 19:07:42 +03:00
This directory contains the release docker container image.
2020-04-30 14:52:54 +03:00
2020-06-03 19:07:42 +03:00
- [./release-image/build.sh ](./release-image/build.sh )
2020-05-17 23:53:08 +03:00
- Builds the release container with the tag `codercom/code-server-$ARCH:$VERSION` .
- Assumes debian releases are ready in `./release-packages` .
2020-05-08 23:31:42 +03:00
2020-06-03 19:07:42 +03:00
## images
2020-04-30 14:52:54 +03:00
2020-06-03 19:07:42 +03:00
This directory contains the images for CI.
2020-04-30 14:52:54 +03:00
## steps
2020-05-17 23:53:08 +03:00
This directory contains the scripts used in CI.
Helps avoid clobbering the CI configuration.
2020-04-30 14:52:54 +03:00
2020-05-13 02:33:34 +03:00
- [./steps/fmt.sh ](./steps/fmt.sh )
2021-03-10 02:35:25 +03:00
- Runs `yarn fmt` .
2020-05-13 02:33:34 +03:00
- [./steps/lint.sh ](./steps/lint.sh )
2021-03-10 02:35:25 +03:00
- Runs `yarn lint` .
- [./steps/test-unit.sh ](./steps/test-unit.sh )
- Runs `yarn test:unit` .
- [./steps/test-e2e.sh ](./steps/test-e2e.sh )
- Runs `yarn test:e2e` .
2020-05-08 03:44:32 +03:00
- [./steps/release.sh ](./steps/release.sh )
2020-05-17 23:53:08 +03:00
- Runs the release process.
- Generates the npm package at `./release` .
2020-05-27 23:39:17 +03:00
- [./steps/release-packages.sh ](./steps/release-packages.sh )
- Takes the output of the previous script and generates a standalone release and
release packages into `./release-packages` .
2020-05-08 10:08:30 +03:00
- [./steps/publish-npm.sh ](./steps/publish-npm.sh )
2020-05-17 23:53:08 +03:00
- Grabs the `npm-package` release artifact for the current commit and publishes it on npm.
2020-05-16 17:55:46 +03:00
- [./steps/build-docker-image.sh ](./steps/build-docker-image.sh )
2020-05-17 23:53:08 +03:00
- Builds the docker image and then saves it into `./release-images/code-server-$ARCH-$VERSION.tar` .
2020-05-16 17:55:46 +03:00
- [./steps/push-docker-manifest.sh ](./steps/push-docker-manifest.sh )
- Loads all images in `./release-images` and then builds and pushes a multi architecture
docker manifest for the amd64 and arm64 images to `codercom/code-server:$VERSION` and
2020-05-17 23:53:08 +03:00
`codercom/code-server:latest` .