Browse Source

use bundle.warn and module.warn throughout codebase

gh-786
Rich-Harris 8 years ago
parent
commit
4dba546885
  1. 30
      src/Bundle.js
  2. 16
      src/Module.js
  3. 7
      src/ast/nodes/ExportDefaultDeclaration.js
  4. 8
      src/ast/nodes/MemberExpression.js
  5. 12
      src/ast/nodes/ThisExpression.js
  6. 6
      src/ast/scopes/ModuleScope.js
  7. 2
      src/finalisers/iife.js
  8. 8
      src/finalisers/shared/getGlobalNameMaker.js
  9. 5
      src/finalisers/shared/warnOnBuiltins.js
  10. 2
      src/finalisers/umd.js
  11. 8
      src/utils/collapseSourcemaps.js
  12. 6
      src/utils/getExportMode.js
  13. 9
      test/function/assign-namespace-to-var/_config.js
  14. 12
      test/function/custom-path-resolver-async/_config.js
  15. 12
      test/function/custom-path-resolver-sync/_config.js
  16. 12
      test/function/does-not-hang-on-missing-module/_config.js
  17. 13
      test/function/double-named-export-from/_config.js
  18. 27
      test/function/empty-exports/_config.js
  19. 9
      test/function/module-tree/_config.js
  20. 24
      test/function/namespace-missing-export/_config.js
  21. 20
      test/function/unused-import/_config.js
  22. 22
      test/function/warn-on-ambiguous-function-export/_config.js
  23. 12
      test/function/warn-on-auto-named-default-exports/_config.js
  24. 11
      test/function/warn-on-empty-bundle/_config.js
  25. 6
      test/function/warn-on-eval/_config.js
  26. 9
      test/function/warn-on-namespace-conflict/_config.js
  27. 0
      test/function/warn-on-namespace-conflict/bar.js
  28. 0
      test/function/warn-on-namespace-conflict/deep.js
  29. 0
      test/function/warn-on-namespace-conflict/foo.js
  30. 0
      test/function/warn-on-namespace-conflict/main.js
  31. 22
      test/function/warn-on-top-level-this/_config.js
  32. 21
      test/function/warn-on-unused-missing-imports/_config.js
  33. 20
      test/sourcemaps/transform-without-sourcemap/_config.js
  34. 59
      test/test.js

30
src/Bundle.js

