Skip to content

Latest commit

 

History

History
241 lines (190 loc) · 9.54 KB

CONTRIBUTING.md

File metadata and controls

241 lines (190 loc) · 9.54 KB

How to contribute to ng-mocks

The best way would be to discuss an issue or an improvement first:

Update docs

To update docs, simply go to the page you want to edit on https://ng-mocks.sudo.eu/ and click on the "Edit this page" link at the bottom of the page.

Prerequisites for development

Requirements on Mac

Requirements on Linux

Requirements on Windows

Development

To develop ng-mocks you need to use bash and WSL in case if you are on Windows.

How to install dependencies

  • start docker and ensure it's running

  • open a bash session in a terminal (Git BASH on Windows)

  • execute

    sh ./compose.sh
  • it will take a while, but afterwards you have all dependencies installed

How to run unit tests locally

nvm use
npm run test

How to debug unit tests locally

nvm use
npm run test:debug

How to run tests in IE locally

How to release ng-mocks

  • You need to create a .env file with the next content:

    GH_TOKEN=<GITHUB_TOKEN>
    NPM_TOKEN=<NPM_TOKEN>
    GIT_AUTHOR_NAME=<YOUR_NAME>
    GIT_AUTHOR_EMAIL=<YOUR_EMAIL>
    GIT_COMMITTER_NAME=<YOUR_NAME>
    GIT_COMMITTER_EMAIL=<YOUR_EMAIL>

    An example of it is:

    GH_TOKEN=123123123
    NPM_TOKEN=123123123
    GIT_AUTHOR_NAME="Best Coder"
    GIT_AUTHOR_EMAIL=[email protected]
    GIT_COMMITTER_NAME="Best Coder"
    GIT_COMMITTER_EMAIL=[email protected]
  • execute npm run release -- --no-ci - to generate a release and publish it on github.com

  • execute npm publish ./tmp/ng-mocks-N.N.N.tgz - to publish it on npmjs.com

  • profit

How to add a new Angular version

First, you need to install the new Angular version somewhere. Below is an example how to add Angular 20 to ng-mocks.

Step #1 - create an empty project

Let's create a fresh project with @angular/cli v20. The name of the project should be a + version: a20.

npx '@angular/cli@^20' new \
  --routing \
  --skip-git=true \
  --skip-tests=true \
  --style=css \
  --ssr=false \
  a20

Basically, the requirements are:

  • no default tests are needed
  • no git repo is needed
  • no styles are needed, css is enough
  • no ssr is needed
  • routing IS needed

Step #2 - move the project to e2e folder and clean it up

