README.md 6.6 KB
Newer Older
1 2 3 4 5 6 7 8
# ci

This directory contains scripts used for code-server's continuous integration infrastructure.

Many of these scripts contain more detailed documentation and options in comments at the top.

Any file and directory added into this tree should be documented here.

A
Anmol Sethi 已提交
9 10
## Publishing a release

A
Anmol Sethi 已提交
11 12
Make sure you have `$GITHUB_TOKEN` set and [hub](https://github.com/github/hub) installed.

A
Anmol Sethi 已提交
13 14 15
1. Update the version of code-server in `package.json` and README.md/guide.md install examples and push a commit
2. GitHub actions will generate the `npm-package` and `release-packages` artifacts
3. Run `yarn release:github-draft` to create a GitHub draft release from the template with
A
Anmol Sethi 已提交
16 17
   the updated version.
   1. Summarize the major changes in the release notes and link to the relevant issues.
A
Anmol Sethi 已提交
18 19 20 21
4. Wait for the artifacts in step 2 to build
5. Run `yarn release:github-assets` to download the artifacts and then upload them to the draft release
6. Run some basic sanity tests on one of the released packages
7. Publish the release
22 23
   1. CI will automatically grab the artifacts and then
      1. Publish the NPM package
24
      2. Publish the Docker Hub image
A
3.3.0  
Anmol Sethi 已提交
25
8. Update the homebrew and AUR packages
A
Anmol Sethi 已提交
26

27 28 29 30 31 32 33
## dev

This directory contains scripts used for the development of code-server.

- [./dev/container](./dev/container)
  - See [CONTRIBUTING.md](../doc/CONTRIBUTING.md) for docs on the development container
- [./dev/ci.sh](./dev/ci.sh) (`yarn ci`)
A
Anmol Sethi 已提交
34
  - Runs `yarn fmt`, `yarn lint` and `yarn test`
35 36 37 38 39 40 41
- [./dev/fmt.sh](./dev/fmt.sh) (`yarn fmt`)
  - Runs formatters
- [./dev/lint.sh](./dev/lint.sh) (`yarn lint`)
  - Runs linters
- [./dev/test.sh](./dev/test.sh) (`yarn test`)
  - Runs tests
- [./dev/vscode.sh](./dev/vscode.sh) (`yarn vscode`)
42 43 44 45 46
  - Ensures [../lib/vscode](../lib/vscode) is cloned, patched and dependencies are installed
- [./dev/patch-vscode.sh](./dev/patch-vscode.sh) (`yarn vscode:patch`)
  - Applies [./dev/vscode.patch](./dev/vscode.patch) to [../lib/vscode](../lib/vscode)
- [./dev/diff-vscode.sh](./dev/diff-vscode.sh) (`yarn vscode:diff`)
  - Diffs [../lib/vscode](../lib/vscode) into [./dev/vscode.patch](./dev/vscode.patch)
47 48 49 50 51 52 53 54 55
- [./dev/vscode.patch](./dev/vscode.patch)
  - Our patch of VS Code to enable remote browser access
  - Generate it with `yarn vscode:diff` and apply with `yarn vscode:patch`
- [./dev/watch.ts](./dev/watch.ts) (`yarn watch`)
  - Starts a process to build and launch code-server and restart on any code changes
  - Example usage in [CONTRIBUTING.md](../doc/CONTRIBUTING.md)

## build

A
Anmol Sethi 已提交
56
This directory contains the scripts used to build and release code-server.
57
You can disable minification by setting `MINIFY=`.
58

59 60
- [./lib.sh](./lib.sh)
  - Contains code duplicated across these scripts.
61 62 63 64 65
- [./build/build-code-server.sh](./build/build-code-server.sh) (`yarn build`)
  - Builds code-server into ./out and bundles the frontend into ./dist.
- [./build/build-vscode.sh](./build/build-vscode.sh) (`yarn build:vscode`)
  - Builds vscode into ./lib/vscode/out-vscode.
- [./build/build-release.sh](./build/build-release.sh) (`yarn release`)
66 67 68
  - Bundles the output of the above two scripts into a single node module at `./release`.
- [./build/build-static-release.sh](./build/build-static-release.sh) (`yarn release:static`)
  - Requires a release already built in `./release`.
69
  - Will build a static release with node bundled into `./release-static`
70
- [./build/clean.sh](./build/clean.sh) (`yarn clean`)
71
  - Removes all build artifacts
72
  - Will also `git reset --hard lib/vscode`
73
  - Useful to do a clean build
74 75
- [./build/code-server.sh](./build/code-server.sh)
  - Copied into static releases to run code-server with the bundled node binary.
76
- [./build/test-static-release.sh](./build/test-static-release.sh) (`yarn test:static-release`)
77
  - Ensures code-server in the `./release-static` directory runs
78
- [./build/build-packages.sh](./build/build-packages.sh) (`yarn package`)
79 80
  - Packages `./release-static` into an archive in `./release-packages`
  - If on linux, [nfpm](https://github.com/goreleaser/nfpm) is used to generate .deb and .rpm
81 82 83 84
- [./build/nfpm.yaml](./build/nfpm.yaml)
  - Used to configure [nfpm](https://github.com/goreleaser/nfpm) to generate .deb and .rpm
- [./build/code-server-nfpm.sh](./build/code-server-nfpm.sh)
  - Entrypoint script for code-server for .deb and .rpm
85 86
- [./build/code-server.service](./build/code-server.service)
  - systemd user service packaged into the debs and rpms
A
Anmol Sethi 已提交
87 88 89 90 91 92
- [./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
- [./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
  - Uses [hub](https://github.com/github/hub) to upload the artifacts to the release
    specified in `package.json`
93 94 95
- [./build/npm-postinstall.sh](./build/npm-postinstall.sh)
  - Post install script for the npm package
  - Bundled by`yarn release`
96 97 98 99 100

## release-container

This directory contains the release docker container.

101
- [./release-container/build.sh](./release-container/build.sh)
102
  - Builds the release container with the tag `codercom/code-server:$VERSION-$ARCH`
103 104
  - Assumes debian releases are ready in `./release-packages`

105 106 107 108 109 110
## container

This directory contains the container for CI.

## steps

A
Anmol Sethi 已提交
111
This directory contains a few scripts used in CI.
112
Just helps avoid clobbering the CI configuration.
113

A
Anmol Sethi 已提交
114 115 116 117
- [./steps/fmt.sh](./steps/fmt.sh)
  - Runs `yarn fmt` after ensuring VS Code is patched
- [./steps/lint.sh](./steps/lint.sh)
  - Runs `yarn lint` after ensuring VS Code is patched
118
- [./steps/test.sh](./steps/test.sh)
A
Anmol Sethi 已提交
119
  - Runs `yarn test` after ensuring VS Code is patched
A
Anmol Sethi 已提交
120
- [./steps/release.sh](./steps/release.sh)
121 122 123
  - Runs the full release process
  - Generates the npm package at `./release`
- [./steps/static-release.sh](./steps/static-release.sh)
124
  - Takes the output of the previous script and generates a static release and packages
A
Anmol Sethi 已提交
125 126 127 128
- [./steps/lib.sh](./steps/lib.sh)
  - Contains helpers to download artifacts from github actions workflow runs
- [./steps/publish-npm.sh](./steps/publish-npm.sh)
  - Grabs the `npm-package` release artifact for the current commit and publishes it on NPM
129 130 131 132 133 134
- [./steps/build-docker-image.sh](./steps/build-docker-image.sh)
  - Builds the docker image and then saves it into `./release-images/$ARCH.tar`
- [./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
    `codercom/code-server:latest`