@ -188,7 +188,10 @@ export default class Bundle {
`'${unused[0]}' is` : `'${unused[0]}' is` :
`${unused.slice( 0, -1 ).map( name => `'${name}'` ).join( ', ' )} and '${unused.pop()}' are`; `${unused.slice( 0, -1 ).map( name => `'${name}'` ).join( ', ' )} and '${unused.pop()}' are`;
this.onwarn( `${names} imported from external module '${module.id}' but never used` ); this.warn({
code: 'UNUSED_EXTERNAL_IMPORT',
message: `${names} imported from external module '${module.id}' but never used`
});
}); });
this.orderedModules = this.sort(); this.orderedModules = this.sort();
@ -309,7 +312,10 @@ export default class Bundle {
keys( exportAllModule.exportsAll ).forEach( name => { keys( exportAllModule.exportsAll ).forEach( name => {
if ( name in module.exportsAll ) { if ( name in module.exportsAll ) {
this.onwarn( `Conflicting namespaces: ${module.id} re-exports '${name}' from both ${module.exportsAll[ name ]} (will be ignored) and ${exportAllModule.exportsAll[ name ]}.` ); this.warn({
code: 'NAMESPACE_CONFLICT',
message: `Conflicting namespaces: ${relativeId( module.id )} re-exports '${name}' from both ${relativeId( module.exportsAll[ name ] )} (will be ignored) and ${relativeId( exportAllModule.exportsAll[ name ] )}`
});
} }
module.exportsAll[ name ] = exportAllModule.exportsAll[ name ]; module.exportsAll[ name ] = exportAllModule.exportsAll[ name ];
}); });
@ -333,7 +339,11 @@ export default class Bundle {
if ( !resolvedId && !isExternal ) { if ( !resolvedId && !isExternal ) {
if ( isRelative( source ) ) throw new Error( `Could not resolve '${source}' from ${module.id}` ); if ( isRelative( source ) ) throw new Error( `Could not resolve '${source}' from ${module.id}` );
this.onwarn( `'${source}' is imported by ${relativeId( module.id )}, but could not be resolved – treating it as an external dependency. For help see https://github.com/rollup/rollup/wiki/Troubleshooting#treating-module-as-external-dependency` ); this.warn({
code: 'UNRESOLVED_IMPORT',
message: `'${source}' is imported by ${relativeId( module.id )}, but could not be resolved – treating it as an external dependency`,
url: 'https://github.com/rollup/rollup/wiki/Troubleshooting#treating-module-as-external-dependency'
});
isExternal = true; isExternal = true;
} }
@ -380,7 +390,11 @@ export default class Bundle {
render ( options = {} ) { render ( options = {} ) {
if ( options.format === 'es6' ) { if ( options.format === 'es6' ) {
this.onwarn( 'The es6 format is deprecated – use `es` instead' ); this.warn({
code: 'DEPRECATED_ES6',
message: 'The es6 format is deprecated – use `es` instead'
});
options.format = 'es'; options.format = 'es';
} }
@ -404,7 +418,10 @@ export default class Bundle {
}); });
if ( !magicString.toString().trim() && this.entryModule.getExports().length === 0 ) { if ( !magicString.toString().trim() && this.entryModule.getExports().length === 0 ) {
this.onwarn( 'Generated an empty bundle' ); this.warn({
code: 'EMPTY_BUNDLE',
message: 'Generated an empty bundle'
});
} }
timeEnd( 'render modules' ); timeEnd( 'render modules' );
@ -470,7 +487,7 @@ export default class Bundle {
if ( typeof map.mappings === 'string' ) { if ( typeof map.mappings === 'string' ) {
map.mappings = decode( map.mappings ); map.mappings = decode( map.mappings );
} }
map = collapseSourcemaps( file, map, usedModules, bundleSourcemapChain, this.onwarn ); map = collapseSourcemaps( this, file, map, usedModules, bundleSourcemapChain );
} else { } else {
map = magicString.generateMap({ file, includeContent: true }); map = magicString.generateMap({ file, includeContent: true });
} }
@ -535,6 +552,7 @@ export default class Bundle {
for ( i += 1; i < ordered.length; i += 1 ) { for ( i += 1; i < ordered.length; i += 1 ) {
const b = ordered[i]; const b = ordered[i];
// TODO reinstate this! it no longer works
if ( stronglyDependsOn[ a.id ][ b.id ] ) { if ( stronglyDependsOn[ a.id ][ b.id ] ) {
// somewhere, there is a module that imports b before a. Because // somewhere, there is a module that imports b before a. Because
// b imports a, a is placed before b. We need to find the module // b imports a, a is placed before b. We need to find the module

16
src/Module.js

@ -180,7 +180,12 @@ export default class Module {
this.exports[ exportedName ] = { localName }; this.exports[ exportedName ] = { localName };
}); });
} else { } else {
this.bundle.onwarn( `Module ${this.id} has an empty export declaration` ); // TODO is this really necessary? `export {}` is valid JS, and
// might be used as a hint that this is indeed a module
this.warn({
code: 'EMPTY_EXPORT',
message: `Empty export declaration`
}, node.start );
} }
} }
} }
@ -408,17 +413,12 @@ export default class Module {
} }
warn ( warning, pos ) { warn ( warning, pos ) {
if ( pos ) { if ( pos !== undefined ) {
warning.pos = pos; warning.pos = pos;
const { line, column } = locate( this.code, pos, { offsetLine: 1 }); // TODO trace sourcemaps const { line, column } = locate( this.code, pos, { offsetLine: 1 }); // TODO trace sourcemaps
warning.loc = { warning.loc = { file: this.id, line, column };
file: this.id,
line: line + 1,
column
};
warning.frame = getCodeFrame( this.code, line, column ); warning.frame = getCodeFrame( this.code, line, column );
} }

7
src/ast/nodes/ExportDefaultDeclaration.js

@ -74,8 +74,11 @@ export default class ExportDefaultDeclaration extends Node {
const newlineSeparated = /\n/.test( code.original.slice( start, end ) ); const newlineSeparated = /\n/.test( code.original.slice( start, end ) );
if ( newlineSeparated ) { if ( newlineSeparated ) {
const { line, column } = locate( this.module.code, this.declaration.start, { offsetLine: 1 }); this.module.warn({
this.module.bundle.onwarn( `${relativeId( this.module.id )} (${line}:${column}) Ambiguous default export (is a call expression, but looks like a function declaration). See https://github.com/rollup/rollup/wiki/Troubleshooting#ambiguous-default-export` ); code: 'AMBIGUOUS_DEFAULT_EXPORT',
message: `Ambiguous default export (is a call expression, but looks like a function declaration)`,
url: 'https://github.com/rollup/rollup/wiki/Troubleshooting#ambiguous-default-export'
}, this.declaration.start );
} }
} }
} }

8
src/ast/nodes/MemberExpression.js

