Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

chore: add sample on how to use esm on cjs #14051

Merged
merged 3 commits into from
Nov 20, 2024

Conversation

micalevisk
Copy link
Member

@micalevisk micalevisk commented Oct 1, 2024

PR Checklist

Please check if your PR fulfills the following requirements:

PR Type

What kind of change does this PR introduce?

  • Bugfix
  • Feature
  • Code style update (formatting, local variables)
  • Refactoring (no functional changes, no api changes)
  • Build related changes
  • CI related changes
  • Other... Please describe:

What is the current behavior?

no examples on how to use ESM-only packages with nestjs (CJS apps), although not directly related with nestjs

What is the new behavior?

this is a first stage to address the issue nestjs/docs.nestjs.com#3093

After creating that new page, I'll mention about these samples as an working examples on three ways to use ESM-only packages in our CJS projects: importing the package when needed or declaring it like a custom provider, or using the --experimental-require-module nodejs flag

About the sample 35: I'm not sure on keeping a dedicate sample because it is just a matter of using a nodejs flag. And we can mention this in the docs. This flag has few gotchas tho (see https://nodejs.medium.com/announcing-a-new-experimental-modules-1be8d2d6c2ff)

Does this PR introduce a breaking change?

  • Yes
  • No

@micalevisk micalevisk force-pushed the add-esm-only-sample branch from 9ef810c to 0dafaaa Compare October 1, 2024 13:35
@coveralls
Copy link

coveralls commented Oct 1, 2024

Pull Request Test Coverage Report for Build 1234f075-0323-42b7-ac03-dae6b0f0b280

Details

  • 0 of 0 changed or added relevant lines in 0 files are covered.
  • 61 unchanged lines in 6 files lost coverage.
  • Overall coverage decreased (-0.03%) to 92.213%

Files with Coverage Reduction New Missed Lines %
packages/common/pipes/validation.pipe.ts 1 94.34%
packages/core/inspector/initialize-on-preview.allowlist.ts 1 75.0%
packages/core/injector/instance-wrapper.ts 4 97.45%
packages/core/injector/internal-core-module/internal-core-module-factory.ts 4 80.0%
packages/microservices/client/client-rmq.ts 14 78.63%
packages/core/injector/injector.ts 37 84.64%
Totals Coverage Status
Change from base Build c625c4c5-c2c4-4cba-9396-4b71158fc068: -0.03%
Covered Lines: 6750
Relevant Lines: 7320

💛 - Coveralls

@micalevisk
Copy link
Member Author

micalevisk commented Oct 1, 2024

CI is failing because it's using node16 while the new sample will only work on node18 because of Jest ESM support:

image

not sure what I can do as we do want to test against node16 as well to ensure that nestjs is still compatible with it I guess. I'll see if could ignore that sample when nodejs version is 16

@Apidcloud
Copy link

Would it be possible to make this work for nestjs + swc as well?

@micalevisk micalevisk marked this pull request as draft October 4, 2024 00:15
@micalevisk
Copy link
Member Author

@Apidcloud it's just the same as sample 34 or 35. I just tested it.

@micalevisk micalevisk marked this pull request as ready for review October 27, 2024 20:39
@Apidcloud
Copy link

I remember that my issue a couple of weeks ago with SWC was the dynamic imports (i.e., the node require module experimental flag also worked for me).

But from the example you provided, is this the way to make it work with a dynamic import instead of relying on the experimental flag? They already unflagged it on Node 23 and might backport it to Node 22 on a minor, so it's not a big deal, I guess.

/**
 * This is the same as `import()` expression that is supposed to load ESM packages while
 * preventing TypeScript from transpiling the import statement into `require()`.
 */
export const importEsmPackage = async <ReturnType>(
  packageName: string,
): Promise<ReturnType> =>
  new Function(`return import('${packageName}')`)().then(
    (loadedModule: unknown) => loadedModule['default'] ?? loadedModule,
  );

@micalevisk
Copy link
Member Author

@Apidcloud from what I tested, yes. Having a function like importEsmPackage is the only way due to how the typescript project is configured.

@kamilmysliwiec kamilmysliwiec merged commit 439516d into nestjs:master Nov 20, 2024
5 checks passed
@kamilmysliwiec
Copy link
Member

LGTM

@micalevisk micalevisk deleted the add-esm-only-sample branch November 20, 2024 11:28
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants