diff --git a/packages/typescript/test/fixtures/preserve-modules/main.ts b/packages/typescript/test/fixtures/preserve-modules/main.ts new file mode 100644 index 000000000..f2cbb3994 --- /dev/null +++ b/packages/typescript/test/fixtures/preserve-modules/main.ts @@ -0,0 +1,6 @@ +const b = () => { + const a = { a: 1, b: 2 }; + console.log({ ...a }); +} + +export { b } diff --git a/packages/typescript/test/fixtures/preserve-modules/tsconfig.json b/packages/typescript/test/fixtures/preserve-modules/tsconfig.json new file mode 100644 index 000000000..7a570de4e --- /dev/null +++ b/packages/typescript/test/fixtures/preserve-modules/tsconfig.json @@ -0,0 +1,11 @@ +{ + "compilerOptions": { + "allowSyntheticDefaultImports": true, + "downlevelIteration": true, + "esModuleInterop": true, + "forceConsistentCasingInFileNames": true, + "module": "esnext", + "strict": true, + "target": "es5" + } +} diff --git a/packages/typescript/test/test.js b/packages/typescript/test/test.js index 0da0b48c1..b8f63dd85 100644 --- a/packages/typescript/test/test.js +++ b/packages/typescript/test/test.js @@ -589,6 +589,19 @@ test('should throw on bad options', async (t) => { ]); }); +test('creates _tslib.js file when preserveModules is used', async (t) => { + const bundle = await rollup({ + input: 'fixtures/preserve-modules/main.ts', + plugins: [typescript({ tsconfig: 'fixtures/preserve-modules/tsconfig.json' })], + preserveModules: true, + onwarn + }); + + const files = await getCode(bundle, { format: 'es' }, true); + t.true(files[0].fileName.includes('main.js'), files[0].fileName); + t.true(files[1].fileName.includes('tslib.es6.js'), files[1].fileName); +}); + test('should handle re-exporting types', async (t) => { const bundle = await rollup({ input: 'fixtures/reexport-type/main.ts',