diff --git a/packages/commonjs/.prettierignore b/packages/commonjs/.prettierignore new file mode 100644 index 000000000..b797e4c31 --- /dev/null +++ b/packages/commonjs/.prettierignore @@ -0,0 +1 @@ +test/fixtures/form/output*.js diff --git a/packages/commonjs/src/index.js b/packages/commonjs/src/index.js index 19d2b203b..9108add70 100644 --- a/packages/commonjs/src/index.js +++ b/packages/commonjs/src/index.js @@ -80,11 +80,14 @@ export default function commonjs(options = {}) { return null; } + const moduleInfo = this.getModuleInfo(id); + const transformed = transformCommonjs( this.parse, code, id, - this.getModuleInfo(id).isEntry, + moduleInfo.isEntry, + moduleInfo.importers && moduleInfo.importers.length > 0, isEsModule, ignoreGlobal || isEsModule, ignoreRequire, diff --git a/packages/commonjs/src/transform.js b/packages/commonjs/src/transform.js index d371b707f..8b882767c 100644 --- a/packages/commonjs/src/transform.js +++ b/packages/commonjs/src/transform.js @@ -106,6 +106,7 @@ export function transformCommonjs( code, id, isEntry, + hasImporters, isEsModule, ignoreGlobal, ignoreRequire, @@ -564,7 +565,7 @@ export function transformCommonjs( let wrapperEnd = ''; const moduleName = deconflict(scope, globals, getName(id)); - if (!isEntry && !isEsModule) { + if ((!isEntry || hasImporters) && !isEsModule) { const exportModuleExports = { str: `export { ${moduleName} as __moduleExports };`, name: '__moduleExports' @@ -634,7 +635,7 @@ export function transformCommonjs( } } - if (!hasDefaultExport && (names.length || (!isEntry && !isEsModule))) { + if (!hasDefaultExport && (names.length || ((!isEntry || hasImporters) && !isEsModule))) { wrapperEnd = `\n\nvar ${moduleName} = {\n${names .map(({ name, deconflicted }) => `\t${name}: ${deconflicted}`) .join(',\n')}\n};`; @@ -660,7 +661,8 @@ export function transformCommonjs( .trim() .append(wrapperEnd); - const injectExportBlock = hasDefaultExport || named.length > 0 || shouldWrap || !isEntry; + const injectExportBlock = + hasDefaultExport || named.length > 0 || shouldWrap || !isEntry || hasImporters; if (injectExportBlock) { magicString.append(exportBlock); } diff --git a/packages/commonjs/test/fixtures/form/multi-entry-module-exports/_config.js b/packages/commonjs/test/fixtures/form/multi-entry-module-exports/_config.js new file mode 100644 index 000000000..54e5ab230 --- /dev/null +++ b/packages/commonjs/test/fixtures/form/multi-entry-module-exports/_config.js @@ -0,0 +1,9 @@ +module.exports = { + multi: { + output1: 'input1.js', + output2: 'input2.js' + }, + importers: { + output2: ['input1.js'] + } +}; diff --git a/packages/commonjs/test/fixtures/form/multi-entry-module-exports/input1.js b/packages/commonjs/test/fixtures/form/multi-entry-module-exports/input1.js new file mode 100644 index 000000000..7aff633ef --- /dev/null +++ b/packages/commonjs/test/fixtures/form/multi-entry-module-exports/input1.js @@ -0,0 +1,4 @@ +const t2 = require('./input2.js'); + +console.log(t2); +module.exports = 1; diff --git a/packages/commonjs/test/fixtures/form/multi-entry-module-exports/input2.js b/packages/commonjs/test/fixtures/form/multi-entry-module-exports/input2.js new file mode 100644 index 000000000..39d4e85af --- /dev/null +++ b/packages/commonjs/test/fixtures/form/multi-entry-module-exports/input2.js @@ -0,0 +1,3 @@ +module.exports = { + a: 2 +}; diff --git a/packages/commonjs/test/fixtures/form/multi-entry-module-exports/output1.js b/packages/commonjs/test/fixtures/form/multi-entry-module-exports/output1.js new file mode 100644 index 000000000..fd1e0719e --- /dev/null +++ b/packages/commonjs/test/fixtures/form/multi-entry-module-exports/output1.js @@ -0,0 +1,8 @@ +import './input2.js'; +import t2 from '_./input2.js?commonjs-proxy'; + +console.log(t2); +var input1 = 1; + +export default input1; +export { input1 as __moduleExports }; diff --git a/packages/commonjs/test/fixtures/form/multi-entry-module-exports/output2.js b/packages/commonjs/test/fixtures/form/multi-entry-module-exports/output2.js new file mode 100644 index 000000000..b02231f2c --- /dev/null +++ b/packages/commonjs/test/fixtures/form/multi-entry-module-exports/output2.js @@ -0,0 +1,6 @@ +var input2 = { + a: 2 +}; + +export default input2; +export { input2 as __moduleExports }; diff --git a/packages/commonjs/test/form.js b/packages/commonjs/test/form.js index 0ecf6e33d..e84cacf66 100644 --- a/packages/commonjs/test/form.js +++ b/packages/commonjs/test/form.js @@ -27,35 +27,50 @@ readdirSync('./fixtures/form').forEach((dir) => { config = {}; } + const inputEntries = []; + + if (typeof config.multi === 'object') { + for (const [key, entry] of Object.entries(config.multi)) { + inputEntries.push([key, `fixtures/form/${dir}/${entry}`]); + } + } else { + inputEntries.push(['output', `fixtures/form/${dir}/input.js`]); + } + (config.solo ? test.only : test)(dir, async (t) => { - const { transform } = commonjs(config.options); - const id = `./fixtures/form/${dir}/input.js`; + for (const [outputName, id] of inputEntries) { + const { transform } = commonjs(config.options); - transformContext.getModuleInfo = (moduleId) => { - return { - isEntry: config.entry && moduleId === id + transformContext.getModuleInfo = (moduleId) => { + return { + isEntry: config.entry && moduleId === id, + importers: + config.importers && config.importers[outputName] + ? config.importers[outputName].map((x) => `fixtures/form/${dir}/${x}`) + : [] + }; }; - }; - transformContext.error = (base, props) => { - let error = base; - if (!(base instanceof Error)) error = Object.assign(new Error(base.message), base); - if (props) Object.assign(error, props); - throw error; - }; - - const input = readFileSync(id, 'utf-8'); - - let outputFile = `fixtures/form/${dir}/output`; - if (existsSync(`${outputFile}.${process.platform}.js`)) { - outputFile += `.${process.platform}.js`; - } else { - outputFile += '.js'; - } + transformContext.error = (base, props) => { + let error = base; + if (!(base instanceof Error)) error = Object.assign(new Error(base.message), base); + if (props) Object.assign(error, props); + throw error; + }; + + const input = readFileSync(id, 'utf-8'); - const expected = readFileSync(outputFile, 'utf-8').trim(); - const transformed = transform.call(transformContext, input, id); - const actual = (transformed ? transformed.code : input).trim().replace(/\0/g, '_'); + let outputFile = `fixtures/form/${dir}/${outputName}`; + if (existsSync(`${outputFile}.${process.platform}.js`)) { + outputFile += `.${process.platform}.js`; + } else { + outputFile += '.js'; + } - t.is(actual, expected); + const expected = readFileSync(outputFile, 'utf-8').trim(); + const transformed = transform.call(transformContext, input, id); + const actual = (transformed ? transformed.code : input).trim().replace(/\0/g, '_'); + + t.is(actual, expected); + } }); }); diff --git a/packages/commonjs/test/snapshots/function.js.md b/packages/commonjs/test/snapshots/function.js.md index fa724cc97..369671717 100644 --- a/packages/commonjs/test/snapshots/function.js.md +++ b/packages/commonjs/test/snapshots/function.js.md @@ -4,7 +4,7 @@ The actual snapshot is saved in `function.js.snap`. Generated by [AVA](https://ava.li). -## \_\_esModule +## __esModule > Snapshot 1 diff --git a/packages/commonjs/test/snapshots/function.js.snap b/packages/commonjs/test/snapshots/function.js.snap index 578c30a54..3ebf253e9 100644 Binary files a/packages/commonjs/test/snapshots/function.js.snap and b/packages/commonjs/test/snapshots/function.js.snap differ