This is the module with configuration for ESlint and Typescript used in every module in CS.
Version 3.0.0 introduces some lint rules that can require some manual fixes (everything based on comments during the code review process) and introduce config for Typescript > 4.
From version 3.0.0 this module requires specific dependencies:
"eslint": "8.6.0"
"eslint-import-resolver-node": "0.3.6"
"typescript": "5.4.5"
Note: it may be a situation when @types/node
module is not updated. The best option update this module to 20.11.1.
So, the migrations process should contain similar steps:
- Update devDependencies (eslint, Typescript, etc.) in project.
- Update @cksource-cs/eslint-config-cs-module to version > 3.0.0
- Run
pnpm cli build [package_name]
ornpm run build
- Run
npm run lint:fix
- Fix manually all lint problems.
- Run
npm run lint
- Run all tests.
- Fix tests.
Note: it can be a problem with ts-node
in Mocha tests so recommendation is to remove ts-node
and use approach with dist-tests
. More information about migrating from Mocha to AVA can be found here: https://www.notion.so/Migrating-from-Mocha-to-AVA-48bd10bf8be141349c4a8d302d5f957d .
If you believe we need to change the ESLint rules, make sure to discuss it with the team first. Once you get the go-ahead, follow the steps below to update the package across the whole CS:
- Update
eslintrc.js
as needed (with generic ESLint rules) and/ortypescript.js
(TS-specific rules only). - Bump the version of this module (
eslint-config-cs-module
) inpackage.json
. - To estimate how much work will be needed to update the linter module in other packages, create local links and try applying auto-fixes:
csli link --min-version=3.0.0 eslint-config-cs-module && \
csli run lint:fix
- If you're happy with the changes, proceed with a PR and release the new version of the ESLint module.
- Once the PR has been merged, switch to
master
. Go to the CS repository root and run the following command to upgrade the ESLint module in all client packages. The command will also attempt to auto-fix any errors, similarly to what we did in step 2.
pnpm recursive install --dev && \
csli run deps:check --command-options="-u,-f @cksource-cs/eslint-config-cs-module" && \
pnpm recursive install --dev && \
csli run lint:fix
- Apply manual fixes if needed, commit the changes to a feature branch and create a PR.