@ -1,5 +1,4 @@
import isReference from 'is-reference'; import isReference from 'is-reference';
import { locate } from 'locate-character';
import relativeId from '../../utils/relativeId.js'; import relativeId from '../../utils/relativeId.js';
import Node from '../Node.js'; import Node from '../Node.js';
import { UNKNOWN } from '../values.js'; import { UNKNOWN } from '../values.js';
@ -34,8 +33,11 @@ export default class MemberExpression extends Node {
declaration = declaration.module.traceExport( part.name ); declaration = declaration.module.traceExport( part.name );
if ( !declaration ) { if ( !declaration ) {
const { line, column } = locate( this.module.code, this.start, { offsetLine: 1 }); this.module.warn({
this.module.bundle.onwarn( `${relativeId( this.module.id )} (${line}:${column}) '${part.name}' is not exported by '${relativeId( exporterId )}'. See https://github.com/rollup/rollup/wiki/Troubleshooting#name-is-not-exported-by-module` ); code: 'MISSING_EXPORT',
message: `'${part.name}' is not exported by '${relativeId( exporterId )}'`,
url: `https://github.com/rollup/rollup/wiki/Troubleshooting#name-is-not-exported-by-module`
}, part.start );
this.replacement = 'undefined'; this.replacement = 'undefined';
return; return;
} }

12
src/ast/nodes/ThisExpression.js

@ -1,8 +1,4 @@
import Node from '../Node.js'; import Node from '../Node.js';
import { locate } from 'locate-character';
import relativeId from '../../utils/relativeId.js';
const warning = `The 'this' keyword is equivalent to 'undefined' at the top level of an ES module, and has been rewritten. See https://github.com/rollup/rollup/wiki/Troubleshooting#this-is-undefined for more information`;
export default class ThisExpression extends Node { export default class ThisExpression extends Node {
initialise ( scope ) { initialise ( scope ) {
@ -11,9 +7,11 @@ export default class ThisExpression extends Node {
if ( lexicalBoundary.isModuleScope ) { if ( lexicalBoundary.isModuleScope ) {
this.alias = this.module.context; this.alias = this.module.context;
if ( this.alias === 'undefined' ) { if ( this.alias === 'undefined' ) {
const { line, column } = locate( this.module.code, this.start, { offsetLine: 1 }); this.module.warn({
const detail = `${relativeId( this.module.id )} (${line}:${column + 1})`; // use one-based column number convention code: 'THIS_IS_UNDEFINED',
this.module.bundle.onwarn( `${detail} ${warning}` ); message: `The 'this' keyword is equivalent to 'undefined' at the top level of an ES module, and has been rewritten`,
url: `https://github.com/rollup/rollup/wiki/Troubleshooting#this-is-undefined`
}, this.start );
} }
} }
} }

6
src/ast/scopes/ModuleScope.js

@ -1,4 +1,5 @@
import { forOwn } from '../../utils/object.js'; import { forOwn } from '../../utils/object.js';
import relativeId from '../../utils/relativeId.js';
import Scope from './Scope.js'; import Scope from './Scope.js';
export default class ModuleScope extends Scope { export default class ModuleScope extends Scope {
@ -26,7 +27,10 @@ export default class ModuleScope extends Scope {
if ( specifier.name !== '*' ) { if ( specifier.name !== '*' ) {
const declaration = specifier.module.traceExport( specifier.name ); const declaration = specifier.module.traceExport( specifier.name );
if ( !declaration ) { if ( !declaration ) {
this.module.bundle.onwarn( `Non-existent export '${specifier.name}' is imported from ${specifier.module.id} by ${this.module.id}` ); this.module.warn({
code: 'NON_EXISTENT_EXPORT',
message: `Non-existent export '${specifier.name}' is imported from ${relativeId( specifier.module.id )}`
}, specifier.specifier.start );
return; return;
} }

2
src/finalisers/iife.js

@ -25,7 +25,7 @@ function setupNamespace ( keypath ) {
} }
export default function iife ( bundle, magicString, { exportMode, indentString, intro, outro }, options ) { export default function iife ( bundle, magicString, { exportMode, indentString, intro, outro }, options ) {
const globalNameMaker = getGlobalNameMaker( options.globals || blank(), bundle.onwarn ); const globalNameMaker = getGlobalNameMaker( options.globals || blank(), bundle );
const name = options.moduleName; const name = options.moduleName;
const isNamespaced = name && ~name.indexOf( '.' ); const isNamespaced = name && ~name.indexOf( '.' );

8
src/finalisers/shared/getGlobalNameMaker.js

@ -1,11 +1,15 @@
export default function getGlobalNameMaker ( globals, onwarn ) { export default function getGlobalNameMaker ( globals, bundle ) {
const fn = typeof globals === 'function' ? globals : id => globals[ id ]; const fn = typeof globals === 'function' ? globals : id => globals[ id ];
return function ( module ) { return function ( module ) {
const name = fn( module.id ); const name = fn( module.id );
if ( name ) return name; if ( name ) return name;
onwarn( `No name was provided for external module '${module.id}' in options.globals – guessing '${module.name}'` ); bundle.warn({
code: 'MISSING_GLOBAL_NAME',
message: `No name was provided for external module '${module.id}' in options.globals – guessing '${module.name}'`
});
return module.name; return module.name;
}; };
} }

5
src/finalisers/shared/warnOnBuiltins.js

@ -35,5 +35,8 @@ export default function warnOnBuiltins ( bundle ) {
`module ('${externalBuiltins[0]}')` : `module ('${externalBuiltins[0]}')` :
`modules (${externalBuiltins.slice( 0, -1 ).map( name => `'${name}'` ).join( ', ' )} and '${externalBuiltins.pop()}')`; `modules (${externalBuiltins.slice( 0, -1 ).map( name => `'${name}'` ).join( ', ' )} and '${externalBuiltins.pop()}')`;
bundle.onwarn( `Creating a browser bundle that depends on Node.js built-in ${detail}. You might need to include https://www.npmjs.com/package/rollup-plugin-node-builtins` ); bundle.warn({
code: 'MISSING_NODE_BUILTINS',
message: `Creating a browser bundle that depends on Node.js built-in ${detail}. You might need to include https://www.npmjs.com/package/rollup-plugin-node-builtins`
});
} }

2
src/finalisers/umd.js

@ -33,7 +33,7 @@ export default function umd ( bundle, magicString, { exportMode, indentString, i
warnOnBuiltins( bundle ); warnOnBuiltins( bundle );
const globalNameMaker = getGlobalNameMaker( options.globals || blank(), bundle.onwarn ); const globalNameMaker = getGlobalNameMaker( options.globals || blank(), bundle );
const amdDeps = bundle.externalModules.map( quotePath ); const amdDeps = bundle.externalModules.map( quotePath );
const cjsDeps = bundle.externalModules.map( req ); const cjsDeps = bundle.externalModules.map( req );

8
src/utils/collapseSourcemaps.js

@ -98,7 +98,7 @@ class Link {
} }
} }
export default function collapseSourcemaps ( file, map, modules, bundleSourcemapChain, onwarn ) { export default function collapseSourcemaps ( bundle, file, map, modules, bundleSourcemapChain ) {
const moduleSources = modules.filter( module => !module.excludeFromSourcemap ).map( module => { const moduleSources = modules.filter( module => !module.excludeFromSourcemap ).map( module => {
let sourceMapChain = module.sourceMapChain; let sourceMapChain = module.sourceMapChain;
@ -127,7 +127,11 @@ export default function collapseSourcemaps ( file, map, modules, bundleSourcemap
sourceMapChain.forEach( map => { sourceMapChain.forEach( map => {
if ( map.missing ) { if ( map.missing ) {
onwarn( `Sourcemap is likely to be incorrect: a plugin${map.plugin ? ` ('${map.plugin}')` : ``} was used to transform files, but didn't generate a sourcemap for the transformation. Consult https://github.com/rollup/rollup/wiki/Troubleshooting and the plugin documentation for more information` ); bundle.warn({
code: 'SOURCEMAP_BROKEN',
message: `Sourcemap is likely to be incorrect: a plugin${map.plugin ? ` ('${map.plugin}')` : ``} was used to transform files, but didn't generate a sourcemap for the transformation. Consult the plugin documentation for help`,
url: `https://github.com/rollup/rollup/wiki/Troubleshooting#sourcemap-is-likely-to-be-incorrect`
});
map = { map = {
names: [], names: [],

6
src/utils/getExportMode.js

@ -24,7 +24,11 @@ export default function getExportMode ( bundle, {exports: exportMode, moduleName
exportMode = 'default'; exportMode = 'default';
} else { } else {
if ( bundle.entryModule.exports.default && format !== 'es') { if ( bundle.entryModule.exports.default && format !== 'es') {
bundle.onwarn( `Using named and default exports together. Consumers of your bundle will have to use ${moduleName || 'bundle'}['default'] to access the default export, which may not be what you want. Use \`exports: 'named'\` to disable this warning. See https://github.com/rollup/rollup/wiki/JavaScript-API#exports for more information` ); bundle.warn({
code: 'MIXED_EXPORTS',
message: `Using named and default exports together. Consumers of your bundle will have to use ${moduleName || 'bundle'}['default'] to access the default export, which may not be what you want. Use \`exports: 'named'\` to disable this warning`,
url: `https://github.com/rollup/rollup/wiki/JavaScript-API#exports`
});
} }
exportMode = 'named'; exportMode = 'named';
} }

9
test/function/assign-namespace-to-var/_config.js

@ -2,9 +2,10 @@ const assert = require( 'assert' );
module.exports = { module.exports = {
description: 'allows a namespace to be assigned to a variable', description: 'allows a namespace to be assigned to a variable',
warnings: warnings => { warnings: [
assert.deepEqual( warnings, [ {
'Generated an empty bundle' code: 'EMPTY_BUNDLE',
]); message: 'Generated an empty bundle'
} }
]
}; };

12
test/function/custom-path-resolver-async/_config.js

@ -21,11 +21,13 @@ module.exports = {
} }
}] }]
}, },
warnings: function ( warnings ) { warnings: [
assert.deepEqual( warnings, [ {
`'path' is imported by main.js, but could not be resolved – treating it as an external dependency. For help see https://github.com/rollup/rollup/wiki/Troubleshooting#treating-module-as-external-dependency` code: 'UNRESOLVED_IMPORT',
]); message: `'path' is imported by main.js, but could not be resolved – treating it as an external dependency`,
}, url: `https://github.com/rollup/rollup/wiki/Troubleshooting#treating-module-as-external-dependency`
}
],
exports: function ( exports ) { exports: function ( exports ) {
assert.strictEqual( exports.path, require( 'path' ) ); assert.strictEqual( exports.path, require( 'path' ) );
} }

12
test/function/custom-path-resolver-sync/_config.js

@ -13,11 +13,13 @@ module.exports = {
} }
}] }]
}, },
warnings: function ( warnings ) { warnings: [
assert.deepEqual( warnings, [ {
`'path' is imported by main.js, but could not be resolved – treating it as an external dependency. For help see https://github.com/rollup/rollup/wiki/Troubleshooting#treating-module-as-external-dependency` code: 'UNRESOLVED_IMPORT',
]); message: `'path' is imported by main.js, but could not be resolved – treating it as an external dependency`,
}, url: `https://github.com/rollup/rollup/wiki/Troubleshooting#treating-module-as-external-dependency`
}
],
exports: function ( exports ) { exports: function ( exports ) {
assert.strictEqual( exports.path, require( 'path' ) ); assert.strictEqual( exports.path, require( 'path' ) );
} }

12
test/function/does-not-hang-on-missing-module/_config.js

@ -2,11 +2,13 @@ var assert = require( 'assert' );
module.exports = { module.exports = {
description: 'does not hang on missing module (#53)', description: 'does not hang on missing module (#53)',
warnings: warnings => { warnings: [
assert.deepEqual( warnings, [ {
`'unlessYouCreatedThisFileForSomeReason' is imported by main.js, but could not be resolved – treating it as an external dependency. For help see https://github.com/rollup/rollup/wiki/Troubleshooting#treating-module-as-external-dependency` code: 'UNRESOLVED_IMPORT',
]); message: `'unlessYouCreatedThisFileForSomeReason' is imported by main.js, but could not be resolved – treating it as an external dependency`,
}, url: `https://github.com/rollup/rollup/wiki/Troubleshooting#treating-module-as-external-dependency`
}
],
runtimeError: function ( error ) { runtimeError: function ( error ) {
assert.equal( "Cannot find module 'unlessYouCreatedThisFileForSomeReason'", error.message ); assert.equal( "Cannot find module 'unlessYouCreatedThisFileForSomeReason'", error.message );
} }

13
test/function/double-named-export-from/_config.js

@ -1,13 +0,0 @@
const { resolve } = require('path');
const assert = require( 'assert' );
const r = path => resolve( __dirname, path );
module.exports = {
description: 'throws on duplicate export * from',
warnings ( warnings ) {
assert.deepEqual( warnings, [
`Conflicting namespaces: ${r('main.js')} re-exports 'foo' from both ${r('foo.js')} (will be ignored) and ${r('deep.js')}.`
]);
}
};

27
test/function/empty-exports/_config.js

@ -1,12 +1,23 @@
const assert = require( 'assert' );
const path = require( 'path' );
module.exports = { module.exports = {
description: 'warns on export {}, but does not fail', description: 'warns on export {}, but does not fail',
warnings: warnings => { warnings: [
assert.deepEqual( warnings, [ {
`Module ${path.resolve( __dirname, 'main.js' )} has an empty export declaration`, code: 'EMPTY_EXPORT',
'Generated an empty bundle' message: 'Empty export declaration',
]); pos: 0,
loc: {
file: require( 'path' ).resolve( __dirname, 'main.js' ),
line: 1,
column: 0
},
frame: `
1: export {};
^
`
},
{
code: 'EMPTY_BUNDLE',
message: 'Generated an empty bundle'
} }
]
}; };

9
test/function/module-tree/_config.js

@ -34,9 +34,10 @@ module.exports = {
} }
]); ]);
}, },
warnings: warnings => { warnings: [
assert.deepEqual( warnings, [ {
'Generated an empty bundle' code: 'EMPTY_BUNDLE',
]); message: 'Generated an empty bundle'
} }
]
}; };

24
test/function/namespace-missing-export/_config.js

@ -1,9 +1,21 @@
var assert = require( 'assert' );
module.exports = { module.exports = {
options: { warnings: [
onwarn: function ( msg ) { {
assert.equal( msg, `main.js (3:21) 'foo' is not exported by 'empty.js'. See https://github.com/rollup/rollup/wiki/Troubleshooting#name-is-not-exported-by-module` ); code: 'MISSING_EXPORT',
} message: `'foo' is not exported by 'empty.js'`,
pos: 61,
loc: {
file: require( 'path' ).resolve( __dirname, 'main.js' ),
line: 3,
column: 25
},
frame: `
1: import * as mod from './empty.js';
2:
3: assert.equal( typeof mod.foo, 'undefined' );
^
`,
url: `https://github.com/rollup/rollup/wiki/Troubleshooting#name-is-not-exported-by-module`
} }
]
}; };

20
test/function/unused-import/_config.js

@ -2,11 +2,19 @@ const assert = require( 'assert' );
module.exports = { module.exports = {
description: 'warns on unused imports ([#595])', description: 'warns on unused imports ([#595])',
warnings: warnings => { warnings: [
assert.deepEqual( warnings, [ {
`'external' is imported by main.js, but could not be resolved – treating it as an external dependency. For help see https://github.com/rollup/rollup/wiki/Troubleshooting#treating-module-as-external-dependency`, code: 'UNRESOLVED_IMPORT',
`'unused', 'notused' and 'neverused' are imported from external module 'external' but never used`, message: `'external' is imported by main.js, but could not be resolved – treating it as an external dependency`,
`Generated an empty bundle` url: `https://github.com/rollup/rollup/wiki/Troubleshooting#treating-module-as-external-dependency`
]); },
{
code: 'UNUSED_EXTERNAL_IMPORT',
message: `'unused', 'notused' and 'neverused' are imported from external module 'external' but never used`
},
{
code: 'EMPTY_BUNDLE',
message: `Generated an empty bundle`
} }
]
}; };

22
test/function/warn-on-ambiguous-function-export/_config.js

@ -2,9 +2,23 @@ const assert = require( 'assert' );
module.exports = { module.exports = {
description: 'uses original name of default export function (#1011)', description: 'uses original name of default export function (#1011)',
warnings: warnings => { warnings: [
assert.deepEqual( warnings, [ {
'foo.js (1:15) Ambiguous default export (is a call expression, but looks like a function declaration). See https://github.com/rollup/rollup/wiki/Troubleshooting#ambiguous-default-export' code: 'AMBIGUOUS_DEFAULT_EXPORT',
]); message: `Ambiguous default export (is a call expression, but looks like a function declaration)`,
pos: 15,
loc: {
file: require( 'path' ).resolve( __dirname, 'foo.js' ),
line: 1,
column: 15
},
frame: `
1: export default function foo ( a, b ) {
^
2: assert.equal( a, b );
3: return 3;
`,
url: `https://github.com/rollup/rollup/wiki/Troubleshooting#ambiguous-default-export`
} }
]
}; };

12
test/function/warn-on-auto-named-default-exports/_config.js

@ -1,10 +1,10 @@
var assert = require( 'assert' );
module.exports = { module.exports = {
description: 'warns if default and named exports are used in auto mode', description: 'warns if default and named exports are used in auto mode',
warnings: function ( warnings ) { warnings: [
assert.deepEqual( warnings, [ {
'Using named and default exports together. Consumers of your bundle will have to use bundle[\'default\'] to access the default export, which may not be what you want. Use `exports: \'named\'` to disable this warning. See https://github.com/rollup/rollup/wiki/JavaScript-API#exports for more information' code: 'MIXED_EXPORTS',
]); message: `Using named and default exports together. Consumers of your bundle will have to use bundle['default'] to access the default export, which may not be what you want. Use \`exports: 'named'\` to disable this warning`,
url: `https://github.com/rollup/rollup/wiki/JavaScript-API#exports`
} }
]
}; };

11
test/function/warn-on-empty-bundle/_config.js

@ -1,10 +1,9 @@
const assert = require( 'assert' );
module.exports = { module.exports = {
description: 'warns if empty bundle is generated (#444)', description: 'warns if empty bundle is generated (#444)',
warnings: warnings => { warnings: [
assert.deepEqual( warnings, [ {
'Generated an empty bundle' code: 'EMPTY_BUNDLE',
]); message: 'Generated an empty bundle'
} }
]
}; };

6
test/function/warn-on-eval/_config.js

@ -8,8 +8,12 @@ module.exports = {
loc: { loc: {
column: 13, column: 13,
file: require( 'path' ).resolve( __dirname, 'main.js' ), file: require( 'path' ).resolve( __dirname, 'main.js' ),
line: 2 line: 1
}, },
frame: `
1: var result = eval( '1 + 1' );
^
`,
url: 'https://github.com/rollup/rollup/wiki/Troubleshooting#avoiding-eval' url: 'https://github.com/rollup/rollup/wiki/Troubleshooting#avoiding-eval'
} }
] ]

