From 78515c3fb1666e5233fd312064b0bda877cf1d3e Mon Sep 17 00:00:00 2001 From: Rich-Harris Date: Sun, 9 Oct 2016 09:35:12 -0400 Subject: [PATCH] better error for missing export (#1033) --- src/Module.js | 3 ++- src/utils/relativeId.js | 4 ++++ test/function/import-of-unexported-fails/_config.js | 2 +- test/test.js | 2 ++ 4 files changed, 9 insertions(+), 2 deletions(-) create mode 100644 src/utils/relativeId.js diff --git a/src/Module.js b/src/Module.js index 3abdd4c..41386f5 100644 --- a/src/Module.js +++ b/src/Module.js @@ -6,6 +6,7 @@ import { basename, extname } from './utils/path.js'; import getLocation from './utils/getLocation.js'; import makeLegalIdentifier from './utils/makeLegalIdentifier.js'; import SOURCEMAPPING_URL from './utils/sourceMappingURL.js'; +import relativeId from './utils/relativeId.js'; import { SyntheticNamespaceDeclaration } from './Declaration.js'; import extractNames from './ast/utils/extractNames.js'; import enhance from './ast/enhance.js'; @@ -357,7 +358,7 @@ export default class Module { const declaration = otherModule.traceExport( importDeclaration.name ); - if ( !declaration ) throw new Error( `Module ${otherModule.id} does not export ${importDeclaration.name} (imported by ${this.id})` ); + if ( !declaration ) throw new Error( `'${importDeclaration.name}' is not exported by ${relativeId( otherModule.id )} (imported by ${relativeId( this.id )}). For help fixing this error see https://github.com/rollup/rollup/wiki/Troubleshooting#name-is-not-exported-by-module` ); return declaration; } diff --git a/src/utils/relativeId.js b/src/utils/relativeId.js new file mode 100644 index 0000000..e26bd02 --- /dev/null +++ b/src/utils/relativeId.js @@ -0,0 +1,4 @@ +export default function relativeId ( id ) { + if ( typeof process === 'undefined' ) return id; + return id.replace( process.cwd(), '' ).replace( /^[\/\\]/, '' ); +} diff --git a/test/function/import-of-unexported-fails/_config.js b/test/function/import-of-unexported-fails/_config.js index 3027ba9..10d11a6 100644 --- a/test/function/import-of-unexported-fails/_config.js +++ b/test/function/import-of-unexported-fails/_config.js @@ -3,6 +3,6 @@ var assert = require( 'assert' ); module.exports = { description: 'marking an imported, but unexported, identifier should throw', error: function ( err ) { - assert.ok( /Module .+empty\.js does not export default \(imported by .+main\.js\)/.test( err.message ) ); + assert.equal( err.message, `'default' is not exported by empty.js (imported by main.js). For help fixing this error see https://github.com/rollup/rollup/wiki/Troubleshooting#name-is-not-exported-by-module` ); } }; diff --git a/test/test.js b/test/test.js index 52cc00e..965cafd 100644 --- a/test/test.js +++ b/test/test.js @@ -186,6 +186,8 @@ describe( 'rollup', function () { const config = loadConfig( FUNCTION + '/' + dir + '/_config.js' ); ( config.skip ? it.skip : config.solo ? it.only : it )( dir, () => { + process.chdir( FUNCTION + '/' + dir ); + const warnings = []; const captureWarning = msg => warnings.push( msg );