Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Convert code base to ESM import #3778

Merged
merged 4 commits into from
Jun 9, 2017
Merged
Show file tree
Hide file tree
Changes from 3 commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 2 additions & 1 deletion .babelrc
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,8 @@
"transform-es2015-destructuring",
"transform-es2015-parameters",
"transform-async-to-generator",
"transform-strict-mode"
"transform-strict-mode",
["transform-es2015-modules-commonjs", {"allowTopLevelThis": true}]
Copy link
Member Author

@SimenB SimenB Jun 9, 2017

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I added the allowTopLevelThis option, otherwise this throws. Might not be an issue, not sure?

],
"retainLines": true
}
9 changes: 7 additions & 2 deletions .eslintrc.js
Original file line number Diff line number Diff line change
Expand Up @@ -19,9 +19,14 @@ module.exports = {
'flowtype/require-valid-file-annotation': 2,
'max-len': 0,
'no-multiple-empty-lines': 1,
'import/order': 2,
'import/no-duplicates': 2,
'import/no-unresolved': [2, { 'ignore': ['^types/'] }]
'import/no-unresolved': [2, { 'ignore': ['^types/'] }],
// This has to be disabled until all type and module imports are combined
// https://github.com/benmosher/eslint-plugin-import/issues/645
'import/order': 0,
// These has to be disabled until the whole code base is converted to ESM
'import/default': 0,
'import/named': 0,
},
'plugins': [
'markdown',
Expand Down
1 change: 1 addition & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@
"babel-plugin-syntax-trailing-function-commas": "^6.13.0",
"babel-plugin-transform-async-to-generator": "^6.16.0",
"babel-plugin-transform-es2015-destructuring": "^6.23.0",
"babel-plugin-transform-es2015-modules-commonjs": "^6.24.1",
"babel-plugin-transform-es2015-parameters": "^6.23.0",
"babel-plugin-transform-flow-strip-types": "^6.18.0",
"babel-plugin-transform-runtime": "^6.23.0",
Copy link
Collaborator

@thymikee thymikee Jun 9, 2017

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

should this be in this PR? I mean babel-plugin-transform-inline-imports-commonjs

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Oh sorry, good catch. Wrong plugin!

Expand Down
8 changes: 4 additions & 4 deletions packages/babel-jest/src/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -11,10 +11,10 @@
import type {Path, ProjectConfig} from 'types/Config';
import type {TransformOptions} from 'types/Transform';

const crypto = require('crypto');
const fs = require('fs');
const path = require('path');
const jestPreset = require('babel-preset-jest');
import crypto from 'crypto';
import fs from 'fs';
import path from 'path';
import jestPreset from 'babel-preset-jest';

const BABELRC_FILENAME = '.babelrc';
const BABELRC_JS_FILENAME = '.babelrc.js';
Expand Down
1 change: 1 addition & 0 deletions packages/eslint-config-fb-strict/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@
*
*/

// Can't be ESModules as this is not transpiled
const fbjsConfig = require('eslint-config-fbjs');

const variableNamePattern = String.raw`\s*[a-zA-Z_$][a-zA-Z_$\d]*\s*`;
Expand Down
4 changes: 2 additions & 2 deletions packages/jest-changed-files/src/git.js
Original file line number Diff line number Diff line change
Expand Up @@ -10,8 +10,8 @@

import type {Path} from 'types/Config';

const path = require('path');
const childProcess = require('child_process');
import path from 'path';
import childProcess from 'child_process';

type Options = {|
lastCommit?: boolean,
Expand Down
4 changes: 2 additions & 2 deletions packages/jest-changed-files/src/hg.js
Original file line number Diff line number Diff line change
Expand Up @@ -10,8 +10,8 @@

import type {Path} from 'types/Config';

const path = require('path');
const childProcess = require('child_process');
import path from 'path';
import childProcess from 'child_process';

const env = Object.assign({}, process.env, {
HGPLAIN: 1,
Expand Down
2 changes: 1 addition & 1 deletion packages/jest-circus/src/eventHandler.js
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@

import type {EventHandler} from '../types';

const {makeDescribe, getTestDuration, makeTest} = require('./utils');
import {makeDescribe, getTestDuration, makeTest} from './utils';

// To pass this value from Runtime object to state we need to use global[sym]
const TEST_TIMEOUT_SYMBOL = Symbol.for('TEST_TIMEOUT_SYMBOL');
Expand Down
2 changes: 1 addition & 1 deletion packages/jest-circus/src/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ import type {
BlockName,
TestName,
} from '../types';
const {dispatch} = require('./state');
import {dispatch} from './state';

const describe = (blockName: BlockName, blockFn: BlockFn) =>
_dispatchDescribe(blockFn, blockName);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -12,13 +12,13 @@ import type {TestResult, Status} from 'types/TestResult';
import type {GlobalConfig, Path, ProjectConfig} from 'types/Config';
import type {Event, TestEntry} from '../../types';

const {getState, setState} = require('jest-matchers');
const {formatResultsErrors} = require('jest-message-util');
const {SnapshotState, addSerializer} = require('jest-snapshot');
const {addEventHandler, ROOT_DESCRIBE_BLOCK_NAME} = require('../state');
const {getTestID} = require('../utils');
const run = require('../run');
const globals = require('../index');
import {getState, setState} from 'jest-matchers';
import {formatResultsErrors} from 'jest-message-util';
import {SnapshotState, addSerializer} from 'jest-snapshot';
import {addEventHandler, ROOT_DESCRIBE_BLOCK_NAME} from '../state';
import {getTestID} from '../utils';
import run from '../run';
import globals from '../index';

const initialize = ({
config,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ import type {TestResult} from 'types/TestResult';
import type Runtime from 'jest-runtime';

const FRAMEWORK_INITIALIZER = require.resolve('./jest-adapter-init');
const path = require('path');
import path from 'path';

const jestAdapter = async (
globalConfig: GlobalConfig,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -10,13 +10,13 @@

import type {RawMatcherFn} from 'types/Matchers';

const expect = require('jest-matchers');
import expect from 'jest-matchers';

const {
import {
addSerializer,
toMatchSnapshot,
toThrowErrorMatchingSnapshot,
} = require('jest-snapshot');
} from 'jest-snapshot';

type JasmineMatcher = {
(): JasmineMatcher,
Expand Down
6 changes: 3 additions & 3 deletions packages/jest-circus/src/run.js
Original file line number Diff line number Diff line change
Expand Up @@ -16,13 +16,13 @@ import type {
DescribeBlock,
} from '../types';

const {getState, dispatch} = require('./state');
const {
import {getState, dispatch} from './state';
import {
callAsyncFn,
getAllHooksForDescribe,
getEachHooksForTest,
makeTestResults,
} = require('./utils');
} from './utils';

const run = async (): Promise<TestResults> => {
const {rootDescribeBlock} = getState();
Expand Down
4 changes: 2 additions & 2 deletions packages/jest-circus/src/state.js
Original file line number Diff line number Diff line change
Expand Up @@ -10,8 +10,8 @@

import type {Event, State, EventHandler} from '../types';

const {makeDescribe} = require('./utils');
const eventHandler = require('./eventHandler');
import {makeDescribe} from './utils';
import eventHandler from './eventHandler';

const eventHandlers: Array<EventHandler> = [eventHandler];

Expand Down
6 changes: 3 additions & 3 deletions packages/jest-cli/src/PatternPrompt.js
Original file line number Diff line number Diff line change
Expand Up @@ -12,9 +12,9 @@

import type {ScrollOptions} from './lib/scrollList';

const chalk = require('chalk');
const ansiEscapes = require('ansi-escapes');
const Prompt = require('./lib/Prompt');
import chalk from 'chalk';
import ansiEscapes from 'ansi-escapes';
import Prompt from './lib/Prompt';

const usage = (entity: string) =>
`\n${chalk.bold('Pattern Mode Usage')}\n` +
Expand Down
12 changes: 5 additions & 7 deletions packages/jest-cli/src/SearchSource.js
Original file line number Diff line number Diff line change
Expand Up @@ -13,13 +13,11 @@ import type {Glob, Path} from 'types/Config';
import type {ResolveModuleConfig} from 'types/Resolve';
import type {Test} from 'types/TestRunner';

const path = require('path');

const micromatch = require('micromatch');

const DependencyResolver = require('jest-resolve-dependencies');
const changedFiles = require('jest-changed-files');
const {escapePathForRegex, replacePathSepForRegex} = require('jest-regex-util');
import path from 'path';
import micromatch from 'micromatch';
import DependencyResolver from 'jest-resolve-dependencies';
import changedFiles from 'jest-changed-files';
import {escapePathForRegex, replacePathSepForRegex} from 'jest-regex-util';

type SearchResult = {|
noSCM?: boolean,
Expand Down
14 changes: 7 additions & 7 deletions packages/jest-cli/src/TestNamePatternPrompt.js
Original file line number Diff line number Diff line change
Expand Up @@ -11,20 +11,20 @@
import type {TestResult} from 'types/TestResult';
import type {ScrollOptions} from './lib/scrollList';

const scroll = require('./lib/scrollList');
const {getTerminalWidth} = require('./lib/terminalUtils');
const Prompt = require('./lib/Prompt');
const formatTestNameByPattern = require('./lib/formatTestNameByPattern');
const {
import scroll from './lib/scrollList';
import {getTerminalWidth} from './lib/terminalUtils';
import Prompt from './lib/Prompt';
import formatTestNameByPattern from './lib/formatTestNameByPattern';
import {
formatTypeaheadSelection,
printMore,
printPatternCaret,
printPatternMatches,
printRestoredPatternCaret,
printStartTyping,
printTypeaheadItem,
} = require('./lib/patternModeHelpers');
const PatternPrompt = require('./PatternPrompt');
} from './lib/patternModeHelpers';
import PatternPrompt from './PatternPrompt';

module.exports = class TestNamePatternPrompt extends PatternPrompt {
_cachedTestResults: Array<TestResult>;
Expand Down
20 changes: 10 additions & 10 deletions packages/jest-cli/src/TestPathPatternPrompt.js
Original file line number Diff line number Diff line change
Expand Up @@ -14,23 +14,23 @@ import type {ScrollOptions} from './lib/scrollList';
// eslint-disable-next-line import/default
import type SearchSource from './SearchSource';

const chalk = require('chalk');
const stringLength = require('string-length');
const scroll = require('./lib/scrollList');
const {getTerminalWidth} = require('./lib/terminalUtils');
const highlight = require('./lib/highlight');
const {trimAndFormatPath} = require('./reporters/utils');
const Prompt = require('./lib/Prompt');
const {
import chalk from 'chalk';
import stringLength from 'string-length';
import scroll from './lib/scrollList';
import {getTerminalWidth} from './lib/terminalUtils';
import highlight from './lib/highlight';
import {trimAndFormatPath} from './reporters/utils';
import Prompt from './lib/Prompt';
import {
formatTypeaheadSelection,
printMore,
printPatternCaret,
printPatternMatches,
printRestoredPatternCaret,
printStartTyping,
printTypeaheadItem,
} = require('./lib/patternModeHelpers');
const PatternPrompt = require('./PatternPrompt');
} from './lib/patternModeHelpers';
import PatternPrompt from './PatternPrompt';

type SearchSources = Array<{|
context: Context,
Expand Down
25 changes: 12 additions & 13 deletions packages/jest-cli/src/TestRunner.js
Original file line number Diff line number Diff line change
Expand Up @@ -18,19 +18,18 @@ import type {Context} from 'types/Context';
import type {Reporter, Test} from 'types/TestRunner';
import type {PathPattern} from './SearchSource';

const {formatExecError} = require('jest-message-util');
const snapshot = require('jest-snapshot');
const pify = require('pify');
const throat = require('throat');
const workerFarm = require('worker-farm');

const DefaultReporter = require('./reporters/DefaultReporter');
const NotifyReporter = require('./reporters/NotifyReporter');
const SummaryReporter = require('./reporters/SummaryReporter');
const VerboseReporter = require('./reporters/VerboseReporter');
const runTest = require('./runTest');
const TestWatcher = require('./TestWatcher');
const ReporterDispatcher = require('./ReporterDispatcher');
import {formatExecError} from 'jest-message-util';
import snapshot from 'jest-snapshot';
import pify from 'pify';
import throat from 'throat';
import workerFarm from 'worker-farm';
import DefaultReporter from './reporters/DefaultReporter';
import NotifyReporter from './reporters/NotifyReporter';
import SummaryReporter from './reporters/SummaryReporter';
import VerboseReporter from './reporters/VerboseReporter';
import runTest from './runTest';
import TestWatcher from './TestWatcher';
import ReporterDispatcher from './ReporterDispatcher';

const SLOW_TEST_TIME = 3000;

Expand Down
5 changes: 3 additions & 2 deletions packages/jest-cli/src/TestSequencer.js
Original file line number Diff line number Diff line change
Expand Up @@ -12,8 +12,9 @@ import type {AggregatedResult} from 'types/TestResult';
import type {Context} from 'types/Context';
import type {Test} from 'types/TestRunner';

const fs = require('fs');
const getCacheFilePath = require('jest-haste-map').getCacheFilePath;
import fs from 'fs';
// $FlowFixMe: Missing ESM export
import {getCacheFilePath} from 'jest-haste-map';

const FAIL = 0;
const SUCCESS = 1;
Expand Down
2 changes: 1 addition & 1 deletion packages/jest-cli/src/TestWatcher.js
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@
* @flow
*/

const {EventEmitter} = require('events');
import EventEmitter from 'events';

type State = {|
interrupted: boolean,
Expand Down
11 changes: 6 additions & 5 deletions packages/jest-cli/src/TestWorker.js
Original file line number Diff line number Diff line change
Expand Up @@ -18,11 +18,11 @@ process.on('uncaughtException', err => {
process.exit(1);
});

const {ModuleMap} = require('jest-haste-map');
const {separateMessageFromStack} = require('jest-message-util');

const Runtime = require('jest-runtime');
const runTest = require('./runTest');
// $FlowFixMe: Missing ESM export
import {ModuleMap} from 'jest-haste-map';
import {separateMessageFromStack} from 'jest-message-util';
import Runtime from 'jest-runtime';
import runTest from './runTest';

type WorkerData = {|
config: ProjectConfig,
Expand Down Expand Up @@ -59,6 +59,7 @@ const getResolver = (config, rawModuleMap) => {
if (rawModuleMap) {
return Runtime.createResolver(
config,
// $FlowFixMe: Missing ESM export
new ModuleMap(rawModuleMap.map, rawModuleMap.mocks),
);
} else {
Expand Down
2 changes: 1 addition & 1 deletion packages/jest-cli/src/cli/args.js
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@

import type {Argv} from 'types/Argv';

const isCI = require('is-ci');
import isCI from 'is-ci';

const check = (argv: Argv) => {
if (argv.runInBand && argv.hasOwnProperty('maxWorkers')) {
Expand Down
6 changes: 3 additions & 3 deletions packages/jest-cli/src/cli/getJest.js
Original file line number Diff line number Diff line change
Expand Up @@ -10,9 +10,9 @@

import type {Path} from 'types/Config';

const path = require('path');
const chalk = require('chalk');
const fs = require('graceful-fs');
import path from 'path';
import chalk from 'chalk';
import fs from 'graceful-fs';

function getJest(packageRoot: Path) {
const packageJSONPath = path.join(packageRoot, 'package.json');
Expand Down
10 changes: 5 additions & 5 deletions packages/jest-cli/src/cli/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -11,11 +11,11 @@
import type {Path} from 'types/Config';
import type {Argv} from 'types/Argv';

const {validateCLIOptions} = require('jest-util');
const yargs = require('yargs');
const args = require('./args');
const getJest = require('./getJest');
const runCLI = require('./runCLI');
import {validateCLIOptions} from 'jest-util';
import yargs from 'yargs';
import args from './args';
import getJest from './getJest';
import runCLI from './runCLI';

function run(argv?: Argv, project?: Path) {
argv = yargs(argv || process.argv.slice(2))
Expand Down
Loading