testing
testing copied to clipboard
`jest-dom` added additional condition to `toBeVisible` preventing use in component test.
I'm submitting a bug report
- Library Version: 1.1.0
Please tell us about your environment:
-
Operating System: Windows 11
-
Node Version: 16.5.0
-
NPM Version: 7.20.0
-
JSPM OR Webpack AND Version webpack: 5.72.1
-
Browser: jest component test
-
Language: typescript
Current behavior:
We recently updated our dependencies and it looks like jest-dom changed the behaviour of toBeVisible
and added a new condition in v5.11.10
so all versions since then (2021-03-25) have the same issue:
it is present in the document
This is causing our component tests to fail with an exception, when we locate an element from the component and try to asset that it is visible.
data:image/s3,"s3://crabby-images/8eac4/8eac4f7def63d5d904bb8968d1244bc038628157" alt="image"
I am assuming this can be fixed somehow by a change in the aurelia-testing package.
Expected/desired behavior: it should not fail or throw an exception
-
What is the expected behavior?
-
What is the motivation / use case for changing the behavior? the jest-dom package has added an extra condition to its
toBeVisible
method.
@bigopon does this make sense to you? is there any way to fix this from the aurelia plugin?
you can see from the code here, the elements are supposed to be in the document if they are resolved from waitForDocumentElement
https://github.com/aurelia/testing/blob/2c4bdea2112b6daa3e97f4b5ab922dd55b62f129/src/wait.ts#L53
Can you check again?
you can see from the code here, the elements are supposed to be in the document if they are resolved from
waitForDocumentElement
https://github.com/aurelia/testing/blob/2c4bdea2112b6daa3e97f4b5ab922dd55b62f129/src/wait.ts#L53Can you check again?
If you look at the screenshot, waitForDocumentElement
is what it is failing on, I have run the test multiple times, when I revert the version of jest-dom
to an earlier version it works, it's only since they added the extra condition that it fails.
toBeVisible
implementation calls getRootNode()
which blows up saying it's not a function, I was thinking this would need to attach something to make it work.
@bigopon I did some digging and found a issue, it looks like this is how it was fixed for vue-test-utils
testing package.
They can mount the component to the document body within the testing framework, can you add something similar to aurelia-testing
? here is the source code for mount in vue-test-utils
:
https://github.com/vuejs/vue-test-utils/blob/3cd81d0593f56034b96f368d8ab066a855e0b204/packages/test-utils/src/mount.js
As you can see from this line https://github.com/aurelia/testing/blob/2c4bdea2112b6daa3e97f4b5ab922dd55b62f129/src/component-tester.ts#L72
All tests attach their root node to the document. So it's unlikely that the issue is in this package. Maybe your jsdom
dep is old, and doesn't have getRootNode()
implemented, if so, maybe upgrade jsdom?
it looks like jsdom first introduced getRootNode
in version 11.11.0
, however in my package lock I see this:
data:image/s3,"s3://crabby-images/56313/56313a8b0fae5712fa5cdf2c025c439c40f3d9bd" alt="image"
data:image/s3,"s3://crabby-images/84e70/84e709c7f053e34235db0177c786e0ac8be39eea" alt="image"
it looks like theaurelia-pal-nodejs
(which we don't directly reference) depends on an old version of jsdom
which doesn't support getRootNode
.
it looks like aurelia-pal-nodejs
is a dependency of aurelia-store
and we do reference that.
@bigopon I have opened a ticket with jest-dom
as its likely something they should deal with.
https://github.com/testing-library/jest-dom/issues/458
@bigopon I just realise we use a jest-pretest.ts
file which adds some DOM polyfils for node:
import "aurelia-polyfills";
import { Options } from "aurelia-loader-nodejs";
import { globalize } from "aurelia-pal-nodejs";
Options.relativeToDir = "app";
globalize();
I had a look at aurelia-pal-nodejs
and found this
shouldn't the getRootNode
polyfill be included here?
or is that abstraction just for the things that aurelia needs?
That could possibly be the case. Maybe it should. Can you try add that in your local node_modules
and see if the error goes away?