You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
It correctly notices that the strings are not the same, good. But as soon as I remove the toString and test with:
test('via deep equal',()=>{expect(getIncorrectParams()).not.to.deep.equal(newURLSearchParams({from: '2020',to: '2021',ids: ['abc-1','abc-2'],}));});
It claims that the assertion failed because the two objects are "equal". Note if you actually go ahead and run the example, the debug output clearly shows that there are differences!
And the deep.equal property works if I use "normal" object. See this example where I convert the URLSearchParams to a "plain object" first:
Hey @Elias-Graf; this is probably an issue with https://github.com/chaijs/deep-eql. I think it doesn't account for URLSearchParams. Investigating the issue in chai and then making a PR to fix the issue either in chai or deep-eql is your best bet. We are open to pull requests and are really happy to have new contributors to chai.
@koddsson Hi! I see if I can take some time to dive into this. Most of the time it's relatively difficult to dive into an existing project. The thing is that as far as I know, everything in JavaScript is an object. So I always assumed everything could be compared in the same way. Note that I'm talking about equality, not comparing pointers.
Also, can I like move this issue to the correct repository? Or is that not a thing?.
I'm trying to test if my
URLSearchParams
are correct with theto.deep.equal
option but it returnstrue
(is equal) when it shouldn't.See the running code at https://stackblitz.com/edit/node-qx7qra?file=index.test.js
Let's assume that we're testing this function:
If I write:
It correctly notices that the strings are not the same, good. But as soon as I remove the
toString
and test with:It claims that the assertion failed because the two objects are "equal". Note if you actually go ahead and run the example, the debug output clearly shows that there are differences!
And the
deep.equal
property works if I use "normal" object. See this example where I convert theURLSearchParams
to a "plain object" first:The text was updated successfully, but these errors were encountered: