modern-node
Version:
> All-in-one development toolkit for creating node modules with Jest, Prettier, ESLint, and Standard
79 lines (73 loc) • 1.91 kB
JavaScript
const path = require('path')
const jest = require('jest')
// 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'
// This is not necessary after eject because we embed config into package.json.
const createJestConfig = require('./utils/createJestConfig')
const paths = require('./paths')
let argv = process.argv.slice(2)
argv.push(
'--config',
JSON.stringify(
createJestConfig(
relativePath => path.resolve(__dirname, '..', relativePath),
path.resolve(paths.appSrc, '..'),
false
)
)
)
// This is a very dirty workaround for https://github.com/facebook/jest/issues/5913.
// We're trying to resolve the environment ourselves because Jest does it incorrectly.
// TODO: remove this as soon as it's fixed in Jest.
const resolve = require('resolve')
function resolveJestDefaultEnvironment (name) {
const jestDir = path.dirname(
resolve.sync('jest', {
basedir: __dirname
})
)
const jestCLIDir = path.dirname(
resolve.sync('jest-cli', {
basedir: jestDir
})
)
const jestConfigDir = path.dirname(
resolve.sync('jest-config', {
basedir: jestCLIDir
})
)
return resolve.sync(name, {
basedir: jestConfigDir
})
}
const cleanArgv = []
let env = 'node'
let next
do {
next = argv.shift()
if (next === '--env') {
env = argv.shift()
} else if (next.indexOf('--env=') === 0) {
env = next.substring('--env='.length)
} else {
cleanArgv.push(next)
}
} while (argv.length > 0)
argv = cleanArgv
let resolvedEnv
try {
resolvedEnv = resolveJestDefaultEnvironment(`jest-environment-${env}`)
} catch (e) {
// ignore
}
if (!resolvedEnv) {
try {
resolvedEnv = resolveJestDefaultEnvironment(env)
} catch (e) {
// ignore
}
}
const testEnvironment = resolvedEnv || env
argv.push('--env', testEnvironment)
jest.run(argv)