From ab08f47dec39188e4daa5fd1403f94e3c80790f9 Mon Sep 17 00:00:00 2001 From: Lukas Taegert-Atkinson Date: Mon, 1 Jun 2020 16:10:38 +0200 Subject: [PATCH] fix(node-resolve): handle nested entry modules with the resolveOnly option (#430) --- packages/node-resolve/package.json | 2 +- packages/node-resolve/src/index.js | 3 +- packages/node-resolve/src/util.js | 2 +- .../node-resolve/test/fixtures/nested/only.js | 10 +++ packages/node-resolve/test/only.js | 20 ++++++ .../node-resolve/test/snapshots/only.js.md | 6 ++ .../node-resolve/test/snapshots/only.js.snap | Bin 411 -> 435 bytes pnpm-lock.yaml | 58 +++++++++++++++--- 8 files changed, 88 insertions(+), 13 deletions(-) create mode 100755 packages/node-resolve/test/fixtures/nested/only.js diff --git a/packages/node-resolve/package.json b/packages/node-resolve/package.json index 4fd8e8755..62c7e1134 100755 --- a/packages/node-resolve/package.json +++ b/packages/node-resolve/package.json @@ -61,7 +61,7 @@ "@babel/preset-env": "^7.9.0", "@rollup/plugin-json": "^4.0.1", "es5-ext": "^0.10.53", - "rollup": "^2.0.0", + "rollup": "^2.12.0", "rollup-plugin-babel": "^4.3.3", "rollup-plugin-commonjs": "^10.1.0", "source-map": "^0.7.3", diff --git a/packages/node-resolve/src/index.js b/packages/node-resolve/src/index.js index 9a6858dd4..bed9a6f2a 100644 --- a/packages/node-resolve/src/index.js +++ b/packages/node-resolve/src/index.js @@ -122,13 +122,12 @@ export function nodeResolve(opts = {}) { isRelativeImport = true; } - const input = normalizeInput(rollupOptions.input); if ( !isRelativeImport && resolveOnly.length && !resolveOnly.some((pattern) => pattern.test(id)) ) { - if (input.includes(id)) { + if (normalizeInput(rollupOptions.input).includes(importee)) { return null; } return false; diff --git a/packages/node-resolve/src/util.js b/packages/node-resolve/src/util.js index bfc0a16e2..c4c8949c6 100644 --- a/packages/node-resolve/src/util.js +++ b/packages/node-resolve/src/util.js @@ -156,7 +156,7 @@ export function normalizeInput(input) { } // otherwise it's a string - return input; + return [input]; } // Resolve module specifiers in order. Promise resolves to the first module that resolves diff --git a/packages/node-resolve/test/fixtures/nested/only.js b/packages/node-resolve/test/fixtures/nested/only.js new file mode 100755 index 000000000..678d27230 --- /dev/null +++ b/packages/node-resolve/test/fixtures/nested/only.js @@ -0,0 +1,10 @@ +import foo from '@scoped/foo'; +import bar from '@scoped/bar'; +import test from 'test'; + +import local from '../only-local'; + +console.log(foo); +console.log(bar); +console.log(test); +console.log(local); diff --git a/packages/node-resolve/test/only.js b/packages/node-resolve/test/only.js index 1bb3b108a..59bb43bed 100644 --- a/packages/node-resolve/test/only.js +++ b/packages/node-resolve/test/only.js @@ -29,6 +29,26 @@ test('specify the only packages to resolve', async (t) => { t.assert(Object.keys(modules).includes(resolve('only-local.js'))); }); +test('handles nested entry modules', async (t) => { + const warnings = []; + const bundle = await rollup({ + input: ['nested/only.js'], + onwarn: (warning) => warnings.push(warning), + plugins: [ + nodeResolve({ + resolveOnly: ['test'] + }) + ] + }); + const imports = await getImports(bundle); + const modules = await getResolvedModules(bundle); + + t.is(warnings.length, 0); + t.snapshot(warnings); + t.deepEqual(imports, ['@scoped/foo', '@scoped/bar']); + t.assert(Object.keys(modules).includes(resolve('only-local.js'))); +}); + test('regex', async (t) => { const warnings = []; const bundle = await rollup({ diff --git a/packages/node-resolve/test/snapshots/only.js.md b/packages/node-resolve/test/snapshots/only.js.md index 4edfeb566..0996c4937 100644 --- a/packages/node-resolve/test/snapshots/only.js.md +++ b/packages/node-resolve/test/snapshots/only.js.md @@ -41,3 +41,9 @@ Generated by [AVA](https://ava.li). > Snapshot 1 [] + +## handles nested entry modules + +> Snapshot 1 + + [] diff --git a/packages/node-resolve/test/snapshots/only.js.snap b/packages/node-resolve/test/snapshots/only.js.snap index 2efe3a5811f338bab6b7bc32c5dd0c322413e093..4f4bed592576a826608a857c63089d2c1cef9638 100644 GIT binary patch delta 354 zcmV-o0iFJv1G57%K~_N^Q*L2!b7*gLAa*he0szVvZaE(O`IZ|{xNLEn=|CTg2mk;8 z00003>tJADU}cdqTz|pl<^O1|2d|AaEg!{KtF!@41BnI#F*5@@*iJ?cMkXB~Z3M)^ zjBJ98td2!RiIt3uFcv>QKLaBd10y2?BR3hpYC;18UVRN-fUMDND6d2+2rQNXXC2sZ3DFFDS{(&ns5QELKQKEhtJ& zPAo}H(NQSKNlh$HRVW4G1gJKDka{$G*a~t=(=+p6Tpna=7#R5&8GV7?gvoN0b=u{hDn5x znSqg2kdY-hKP45$;S2Byb@%j(4|fdm^Yn8^Q_7y3T3no%4u4nekq6YOTa;RypHr4< zr4W*ls*sSMms6RbkY7-enV(mzkXfvdl3Gxdnw(gYnxdmnkdvBNoT^X?#0gMs{vh>e z_OKP?l%{9q!MHrg)-W*gF*5oBy$O@$D9H~lDay=CXJC{B86pS?01mg(ykw9g7@3hc cz(7ERInJOaNe{_r%+V|605?vzYn%fB0KLGBMF0Q* diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index bf2b7df35..624cfd217 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -282,7 +282,7 @@ importers: rollup-plugin-babel: ^4.4.0 packages/node-resolve: dependencies: - '@rollup/pluginutils': 3.0.8_rollup@2.2.0 + '@rollup/pluginutils': 3.0.10_rollup@2.12.0 '@types/resolve': 0.0.8 builtin-modules: 3.1.0 deep-freeze: 0.0.1 @@ -292,11 +292,11 @@ importers: devDependencies: '@babel/core': 7.9.0 '@babel/preset-env': 7.9.5_@babel+core@7.9.0 - '@rollup/plugin-json': 4.0.1_rollup@2.2.0 + '@rollup/plugin-json': 4.0.3_rollup@2.12.0 es5-ext: 0.10.53 - rollup: 2.2.0 - rollup-plugin-babel: 4.3.3_@babel+core@7.9.0+rollup@2.2.0 - rollup-plugin-commonjs: 10.1.0_rollup@2.2.0 + rollup: 2.12.0 + rollup-plugin-babel: 4.3.3_@babel+core@7.9.0+rollup@2.12.0 + rollup-plugin-commonjs: 10.1.0_rollup@2.12.0 source-map: 0.7.3 string-capitalize: 1.0.1 specifiers: @@ -311,7 +311,7 @@ importers: es5-ext: ^0.10.53 is-module: ^1.0.0 resolve: ^1.14.2 - rollup: ^2.0.0 + rollup: ^2.12.0 rollup-plugin-babel: ^4.3.3 rollup-plugin-commonjs: ^10.1.0 source-map: ^0.7.3 @@ -2146,6 +2146,15 @@ packages: rollup: ^1.20.0 resolution: integrity: sha512-soxllkhOGgchswBAAaTe7X9G80U2tjjHvXv0sBrriLJcC/89PkP59iTrKPOfbz3SjX088mKDmMhAscuyLz8ZSg== + /@rollup/plugin-json/4.0.3_rollup@2.12.0: + dependencies: + '@rollup/pluginutils': 3.0.10_rollup@2.12.0 + rollup: 2.12.0 + dev: true + peerDependencies: + rollup: ^1.20.0 || ^2.0.0 + resolution: + integrity: sha512-QMUT0HZNf4CX17LMdwaslzlYHUKTYGuuk34yYIgZrNdu+pMEfqMS55gck7HEeHBKXHM4cz5Dg1OVwythDdbbuQ== /@rollup/plugin-node-resolve/7.1.1: dependencies: '@rollup/pluginutils': 3.0.8 @@ -2263,6 +2272,18 @@ packages: typescript: '>=2.1.0' resolution: integrity: sha512-KYZCn1Iw9hZWkeEPqPs5YjlmvSjR7UdezVca8z0e8rm/29wU24UD9Y4IZHhnc9tm749hzsgBTiOUxA85gfShEQ== + /@rollup/pluginutils/3.0.10_rollup@2.12.0: + dependencies: + '@types/estree': 0.0.39 + estree-walker: 1.0.1 + picomatch: 2.2.2 + rollup: 2.12.0 + engines: + node: '>= 8.0.0' + peerDependencies: + rollup: ^1.20.0||^2.0.0 + resolution: + integrity: sha512-d44M7t+PjmMrASHbhgpSbVgtL6EFyX7J4mYxwQ/c5eoaE6N2VgCgEcWVzNnwycIloti+/MpwFr8qfw+nRw00sw== /@rollup/pluginutils/3.0.10_rollup@2.2.0: dependencies: '@types/estree': 0.0.39 @@ -4518,7 +4539,6 @@ packages: resolution: integrity: sha512-R4wDiBwZ0KzpgOWetKDug1FZcYhqYnUYKtfZYt4mD5SBz76q0KR4Q9o7GIPamsVPGmW3EYPPJ0dOOjvx32ldZA== /fsevents/2.1.3: - dev: true engines: node: ^8.16.0 || ^10.6.0 || >=11.0.0 optional: true @@ -7524,6 +7544,18 @@ packages: hasBin: true resolution: integrity: sha512-NDGVxTsjqfunkds7CqsOiEnxln4Bo7Nddl3XhS4pXg5OzwkLqJ971ZVAAnB+DDLnF76N+VnDEiBHaVV8I06SUg== + /rollup-plugin-babel/4.3.3_@babel+core@7.9.0+rollup@2.12.0: + dependencies: + '@babel/core': 7.9.0 + '@babel/helper-module-imports': 7.8.3 + rollup: 2.12.0 + rollup-pluginutils: 2.8.2 + dev: true + peerDependencies: + '@babel/core': 7 || ^7.0.0-rc.2 + rollup: '>=0.60.0 <2' + resolution: + integrity: sha512-tKzWOCmIJD/6aKNz0H1GMM+lW1q9KyFubbWzGiOG540zxPPifnEAHTZwjo0g991Y+DyOZcLqBgqOdqazYE5fkw== /rollup-plugin-babel/4.3.3_@babel+core@7.9.0+rollup@2.2.0: dependencies: '@babel/core': 7.9.0 @@ -7560,13 +7592,13 @@ packages: rollup: '>=0.60.0 <3' resolution: integrity: sha512-Lek/TYp1+7g7I+uMfJnnSJ7YWoD58ajo6Oarhlex7lvUce+RCKRuGRSgztDO3/MF/PuGKmUL5iTHKf208UNszw== - /rollup-plugin-commonjs/10.1.0_rollup@2.2.0: + /rollup-plugin-commonjs/10.1.0_rollup@2.12.0: dependencies: estree-walker: 0.6.1 is-reference: 1.1.4 magic-string: 0.25.7 resolve: 1.15.0 - rollup: 2.2.0 + rollup: 2.12.0 rollup-pluginutils: 2.8.2 deprecated: This package has been deprecated and is no longer maintained. Please use @rollup/plugin-commonjs. dev: true @@ -7601,6 +7633,14 @@ packages: dev: true resolution: integrity: sha512-EEp9NhnUkwY8aif6bxgovPHMoMoNr2FulJziTndpt5H9RdwC47GSGuII9XxpSdzVGM0GWrNPHV6ie1LTNJPaLQ== + /rollup/2.12.0: + engines: + node: '>=10.0.0' + hasBin: true + optionalDependencies: + fsevents: 2.1.3 + resolution: + integrity: sha512-vKwc/xFkZGM9DRai3Eztpr/4g0yYDgNKVq8tLXhq/aSLbR+/EVL6rTjEW9bgWgeYEIKoN66/5w2Bjv1gzyHR/w== /rollup/2.2.0: engines: node: '>=10.0.0'