diff --git a/CHANGELOG.md b/CHANGELOG.md index 37cecfbc8229..4b0673350512 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -4,6 +4,8 @@ ### Fixes +- `[expect]` Match symbols and bigints in `any()`; stop matching `null` ([#10223](https://github.com/facebook/jest/pull/10223)) + ### Chore & Maintenance ### Performance diff --git a/packages/expect/src/__tests__/asymmetricMatchers.test.ts b/packages/expect/src/__tests__/asymmetricMatchers.test.ts index b45e4c23d0b4..7e8b29e11939 100644 --- a/packages/expect/src/__tests__/asymmetricMatchers.test.ts +++ b/packages/expect/src/__tests__/asymmetricMatchers.test.ts @@ -29,7 +29,11 @@ test('Any.asymmetricMatch()', () => { any(Number).asymmetricMatch(1), any(Function).asymmetricMatch(() => {}), any(Boolean).asymmetricMatch(true), + /* global BigInt */ + any(BigInt).asymmetricMatch(1n), + any(Symbol).asymmetricMatch(Symbol()), any(Object).asymmetricMatch({}), + !any(Object).asymmetricMatch(null), any(Array).asymmetricMatch([]), any(Thing).asymmetricMatch(new Thing()), ].forEach(test => { diff --git a/packages/expect/src/asymmetricMatchers.ts b/packages/expect/src/asymmetricMatchers.ts index fa7293e0eaaa..196493db455f 100644 --- a/packages/expect/src/asymmetricMatchers.ts +++ b/packages/expect/src/asymmetricMatchers.ts @@ -46,13 +46,22 @@ class Any extends AsymmetricMatcher { } if (this.sample == Object) { - return typeof other == 'object'; + return typeof other == 'object' && other !== null; } if (this.sample == Boolean) { return typeof other == 'boolean'; } + /* global BigInt */ + if (this.sample == BigInt) { + return typeof other == 'bigint'; + } + + if (this.sample == Symbol) { + return typeof other == 'symbol'; + } + return other instanceof this.sample; }