diff --git a/local-cli/bundle/buildBundle.js b/local-cli/bundle/buildBundle.js index 97be14d79..123cb6b76 100644 --- a/local-cli/bundle/buildBundle.js +++ b/local-cli/bundle/buildBundle.js @@ -68,10 +68,9 @@ function buildBundle( const sourceExts = (config.getSourceExts && config.getSourceExts()) || []; const platforms = (config.getPlatforms && config.getPlatforms()) || []; - const transformModulePath = - args.transformer ? path.resolve(args.transformer) : - typeof config.getTransformModulePath === 'function' ? config.getTransformModulePath() : - undefined; + const transformModulePath = args.transformer + ? path.resolve(args.transformer) + : config.getTransformModulePath(); const providesModuleNodeModules = typeof config.getProvidesModuleNodeModules === 'function' ? config.getProvidesModuleNodeModules() : diff --git a/local-cli/util/Config.js b/local-cli/util/Config.js index 5454e2121..984ebd6ad 100644 --- a/local-cli/util/Config.js +++ b/local-cli/util/Config.js @@ -101,7 +101,7 @@ const defaultConfig: ConfigT = { getProjectRoots: () => [process.cwd()], getProvidesModuleNodeModules: () => providesModuleNodeModules.slice(), getSourceExts: () => [], - getTransformModulePath: () => path.resolve(__dirname, '../../packager/transformer'), + getTransformModulePath: () => path.resolve(__dirname, '../../packager/transformer.js'), getTransformOptions: async () => ({}), postMinifyProcess: x => x, postProcessModules: modules => modules, diff --git a/packager/react-packager.js b/packager/react-packager.js index 24d001c1d..457a877f5 100644 --- a/packager/react-packager.js +++ b/packager/react-packager.js @@ -34,6 +34,7 @@ type Options = { projectRoots: Array, reporter?: Reporter, +sourceExts: ?Array, + +transformModulePath: string, watch?: boolean, }; diff --git a/packager/src/Bundler/__tests__/Bundler-test.js b/packager/src/Bundler/__tests__/Bundler-test.js index 5a171a806..bfcfa7878 100644 --- a/packager/src/Bundler/__tests__/Bundler-test.js +++ b/packager/src/Bundler/__tests__/Bundler-test.js @@ -25,6 +25,7 @@ jest .mock('../Bundle') .mock('../HMRBundle') .mock('../../Logger') + .mock('/path/to/transformer.js', () => ({}), {virtual: true}) ; var Bundler = require('../'); @@ -36,6 +37,7 @@ const os = require('os'); const {any, objectContaining} = expect; + var commonOptions = { allowBundleUpdates: false, assetExts: defaults.assetExts, @@ -44,6 +46,7 @@ var commonOptions = { platforms: defaults.platforms, resetCache: false, sourceExts: defaults.sourceExts, + transformModulePath: '/path/to/transformer.js', watch: false, }; @@ -95,6 +98,10 @@ describe('Bundler', function() { }); Resolver.load = jest.fn().mockImplementation(opts => Promise.resolve(new Resolver(opts))); + fs.__setMockFilesystem({ + 'path': {'to': {'transformer.js': ''}}, + }); + fs.statSync.mockImplementation(function() { return { isDirectory: () => true, diff --git a/packager/src/Bundler/index.js b/packager/src/Bundler/index.js index d64820e9c..bf88f7846 100644 --- a/packager/src/Bundler/index.js +++ b/packager/src/Bundler/index.js @@ -133,7 +133,7 @@ type Options = {| +reporter: Reporter, +resetCache: boolean, +sourceExts: Array, - +transformModulePath?: string, + +transformModulePath: string, +transformTimeoutInterval: ?number, +watch: boolean, |}; @@ -155,15 +155,9 @@ class Bundler { opts.projectRoots.forEach(verifyRootExists); - let transformModuleHash; - try { - /* $FlowFixMe: if transformModulePath is null it'll just be caught */ - const transformModuleStr = fs.readFileSync(opts.transformModulePath); - transformModuleHash = - crypto.createHash('sha1').update(transformModuleStr).digest('hex'); - } catch (error) { - transformModuleHash = ''; - } + const transformModuleStr = fs.readFileSync(opts.transformModulePath); + const transformModuleHash = + crypto.createHash('sha1').update(transformModuleStr).digest('hex'); const stableProjectRoots = opts.projectRoots.map(p => { return path.relative(path.join(__dirname, '../../../..'), p); @@ -197,7 +191,6 @@ class Bundler { const maxWorkerCount = Bundler.getMaxWorkerCount(); this._transformer = new Transformer( - /* $FlowFixMe: in practice it's always here. */ opts.transformModulePath, maxWorkerCount, { diff --git a/packager/src/Server/index.js b/packager/src/Server/index.js index 9fb3fe80b..0e0f53717 100644 --- a/packager/src/Server/index.js +++ b/packager/src/Server/index.js @@ -75,7 +75,7 @@ type Options = { resetCache?: boolean, silent?: boolean, +sourceExts: ?Array, - transformModulePath?: string, + +transformModulePath: string, transformTimeoutInterval?: number, watch?: boolean, }; @@ -131,7 +131,7 @@ class Server { resetCache: boolean, silent: boolean, +sourceExts: Array, - transformModulePath: void | string, + +transformModulePath: string, transformTimeoutInterval: ?number, watch: boolean, };