-
Notifications
You must be signed in to change notification settings - Fork 792
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
feat: Support ES modules in jest tests #3230
Comments
Hey @johncrim 👋 I agree that Stencil should support ES Modules when using Jest. To be honest, I had not been considering this support until Jest's ESM support came out of it's 'experimental' phase. But if you're interested, I say go for it! |
Thanks @rwaskiewicz . I certainly understand waiting until the experimental phase ends - I can't fault you for that, though I don't know how long it will remain in experimental. It's working acceptably with ts-jest and jest + angular (though still a little bumpy). I just migrated our angular jest tests to Jest ESM and would like to tackle this as long as it's not too involved (from a code review it looks pretty straightforward, but I could certainly be wrong about that). |
Hi @rwaskiewicz - I have a working PR that works great for our projects. Lmk when you have time to review. |
Hey @johncrim - I haven't forgotten about this, I'll circle back as soon as I get a chance |
any updates on this? |
Hi @rwaskiewicz - the PR may be outdated (I don't know what has changed since I created it), but would be great to get either my PR merged, or this fixed some other way. |
Agreed - I've done a little work internally to make Jest easier to upgrade (and easier to change things like ESM support). I'm hoping to move to the prototyping stage later this week, from there I hope to be able to be in a better place to determine how we can work with this PR |
I'm blocked by this situation because one of my component use swiper available only as esm in last version and it make fail the related spec test.
Current workaround, add a transform option in jest config to transform concerned modules from ESM to CommonJS using |
The old workaround of editing the jest config doesn't work since stencil 2.14.0 when jest's config file sterted to be ignored (per: #3251) so fixing this is pretty important since there's no workaround anymore. |
this adjustment would be very important for the project I've been developing! |
any news? we also need the es modules working in tests.
now add to stencil.config.ts
so that has an effect, but subsequent imports are now failing. transformIgnorePatterns: ['node_modules/(?!(wired-elements|lit-element|lit-html|lit|@lit|@lit/reactive-element)/)'], So there is currently no workaround for this right now. This is reproducable with a lot of libraries e.g. ibm carbon and our own library, too. |
I provided a PR for this in Feb 2022, but it never went anywhere... |
@rwaskiewicz Very interested in seeing this resolved, too. I just spent a week porting one of our web components to Stencil (which was a huge improvement), and was very surprised to learn that I can't actually port the tests over to Stencil, because the component has an ESM dependency. If there's anything I can do to help land @johncrim 's PR (perhaps a rebase), or otherwise assist in getting this fixed, I volunteer my time. Please advise? |
@ryuran Hello! I have the same problem using stencil@2.22.3 and swiper@11.0.5. I've tried all the solutions I've found, but none of them work, can you share your config code for this? |
Any updates on this, should be quite important ? |
@pfteter we have been de-prioritizing Stencils Jest integration and worked on better alternatives, e.g. via WebdriverIO or Playwright. At this point I can't tell when this will be picked up. Maintaining this Jest integration adds a lot of work to the team with little value in return. In an ideal world we would want to have users use Jest directly and ESM should work out of the box. I may look into this in one of our next Jedi days. |
@pfteter with the release of Jest v30 we will be working on a Jest preset plugin (e.g. |
This comment was marked as spam.
This comment was marked as spam.
Please don't comment with "any updates on this", especially not until Jest v30 actually has been released that would allow to make progress on this. In general I would recommend to use a better test runner for testing Stencil components. There are two great alternatives in Playwright and WebdriverIO that allow you to load ESM modules. |
Prerequisites
Describe the Feature Request
Stencil tests should be able to run using Jest ES Module support, instead of transpiling all ESM modules to CJS. This needs to be done to improve test perf, and because ESM is preferred in all modern projects that are used in browsers.
Right now, stencil jest support hard-codes CJS output: https://github.com/ionic-team/stencil/blob/main/src/testing/test-transpile.ts
Describe the Use Case
When I run stencil tests, I should have the option to run them in Jest ESM mode.
The lack of this feature causes bugs and wasted dev effort, eg: #2178
Performance should be improved b/c .mjs files (most dependencies) will no longer need to be transpiled. Dev cycle speed is important!
In addition, there are behavioral differences between CJS and ESM, and it's valuable for the test environment to be as similar as possible to the runtime environment.
Describe Preferred Solution
A config option exists for running tests in Jest ESM mode.
Describe Alternatives
No response
Related Code
No response
Additional Information
https://kulshekhar.github.io/ts-jest/docs/next/guides/esm-support/
Related issues:
I'm willing to work on a PR for this - looks like it shouldn't be too hard.
The text was updated successfully, but these errors were encountered: