@liquid-labs/catalyst-resource-jest
Version:
213 lines (157 loc) • 7.09 kB
JavaScript
// For a detailed explanation regarding each configuration property, visit:
// https://jestjs.io/docs/en/configuration.html
const fsPath = require('node:path')
// we expect to execute from the 'test-staging' subdir, so we drop down one; unless we're testing ourselves in which
// case we don't.
const pkg = process.env.SELF_TEST === 'true'
? require(fsPath.join(process.cwd(), 'package.json'))
: require(fsPath.join(process.cwd(), '..', 'package.json'))
const config = {
// All imported modules in your tests should be mocked automatically
// automock: false,
// Stop running tests after the first failure
// bail: false,
// Respect "browser" field in package.json when resolving modules
// browser: false,
// The directory where Jest should store its cached dependency information
// cacheDirectory: "/var/folders/x7/dkrqh9dd6yd4kx0xs6st40980000gn/T/jest_dx",
// Automatically clear mock calls and instances between every test
// clearMocks: true,
// Indicates whether the coverage information should be collected while executing the test
collectCoverage : true,
// An array of glob patterns indicating a set of files for which coverage information should be collected
collectCoverageFrom : ['**/*.{js,cjs,mjs,jsx}', '!**/index.{js,mjs,cjs}', '!**/.*.{js,mjs,cjs}'],
// The directory where Jest should output its coverage files
coverageDirectory : 'coverage',
// An array of regexp pattern strings used to skip coverage collection
coveragePathIgnorePatterns : [
'/node_modules/',
'/test/',
'\\.test\\.[mc]?js',
'/test-data/',
'<rootDir>/test-staging/',
'<rootDir>/dist/',
'<rootDir>/qa/',
'<rootDir>/coverage/'
],
// A list of reporter names that Jest uses when writing coverage reports
coverageReporters : [
'json',
'text',
'html',
// "lcov",
'clover'
],
// An object that configures minimum threshold enforcement for coverage results
// coverageThreshold: null,
// Make calling deprecated APIs throw helpful error messages
// errorOnDeprecated: false,
// Force coverage collection from ignored files usin a array of glob patterns
// forceCoverageMatch: [],
// A path to a module which exports an async function that is triggered once before all test suites
// globalSetup: null,
// A path to a module which exports an async function that is triggered once after all test suites
// globalTeardown: null,
// A set of global variables that need to be available in all test environments
// globals: {},
// An array of directory names to be searched recursively up from the requiring module's location
// moduleDirectories: [
// "node_modules"
// ],
// An array of file extensions your modules use
// moduleFileExtensions: [
// "js",
// "json",
// "jsx",
// "node"
// ],
// A map from regular expressions to module names that allow to stub out resources with a single module
// moduleNameMapper: {},
// An array of regexp pattern strings, matched against all module paths before considered 'visible' to the module loader
// modulePathIgnorePatterns: [],
// Activates notifications for test results
// notify: false,
// An enum that specifies notification mode. Requires { notify: true }
// notifyMode: "always",
// A preset that is used as a base for Jest's configuration
// preset: null,
// Run tests from one or more projects
// projects: null,
// Use this configuration option to add custom reporters to Jest
// reporters: undefined,
// Automatically reset mock state between every test
// resetMocks: false,
// Reset the module registry before running each individual test
// resetModules: false,
// A path to a custom resolver
// resolver: null,
// Automatically restore mock state between every test
// restoreMocks: false,
// The root directory that Jest should scan for tests and modules within
// By using '--config=' in our command the root gets set to the dir of the
// config file. This behavior is documented and intended, though also pretty
// inexplicable.
rootDir : process.cwd(),
// A list of paths to directories that Jest should use to search for files in
// roots: [
// "<rootDir>"
// ],
// Allows you to use a custom runner instead of Jest's default test runner
// runner: "jest-runner",
// The paths to modules that run some code to configure or set up the testing environment before each test
// setupFiles: [],
// The path to a module that runs some code to configure or set up the testing framework before each test
// setupTestFrameworkScriptFile: null,
// A list of paths to snapshot serializer modules Jest should use for snapshot testing
// snapshotSerializers: [],
snapshotResolver : fsPath.join(__dirname, 'jest-snapshot-resolver.js'),
// The test environment that will be used for testing
// TODO: should default to jsdom
testEnvironment : 'node'
// Options that will be passed to the testEnvironment
// testEnvironmentOptions: {},
// Adds a location field to test results
// testLocationInResults: false,
// The glob patterns Jest uses to detect test files
// testMatch: [
// "**/__tests__/**/*.js?(x)",
// "**/?(*.)+(spec|test).js?(x)"
// ],
// An array of regexp pattern strings that are matched against all test paths, matched tests are skipped
// testPathIgnorePatterns: [
// "/node_modules/"
// ],
// The regexp pattern Jest uses to detect test files
// testRegex: "",
// This option allows the use of a custom results processor
// testResultsProcessor: null,
// This option allows use of a custom test runner
// testRunner: "jasmine2",
// This option sets the URL for the jsdom environment. It is reflected in properties such as location.href
// testURL: "about:blank",
// Setting this value to "fake" allows the use of fake timers for functions such as "setTimeout"
// timers: "real",
// A map from regular expressions to paths to transformers
// transform: null,
// An array of regexp pattern strings that are matched against all source file paths, matched files will skip transformation
// transformIgnorePatterns: [
// "/node_modules/"
// ],
// An array of regexp pattern strings that are matched against all modules before the module loader will automatically return a mock for them
// unmockedModulePathPatterns: undefined,
// Indicates whether each individual test should be reported during the run
// verbose: null,
// An array of regexp patterns that are matched against all source file paths before re-running tests in watch mode
// watchPathIgnorePatterns: [],
// Whether to use watchman for file crawling
// watchman: true,
}
if (pkg.catalyst) {
const { jestConfig, jestCoverageGlobs } = pkg.catalyst
Object.assign(config, jestConfig)
if (jestCoverageGlobs !== undefined) {
// config.coveragePathIgnorePatterns.push(...pkg.catalyst.jestCoverageIgnorePatterns)
config.collectCoverageFrom.push(...jestCoverageGlobs)
}
}
module.exports = config