From 96d92fa955eac07ce50184166dc42de23b97425b Mon Sep 17 00:00:00 2001 From: simonihmig Date: Fri, 3 Jun 2022 19:25:24 +0200 Subject: [PATCH] Strip extension from reexport of `rollup-app-reexports` This makes `rollup-app-reexports` strip file extensions (`.js`) from reexports, aligning with (the blueprint of) v1 addons, and allowing better interoperability with `package.json#exports` with path mappings including extensions, as discussed in https://github.com/typed-ember/glint/issues/338. --- .../addon-dev/src/rollup-app-reexports.ts | 6 +++- tests/scenarios/v2-addon-dev-test.ts | 28 ++++++++++++++----- 2 files changed, 26 insertions(+), 8 deletions(-) diff --git a/packages/addon-dev/src/rollup-app-reexports.ts b/packages/addon-dev/src/rollup-app-reexports.ts index 0e87da532..9e72c3809 100644 --- a/packages/addon-dev/src/rollup-app-reexports.ts +++ b/packages/addon-dev/src/rollup-app-reexports.ts @@ -1,4 +1,5 @@ import { readJsonSync, writeJsonSync } from 'fs-extra'; +import { extname } from 'path'; import minimatch from 'minimatch'; import type { Plugin } from 'rollup'; @@ -24,7 +25,10 @@ export default function appReexports(opts: { this.emitFile({ type: 'asset', fileName: `_app_/${appFilename}`, - source: `export { default } from "${pkg.name}/${addonFilename}";\n`, + source: `export { default } from "${pkg.name}/${addonFilename.slice( + 0, + -extname(addonFilename).length + )}";\n`, }); } } diff --git a/tests/scenarios/v2-addon-dev-test.ts b/tests/scenarios/v2-addon-dev-test.ts index bd819ad1e..3ba510495 100644 --- a/tests/scenarios/v2-addon-dev-test.ts +++ b/tests/scenarios/v2-addon-dev-test.ts @@ -3,7 +3,7 @@ import { appScenarios, baseV2Addon } from './scenarios'; import { PreparedApp } from 'scenario-tester'; import QUnit from 'qunit'; import merge from 'lodash/merge'; -import { pathExistsSync, readJsonSync } from 'fs-extra'; +import { pathExistsSync, readJsonSync, readFileSync } from 'fs-extra'; const { module: Qmodule, test } = QUnit; @@ -202,12 +202,26 @@ appScenarios test('the addon was built successfully', async function (assert) { let { dir } = inDependency(app, 'v2-addon'); - let files: string[] = Object.values(readJsonSync(path.join(dir, 'package.json'))['ember-addon']['app-js']); - - assert.expect(files.length); - - for (let pathName of files) { - assert.deepEqual(pathExistsSync(path.join(dir, pathName)), true, `pathExists: ${pathName}`); + let expectedModules = { + './dist/_app_/components/demo/index.js': 'export { default } from "v2-addon/components/demo/index";\n', + './dist/_app_/components/demo/out.js': 'export { default } from "v2-addon/components/demo/out";\n', + './dist/_app_/components/demo/namespace/namespace-me.js': + 'export { default } from "v2-addon/components/demo/namespace-me";\n', + }; + + assert.strictEqual( + Object.keys(readJsonSync(path.join(dir, 'package.json'))['ember-addon']['app-js']).length, + Object.keys(expectedModules).length + ); + + for (let [pathName, moduleContents] of Object.entries(expectedModules)) { + let filePath = path.join(dir, pathName); + assert.deepEqual(pathExistsSync(filePath), true, `pathExists: ${pathName}`); + assert.strictEqual( + readFileSync(filePath, { encoding: 'utf8' }), + moduleContents, + `has correct reexport: ${pathName}` + ); } }); });