9
test/function/warn-on-namespace-conflict/_config.js

@ -0,0 +1,9 @@
module.exports = {
description: 'warns on duplicate export * from',
warnings: [
{
code: 'NAMESPACE_CONFLICT',
message: `Conflicting namespaces: main.js re-exports 'foo' from both foo.js (will be ignored) and deep.js`
}
]
};

0
test/function/double-named-export-from/bar.js → test/function/warn-on-namespace-conflict/bar.js

0
test/function/double-named-export-from/deep.js → test/function/warn-on-namespace-conflict/deep.js

0
test/function/double-named-export-from/foo.js → test/function/warn-on-namespace-conflict/foo.js

0
test/function/double-named-export-from/main.js → test/function/warn-on-namespace-conflict/main.js

22
test/function/warn-on-top-level-this/_config.js

@ -2,11 +2,25 @@ const assert = require( 'assert' );
module.exports = { module.exports = {
description: 'warns on top-level this (#770)', description: 'warns on top-level this (#770)',
warnings: warnings => { warnings: [
assert.deepEqual( warnings, [ {
`main.js (3:1) The 'this' keyword is equivalent to 'undefined' at the top level of an ES module, and has been rewritten. See https://github.com/rollup/rollup/wiki/Troubleshooting#this-is-undefined for more information` code: 'THIS_IS_UNDEFINED',
]); message: `The 'this' keyword is equivalent to 'undefined' at the top level of an ES module, and has been rewritten`,
pos: 81,
loc: {
file: require( 'path' ).resolve( __dirname, 'main.js' ),
line: 3,
column: 0
}, },
frame: `
1: const someVariableJustToCheckOnCorrectLineNumber = true; // eslint-disable-line
2:
3: this.foo = 'bar';
^
`,
url: `https://github.com/rollup/rollup/wiki/Troubleshooting#this-is-undefined`
}
],
runtimeError: err => { runtimeError: err => {
assert.equal( err.message, `Cannot set property 'foo' of undefined` ); assert.equal( err.message, `Cannot set property 'foo' of undefined` );
} }

21
test/function/warn-on-unused-missing-imports/_config.js

@ -3,9 +3,22 @@ const assert = require( 'assert' );
module.exports = { module.exports = {
description: 'warns on missing (but unused) imports', description: 'warns on missing (but unused) imports',
warnings: warnings => { warnings: [
assert.deepEqual( warnings, [ {
`Non-existent export 'b' is imported from ${path.resolve(__dirname, 'foo.js')} by ${path.resolve(__dirname, 'main.js')}` code: 'NON_EXISTENT_EXPORT',
]); message: `Non-existent export 'b' is imported from foo.js`,
pos: 12,
loc: {
file: path.resolve( __dirname, 'main.js' ),
line: 1,
column: 12
},
frame: `
1: import { a, b } from './foo.js';
^
2:
3: assert.equal( a, 42 );
`
} }
]
}; };

20
test/sourcemaps/transform-without-sourcemap/_config.js

@ -1,10 +1,5 @@
const assert = require( 'assert' );
let warnings = [];
module.exports = { module.exports = {
description: 'preserves sourcemap chains when transforming', description: 'preserves sourcemap chains when transforming',
before: () => warnings = [], // reset
options: { options: {
plugins: [ plugins: [
{ {
@ -13,14 +8,13 @@ module.exports = {
return code; return code;
} }
} }
], ]
onwarn ( msg ) {
warnings.push( msg );
}
}, },
test: () => { warnings: [
assert.deepEqual( warnings, [ {
`Sourcemap is likely to be incorrect: a plugin ('fake plugin') was used to transform files, but didn't generate a sourcemap for the transformation. Consult https://github.com/rollup/rollup/wiki/Troubleshooting and the plugin documentation for more information` code: `SOURCEMAP_BROKEN`,
]); message: `Sourcemap is likely to be incorrect: a plugin ('fake plugin') was used to transform files, but didn't generate a sourcemap for the transformation. Consult the plugin documentation for help`,
url: `https://github.com/rollup/rollup/wiki/Troubleshooting#sourcemap-is-likely-to-be-incorrect`
} }
]
}; };

59
test/test.js

@ -58,6 +58,27 @@ function loader ( modules ) {
}; };
} }
function compareWarnings ( actual, expected ) {
assert.deepEqual(
actual.map( warning => {
const clone = Object.assign( {}, warning );
delete clone.toString;
if ( clone.frame ) {
clone.frame = clone.frame.replace( /\s+$/gm, '' );
}
return clone;
}),
expected.map( warning => {
if ( warning.frame ) {
warning.frame = warning.frame.slice( 1 ).replace( /^\t+/gm, '' ).replace( /\s+$/gm, '' ).trim();
}
return warning;
})
);
}
describe( 'rollup', function () { describe( 'rollup', function () {
this.timeout( 10000 ); this.timeout( 10000 );
@ -271,13 +292,7 @@ describe( 'rollup', function () {
if ( config.warnings ) { if ( config.warnings ) {
if ( Array.isArray( config.warnings ) ) { if ( Array.isArray( config.warnings ) ) {
assert.deepEqual( warnings.map( warning => { compareWarnings( warnings, config.warnings );
const clone = Object.assign( {}, warning );
delete clone.toString;
delete clone.frame;
return clone;
}), config.warnings );
} else { } else {
config.warnings( warnings ); config.warnings( warnings );
} }
@ -387,11 +402,18 @@ describe( 'rollup', function () {
const entry = path.resolve( SOURCEMAPS, dir, 'main.js' ); const entry = path.resolve( SOURCEMAPS, dir, 'main.js' );
const dest = path.resolve( SOURCEMAPS, dir, '_actual/bundle' ); const dest = path.resolve( SOURCEMAPS, dir, '_actual/bundle' );
const options = extend( {}, config.options, { entry }); let warnings;
const options = extend( {}, config.options, {
entry,
onwarn: warning => warnings.push( warning )
});
PROFILES.forEach( profile => { PROFILES.forEach( profile => {
( config.skip ? it.skip : config.solo ? it.only : it )( 'generates ' + profile.format, () => { ( config.skip ? it.skip : config.solo ? it.only : it )( 'generates ' + profile.format, () => {
process.chdir( SOURCEMAPS + '/' + dir ); process.chdir( SOURCEMAPS + '/' + dir );
warnings = [];
return rollup.rollup( options ).then( bundle => { return rollup.rollup( options ).then( bundle => {
const options = extend( {}, { const options = extend( {}, {
format: profile.format, format: profile.format,
@ -401,9 +423,16 @@ describe( 'rollup', function () {
bundle.write( options ); bundle.write( options );
if ( config.before ) config.before(); if ( config.test ) {
const result = bundle.generate( options ); const { code, map } = bundle.generate( options );
config.test( result.code, result.map ); config.test( code, map );
}
if ( config.warnings ) {
compareWarnings( warnings, config.warnings );
} else if ( warnings.length ) {
throw new Error( `Unexpected warnings` );
}
}); });
}); });
}); });
@ -747,11 +776,9 @@ describe( 'rollup', function () {
moduleName: 'myBundle' moduleName: 'myBundle'
}); });
assert.deepEqual( warnings, [ const relevantWarnings = warnings.filter( warning => warning.code === 'MISSING_NODE_BUILTINS' );
`'util' is imported by entry, but could not be resolved – treating it as an external dependency. For help see https://github.com/rollup/rollup/wiki/Troubleshooting#treating-module-as-external-dependency`, assert.equal( relevantWarnings.length, 1 );
`Creating a browser bundle that depends on Node.js built-in module ('util'). You might need to include https://www.npmjs.com/package/rollup-plugin-node-builtins`, assert.equal( relevantWarnings[0].message, `Creating a browser bundle that depends on Node.js built-in module ('util'). You might need to include https://www.npmjs.com/package/rollup-plugin-node-builtins` );
`No name was provided for external module 'util' in options.globals – guessing 'util'`
]);
}); });
}); });
}); });

Loading…
Cancel
Save