We'll use 3.9.0 as the example. Note this looks long because there's a lot of explanations, assuming everything compiles then it'll probably take about 15-30m.
The website uses one version of TypeScript which you can find in the root package.json
inside the resolutions
field. It's always a specific version, so change the version to:
"resolutions": {
"typescript": "3.9.0-beta",
},
Then run yarn install
.
That will update all of the site to use 3.9.0 for building. Run yarn build
to see if any of the website's code broke.
You might see issues with yarn patching TypeScript, if so, try run: yarn set version latest
first to update to the latest yarn.
Then empty the twoslash cache: rm node_modules/.cache/twoslash
.
You might have a new reference doc to add, they live in packages/documentation/copy
. You can ignore languages other than en
. The folder structure is only for your reference and has no bearing on the site navigation. Each markdown document needs a header like:
---
title: Basic Types
layout: docs
permalink: /docs/handbook/basic-types.html
oneline: "Step one in learning TypeScript: The basic types."
---
Or the site will fail the build. Once that file is ready, add it to the sidebar via the file packages/documentation/scripts/generateDocsNavigationPerLanguage.js
.
The source of truth for the JSON Schema is https://github.com/SchemaStore/schemastore/blob/master/src/schemas/json/tsconfig.json
To download a copy of that into our repo to handle new PRs sent to it in-between TS releases, run: node ./node_modules/.bin/ts-node packages/tsconfig-reference/scripts/schema/downloadSchemaBase.ts
Updating the version of TypeScript will force you to update the TSConfig Reference and JSON Schema. It will fail incrementally with each missing compiler flag.
For each new flag:
-
Add a markdown file for the new compiler flags. The build will crash and give you a command to run which will set that up.
-
Add the flag to the JSON schema base file. You can leave descriptions blank in there as it will be added by the site.
-
Update tsconfigRules.ts - with things like:
- Default values
- Linking compiler versions
- Add a new section to
releaseToConfigsMap
for your version
The tag should be automatically generated on a daily basis - so you shouldn't have to do anything
Run yarn test
.
Tests can fail between TS builds, for example snapshot tests in packages which have compiler errors or LSP responses in them.
Run yarn build; yarn update-test-snapshots
to try auto-update all snapshots, otherwise use yarn workspace [package_name] test -u
for 1 package.
Unless something drastic has change, you shouldn't need to do anything. You could run through the playground section for the RC and update the dropdown to be the RC.
Grab the markdown from the blog posts repo, create a file like: packages/documentation/copy/en/release-notes/TypeScript 3.9.md
Grab the header info from a previous release notes, and add it to your new version:
---
title: TypeScript 3.9
layout: docs
permalink: /docs/handbook/release-notes/typescript-3-9.html
oneline: TypeScript 3.9 Release Notes
---
You can add twoslash to the code samples if you want.
When you're happy with that, then edit `packages/documentation/copy/en/release-notes/Overview.md to include the changes you just added, and simplify descriptions.
Using the GitHub CLI, from the root of the repo
# Clone a copy and move in new file
gh repo clone https://github.com/SchemaStore/schemastore.git /tmp/schemastore
cp packages/tsconfig-reference/scripts/schema/result/schema.json /tmp/schemastore/src/schemas/json/tsconfig.json
# Go in and set up the changes
cd /tmp/schemastore
gh repo fork
git add .
git commit -m "Update tsconfig.json schema"
# Validate it didn't break
cd src
npm ci
npm run build
# Shippit
gh pr create --web