Skip to content

Commit

Permalink
Merge branch 'main' of https://github.com/tr1ckydev/jest
Browse files Browse the repository at this point in the history
  • Loading branch information
tr1ckydev committed Nov 2, 2023
2 parents 745eaf9 + 4598475 commit ae12c6c
Show file tree
Hide file tree
Showing 3 changed files with 57 additions and 7 deletions.
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@
- `[jest-circus, jest-expect, jest-snapshot]` Pass `test.failing` tests when containing failing snapshot matchers ([#14313](https://github.com/jestjs/jest/pull/14313))
- `[jest-config]` Make sure to respect `runInBand` option ([#14578](https://github.com/facebook/jest/pull/14578))
- `[@jest/expect-utils]` Fix comparison of `DataView` ([#14408](https://github.com/jestjs/jest/pull/14408))
- `[@jest/expect-utils]` [**BREAKING**] exclude non-enumerable in object matching ([#14670](https://github.com/jestjs/jest/pull/14670))
- `[@jest/expect-utils]` Fix comparison of `URL` ([#14672](https://github.com/jestjs/jest/pull/14672))
- `[jest-leak-detector]` Make leak-detector more aggressive when running GC ([#14526](https://github.com/jestjs/jest/pull/14526))
- `[jest-runtime]` Properly handle re-exported native modules in ESM via CJS ([#14589](https://github.com/jestjs/jest/pull/14589))
Expand Down
45 changes: 45 additions & 0 deletions packages/expect-utils/src/__tests__/utils.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -356,6 +356,51 @@ describe('subsetEquality()', () => {
).toBe(false);
});
});

describe('matching subsets with symbols', () => {
describe('same symbol', () => {
test('objects to not match with value diff', () => {
const symbol = Symbol('foo');
expect(subsetEquality({[symbol]: 1}, {[symbol]: 2})).toBe(false);
});

test('objects to match with non-enumerable symbols', () => {
const symbol = Symbol('foo');
const foo = {};
Object.defineProperty(foo, symbol, {
enumerable: false,
value: 1,
});
const bar = {};
Object.defineProperty(bar, symbol, {
enumerable: false,
value: 2,
});
expect(subsetEquality(foo, bar)).toBe(true);
});
});

describe('different symbol', () => {
test('objects to not match with same value', () => {
expect(subsetEquality({[Symbol('foo')]: 1}, {[Symbol('foo')]: 2})).toBe(
false,
);
});
test('objects to match with non-enumerable symbols', () => {
const foo = {};
Object.defineProperty(foo, Symbol('foo'), {
enumerable: false,
value: 1,
});
const bar = {};
Object.defineProperty(bar, Symbol('foo'), {
enumerable: false,
value: 2,
});
expect(subsetEquality(foo, bar)).toBe(true);
});
});
});
});

describe('iterableEquality', () => {
Expand Down
18 changes: 11 additions & 7 deletions packages/expect-utils/src/utils.ts
Original file line number Diff line number Diff line change
Expand Up @@ -44,13 +44,17 @@ const hasPropertyInObject = (object: object, key: string | symbol): boolean => {
};

// Retrieves an object's keys for evaluation by getObjectSubset. This evaluates
// the prototype chain for string keys but not for symbols. (Otherwise, it
// could find values such as a Set or Map's Symbol.toStringTag, with unexpected
// results.)
export const getObjectKeys = (object: object): Array<string | symbol> => [
...Object.keys(object),
...Object.getOwnPropertySymbols(object),
];
// the prototype chain for string keys but not for non-enumerable symbols.
// (Otherwise, it could find values such as a Set or Map's Symbol.toStringTag,
// with unexpected results.)
export const getObjectKeys = (object: object): Array<string | symbol> => {
return [
...Object.keys(object),
...Object.getOwnPropertySymbols(object).filter(
s => Object.getOwnPropertyDescriptor(object, s)?.enumerable,
),
];
};

export const getPath = (
object: Record<string, any>,
Expand Down

0 comments on commit ae12c6c

Please sign in to comment.