Run with yarn/npm

setup

config package.json

{
...
  "scripts": {
    "start": "node scripts/start.js",
    "test": "node scripts/test.js --env=jsdom",
...
}

scripts/test.js content

'use strict'

// Do this as the first thing so that any code reading it knows the right env.
process.env.BABEL_ENV = 'test'
process.env.NODE_ENV = 'test'
process.env.PUBLIC_URL = ''

// Makes the script crash on unhandled rejections instead of silently
// ignoring them. In the future, promise rejections that are not handled will
// terminate the Node.js process with a non-zero exit code.
process.on('unhandledRejection', err => {
  throw err
})

// Ensure environment variables are read.
require('../config/env')

const jest = require('jest')
const argv = process.argv.slice(2)

// Watch unless on CI or in coverage mode
if (!process.env.CI && argv.indexOf('--coverage') < 0) {
  argv.push('--watch')
}

jest.run(argv)

Notes: both package.json and files in scripts dir are generated by create-react-app CLI tool.

command line

yarn test

test single file

yarn test src/index.test.js

test without watch mode

$ yarn test index.test.js -- --watchAll=false

Ref: https://stackoverflow.com/questions/39724017/running-cra-jest-in-non-interactive-mode

Generate for all the directories

$ yarn test --coverage

Code coverage report

Use this to exclude this file in the coverage report.

/* istanbul ignore file */

test single

describe('Component', () => {
  test('Test no run', () => {
    ...
  })

  test('Test no run', () => {
    ...
  })

  test.only('Only this test run', () => {
    ...
  })
})

or

yarn test src/index.test.jsx

compare object vs primitive value

expect({foo:'bar'}).toEqual({foo:'bar'}) // object
expect(1).toBe(1) // primitive value

Configurations vs CLI Options

Configurations (https://jestjs.io/docs/configuration) CLI Options (https://jestjs.io/docs/cli) In file Default Value
"collectCoverage": true –coverage=true or –coverage or –collectCoverage false
"testEnvironment": "jsdom" --env=jsdom jest-env “node”

References