codeceptjs / CodeceptJS

Supercharged End 2 End Testing Framework for NodeJS
http://codecept.io
MIT License
4.09k stars 718 forks source link

Migrate CodeceptJS to ESM (Top-level await) #4185

Open danielhelen opened 6 months ago

danielhelen commented 6 months ago

What are you trying to achieve?

I need to use top-level await to retrieve config from AWS and other APIs but CodeceptJS seems completely incompatible with ES modules. Top-level await is simply not possible in CommonJS. Are there any plans to support ES modules?

What do you get instead?

If you set "type": "module" in package.json you get this error:

Error [ERR_REQUIRE_ESM]: require() of ES Module /Users/REDACTED/config/codecept.conf.js from /Users/REDACTED/node_modules/codeceptjs/lib/config.js not supported.
Instead change the require of codecept.conf.js in /Users/REDACTED/node_modules/codeceptjs/lib/config.js to a dynamic import() which is available in all CommonJS modules.
    at loadConfigFile (/Users/REDACTED/node_modules/codeceptjs/lib/config.js:160:26)
    at Config.load (/Users/REDACTED/node_modules/codeceptjs/lib/config.js:91:14)
    at module.exports.getConfig (/Users/REDACTED/node_modules/codeceptjs/lib/command/utils.js:14:33)
    at module.exports (/Users/REDACTED/node_modules/codeceptjs/lib/command/run.js:18:16)
    at Command.<anonymous> (/Users/REDACTED/node_modules/codeceptjs/bin/codecept.js:9:11)

Details

DavertMik commented 6 months ago

@danielhelen at this moment this means to rewrite CodeceptJS completely and I don't think we have enough resources to handle this task.

DavertMik commented 6 months ago

Actually we can try this codemod, which can make migration faster

https://github.com/azu/commonjs-to-es-module-codemod

DavertMik commented 4 months ago

4229 We are working on it!

github-actions[bot] commented 1 month ago

This issue is stale because it has been open for 90 days with no activity.

kaashan commented 2 days ago

Do we have any target date for https://github.com/codeceptjs/CodeceptJS/pull/4229 ?