Absolute paths for tests
Asked Answered
P

3

5

Here's my jest config inside of package.json:

"jest": {
  "moduleFileExtensions": [
    "js",
    "json",
    "ts"
  ],
  "moduleDirectories":["node_modules", "src"], // tried to solve the issue like that
  "rootDir": "src",
  "testRegex": ".spec.ts$",
  "transform": {
    "^.+\\.(t|j)s$": "ts-jest"
  },
  "coverageDirectory": "../coverage",
  "testEnvironment": "node"
}

AFAIK Nest doesn't add jest.config file, so package.json is my best bet.

But after doing this, my code still fails:

yarn run v1.22.5
$ jest
 FAIL  src/auth/auth.service.spec.ts
  ● Test suite failed to run

    Cannot find module 'src/auth/auth.service' from 'auth/auth.service.spec.ts'

      3 | import * as moment from 'moment';
      4 | import { RedisService } from '@custom/redis-client'; // this is in node_modules
    > 5 | import { AuthService } from 'src/auth/auth.service';
        | ^
      6 | import { ConfigService } from 'src/config/config.service';
      7 |
      8 | describe('AuthService', () => {

      at Resolver.resolveModule (../node_modules/jest-resolve/build/index.js:306:11)
      at Object.<anonymous> (auth/auth.service.spec.ts:5:1)

Test Suites: 1 failed, 1 total
Tests:       0 total
Snapshots:   0 total
Time:        3.486 s
Ran all test suites.
error Command failed with exit code 1.
info Visit https://yarnpkg.com/en/docs/cli/run for documentation about this command.

I also tried adding this to the jest config, as well as tsconfig:

"moduleNameMapper": {
  "src/(.*)": "<rootDir>/$1",
  "tests/(.*)": "<rootDir>/__tests__/$1"
},

But with this code I get:

yarn run v1.22.5
$ jest
 FAIL  src/auth/auth.service.spec.ts
  ● Test suite failed to run

    Configuration error:
    
    Could not locate module ./src/redis/redis.health.indicator mapped as:
    /home/aironside/Documents/sygnum/dev-environment/api-layer/src/$1.
    
    Please check your configuration for these entries:
    {
      "moduleNameMapper": {
        "/src\/(.*)/": "/home/aironside/Documents/sygnum/dev-environment/api-layer/src/$1"
      },
      "resolver": undefined
    }

      at createNoMappedModuleFoundError (../node_modules/jest-resolve/build/index.js:551:17)
      at Object.<anonymous> (../node_modules/@sygnum/redis-client/index.ts:1:1)

Test Suites: 1 failed, 1 total
Tests:       0 total
Snapshots:   0 total
Time:        3.183 s
Ran all test suites.
error Command failed with exit code 1.
info Visit https://yarnpkg.com/en/docs/cli/run for documentation about this command.

What am I missing?

My full tsconfig:

{
  "compilerOptions": {
    "module": "commonjs",
    "declaration": true,
    "removeComments": true,
    "emitDecoratorMetadata": true,
    "experimentalDecorators": true,
    "allowSyntheticDefaultImports": true,
    "target": "es2017",
    "sourceMap": true,
    "outDir": "./dist",
    "baseUrl": "./",
    "incremental": true,
    "rootDir": "./",
  }
}
Privet answered 25/6, 2021 at 8:44 Comment(0)
D
4

I had the same issue. Please change "rootDir": "src" to "rootDir": "./" and add "modulePaths": ["<rootDir>"]. in your pakage.json

Finally your jest object should look like this:

"jest": {
    "moduleFileExtensions": [
        "js",
        "json",
        "ts"
    ],
    "moduleDirectories": [
        "node_modules",
        "src"
    ],
    "rootDir": "./", // ***** CHANGE "rootDir": "src" to "rootDir": "./"
    "modulePaths": ["<rootDir>"], // ***** ADD "modulePaths": ['<rootDir>'], 
    "testRegex": ".spec.ts$",
    "transform": {
        "^.+\\.(t|j)s$": "ts-jest"
    },
    "coverageDirectory": "../coverage",
    "testEnvironment": "node"
}

This worked fine for me. I hope you too!!

Dann answered 5/10, 2021 at 16:40 Comment(0)
W
2

I use the ts-jest module for working with Jest in my Typescript projects. I use Jest for unit testing and E2E testing (at the moment) so I have different configuration files for each, with a common base module to not repeat settings.

My tests do not need to specify the src/ when importing files, just the normal paths under that. Also, this configuration has the plugins to support using the Typescript paths (@LIBRARY, @MODULE, etc.) in your source code.

jest-base.config.js

const tsconfig = require('./tsconfig.json');
const moduleNameMapper = require('tsconfig-paths-jest')(tsconfig);

module.exports = {
    moduleNameMapper,
    preset: 'ts-jest',
    testEnvironment: 'node',

    rootDir: './',

    collectCoverage: true,
    collectCoverageFrom: [
        '<rootDir>/**/*.ts',
        '!<rootDir>/**/*.interface.ts',
        '!<rootDir>/**/*.mock.ts',
        '!<rootDir>/**/*.module.ts',
        '!<rootDir>/**/__mock__/*',
        '!<rootDir>/src/main.ts'
    ],
    coverageProvider: 'v8',
    coverageReporters: [
        'clover',
        'json',
        'lcov',
        'text',
        'text-summary'
    ],
    resetModules: true,
    setupFiles: [
        'dotenv/config'
    ],
    // Add the community jest-extended matchers
    setupFilesAfterEnv: [
        'jest-extended'
    ],
    verbose: false
};

Then for unit tests, I use the following jest.config.js, with the package.json script option jest --watchAll --config ./jest.config.js

jest.config.js

const JestBaseConfiguration = require('./jest-base.config');

module.exports = Object.assign(JestBaseConfiguration, {

    // A list of paths to directories that Jest should use to search for files in
    roots: [
        '<rootDir>/src',
    ],

    coverageDirectory: '<rootDir>/docs/coverage',
    coverageThreshold: {
        global: {
            branches: 80,
            functions: 50,
            lines: 50,
            statements: 50
        }
    },
    testTimeout: 30000    // Set in each config in case different values are needed
});

For End to End tests, I use the following jest-e2e.config.js, with the package.json script option jest --watchAll --config ./jest-e2e.config.js

jest-e2e.config.js

const JestBaseConfiguration = require('./jest-base.config');

module.exports = Object.assign(JestBaseConfiguration, {
    moduleFileExtensions: ['js', 'json', 'ts'],
    testRegex: '.e2e-spec.ts$',
    transform: {
        '^.+\\.(t|j)s$': 'ts-jest'
    },

    // A list of paths to directories that Jest should use to search for files in
    roots: [
        '<rootDir>/test'
    ],

    coverageDirectory: '<rootDir>/docs/e2e-coverage',
    coverageThreshold: {
        global: {
            branches: 5,
            functions: 5,
            lines: 5,
            statements: 5
        }
    },
    testTimeout: 30000    // Set in each file in case different values are needed
});
Woolfolk answered 25/6, 2021 at 14:35 Comment(0)
B
0

For e2e tests, updating the test/jest-e2e.json as below, fixed the issue for me.

{
  "moduleFileExtensions": ["js", "json", "ts"],
  "rootDir": "../", # <--- Change this line
  "modulePaths": ["<rootDir>"], # <---- Add this line
  "testEnvironment": "node",
  "testRegex": ".e2e-spec.ts$",
  "transform": {
    "^.+\\.(t|j)s$": "ts-jest"
  }
}
Boondocks answered 30/8, 2024 at 19:17 Comment(0)

© 2022 - 2025 — McMap. All rights reserved.