The next step is:

  • move a20 folder to ng-mocks/e2e folder
  • delete .vscode folder in ng-mocks/e2e/a20
  • delete .editorconfig file in ng-mocks/e2e/a20
  • change .gitignore to be the same as in the prev version: ng-mocks/e2e/a19/.gitignore
  • change angular.json to be similar as in the prev version: ng-mocks/e2e/a19/angular.json
    • projects/a20/schematics should be empty
    • remove projects/a20/architect/build/options/assets
    • remove projects/a20/architect/build/options/styles
    • remove projects/a20/architect/build/options/scripts
    • change projects/a20/architect/build/options/tsConfig to tsconfig.json
    • remove projects/a20/architect/build/configurations/production/budgets
    • remove projects/a20/architect/extract-i18n
    • remove projects/a20/architect/test/options/assets
    • remove projects/a20/architect/test/options/styles
    • remove projects/a20/architect/test/options/scripts
    • change projects/a20/architect/test/options/tsConfig to tsconfig.json
    • add projects/a20/architect/test/options/main with the value of src/test.ts
    • add projects/a20/architect/test/options/karmaConfig with the value of karma.conf.js
    • add projects/lib as it is in the prev version: ng-mocks/e2e/a19/angular.json
  • change package.json to be similar as in the prev version: ng-mocks/e2e/a19/package.json
    • name should be a20
    • description should be Angular 20
    • private should be true
    • replace scripts as it is in the prev version: ng-mocks/e2e/a19/package.json
    • remove flexible versions (^~) in dependencies as it is in the prev version: ng-mocks/e2e/a19/package.json
    • remove flexible versions (^~) in devDependencies as it is in the prev version: ng-mocks/e2e/a19/package.json
    • in devDependencies, add @types/jest, jest, jest-preset-angular, ng-packagr, puppeteer, ts-node which support the desired angular version
    • add engines with the correct npm which supports the desired angular version
  • delete README.md
  • merge tsconfig.app.json and tsconfig.spec.json into tsconfig.json as it is in the prev version: ng-mocks/e2e/a19/tsconfig.json
    • add compilerOptions/baseUrlwith the value of ./
    • add compilerOptions/types as it is in the prev version: ng-mocks/e2e/a19/tsconfig.json
    • add compilerOptions/skipLibCheck as it is in the prev version: ng-mocks/e2e/a19/tsconfig.json
    • change compilerOptions/noImplicitOverride to false
    • add files as it is in the prev version: ng-mocks/e2e/a19/tsconfig.json
    • add include as it is in the prev version: ng-mocks/e2e/a19/tsconfig.json
    • delete tsconfig.app.json
    • delete tsconfig.spec.json
  • add .nvmrc which supports the desired angular version
  • add jest.config.ts as it is in the prev version: ng-mocks/e2e/a19/jest.config.ts
  • add karma.conf.js as it is in the prev version: ng-mocks/e2e/a19/karma.conf.js
  • add ng-package.json as it is in the prev version: ng-mocks/e2e/a19/ng-package.json
  • delete ng-mocks/e2e/a20/public
  • delete ng-mocks/e2e/a20/src/app
  • delete ng-mocks/e2e/a20/src/style.css
  • remove <link rel="icon"> from ng-mocks/e2e/a20/src/index.html
  • change ng-mocks/e2e/a20/src/main.ts as it is in the prev version: ng-mocks/e2e/a19/src/main.ts
  • add ng-mocks/e2e/a20/src/test.ts as it is in the prev version: ng-mocks/e2e/a19/src/test.ts
  • add ng-mocks/e2e/a20/src/setup-jest.ts as it is in the prev version: ng-mocks/e2e/a19/src/setup-jest.ts

Step #3 - update scripts

  • update ng-mocks/package.json, search for a19 and extended scripts to support a20
  • update ng-mocks/compose.yml, search for a19 and copy blocks to support a20 with the right node version
  • update ng-mocks/compose.sh, search for a19 and copy blocks to support a20 with the right command to install puppeteer
  • update ng-mocks/.dockerignore, search for a19 and copy blocks to support a20
  • update ng-mocks/.github/dependabot.yml, search for a19 and copy blocks to support a20
  • update ng-mocks/.circleci/config.yml, search for a19 and copy blocks to support a20
  • update ng-mocks/.eslintrc.yml, search for a19 and copy blocks to support a20
  • execute sh compose.sh a20 in ng-mocks to install dependencies for a20, it might require --force at this moment in compose.yml in the command for the new version

Step #4 - update ng-mocks dependencies

  • update ng-mocks/package.json to point to the new angular version in dependencies
  • execute sh compose.sh root in ng-mocks to install the dependencies

Step #5 - verify thatng-mocks does not fail with the new version

  • execute nvm install in ng-mocks
  • execute nvm use
  • execute npm run build
  • execute npm run clean:a20
  • execute npm run s:a20
  • execute npm run s:app:a20
  • execute npm run s:test:a20
  • execute npm run test:a20
  • tests should pass successfully without failures

Step #6 - update version references

  • update the version table in ng-mocks/docs/articles/index.md
  • update the migration guide in docs/articles/migrations.md
  • update the version table in ng-mocks/README.md
  • update description in libs/ng-mocks/package.json
  • update peerDependencies in libs/ng-mocks/package.json
  • update this file and replace a20 with a21
  • update this file and replace v20 with v21
  • update this file and replace ^20 with ^21
  • update this file and replace Angular 20 with Angular 21
  • update this file and replace a19 with a20

Step #7 - verify