File tree 2 files changed +26
-0
lines changed
2 files changed +26
-0
lines changed Original file line number Diff line number Diff line change @@ -24,6 +24,10 @@ function shouldUseESMLoader(mainPath) {
24
24
const userLoader = getOptionValue ( '--experimental-loader' ) ;
25
25
if ( userLoader )
26
26
return true ;
27
+ const esModuleSpecifierResolution =
28
+ getOptionValue ( '--es-module-specifier-resolution' ) ;
29
+ if ( esModuleSpecifierResolution === 'node' )
30
+ return true ;
27
31
// Determine the module format of the main
28
32
if ( mainPath && mainPath . endsWith ( '.mjs' ) )
29
33
return true ;
Original file line number Diff line number Diff line change 1
1
// Flags: --es-module-specifier-resolution=node
2
2
import { mustNotCall } from '../common/index.mjs' ;
3
3
import assert from 'assert' ;
4
+ import path from 'path' ;
5
+ import { spawn } from 'child_process' ;
6
+ import { fileURLToPath } from 'url' ;
4
7
5
8
// commonJS index.js
6
9
import commonjs from '../fixtures/es-module-specifiers/package-type-commonjs' ;
@@ -33,3 +36,22 @@ async function main() {
33
36
}
34
37
35
38
main ( ) . catch ( mustNotCall ) ;
39
+
40
+ // Test path from command line arguments
41
+ [
42
+ 'package-type-commonjs' ,
43
+ 'package-type-module' ,
44
+ '/' ,
45
+ '/index' ,
46
+ ] . forEach ( ( item ) => {
47
+ const modulePath = path . join (
48
+ fileURLToPath ( import . meta. url ) ,
49
+ '../../fixtures/es-module-specifiers' ,
50
+ item ,
51
+ ) ;
52
+ spawn ( process . execPath ,
53
+ [ '--es-module-specifier-resolution=node' , modulePath ] ,
54
+ { stdio : 'inherit' } ) . on ( 'exit' , ( code ) => {
55
+ assert . strictEqual ( code , 0 ) ;
56
+ } ) ;
57
+ } ) ;
You can’t perform that action at this time.
0 commit comments