Skip to content

commonjs: hoists conditionally require()'d ESM side effects #1177

@privatenumber

Description

@privatenumber

Input

index.js

if (process.env.NODE_ENV === 'production') {
	require('./prod.js');
}

prod.js

console.log('side effect');

export default 'production';

Output

var src = {};

console.log('side effect');

if (process.env.NODE_ENV === 'production') ;

export { src as default };

Expected Behavior

For the console.log('side effect'); to be delayed until the if-condition passes.

Note, this only happens because prod.js is an ESM file. If the export ... is removed for it to be interpreted as a CJS file, it will compile expectedly:

var src = {};

var prod = {};

var hasRequiredProd;

function requireProd () {
	if (hasRequiredProd) return prod;
	hasRequiredProd = 1;
	console.log('side effect');

	// export default 'production';
	return prod;
}

if (process.env.NODE_ENV === 'production') {
	requireProd();
}

export { src as default };

Actual Behavior

The side effects of the ESM file are hoisted up and executed even if the if-condition doesn't pass.

Additional Information

Metadata

Metadata

Assignees

No one assigned

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions