From 7eeacae56c3ee4c17aa602a36706c1b72119565c Mon Sep 17 00:00:00 2001 From: BenceSzalai Date: Tue, 14 Mar 2023 17:00:37 +0100 Subject: [PATCH] fix: compare value of inherited getter on test failure (#10167) --- .../__tests__/deepCyclicCopyReplaceable.test.ts | 14 +++++++++++++- .../src/deepCyclicCopyReplaceable.ts | 8 +++++--- 2 files changed, 18 insertions(+), 4 deletions(-) diff --git a/packages/jest-matcher-utils/src/__tests__/deepCyclicCopyReplaceable.test.ts b/packages/jest-matcher-utils/src/__tests__/deepCyclicCopyReplaceable.test.ts index 6a017b694103..e63b680a8c75 100644 --- a/packages/jest-matcher-utils/src/__tests__/deepCyclicCopyReplaceable.test.ts +++ b/packages/jest-matcher-utils/src/__tests__/deepCyclicCopyReplaceable.test.ts @@ -43,7 +43,7 @@ test('convert accessor descriptor into value descriptor', () => { }); }); -test('should not skips non-enumerables', () => { +test('should not skip non-enumerables', () => { const obj = {}; Object.defineProperty(obj, 'foo', {enumerable: false, value: 'bar'}); @@ -66,6 +66,18 @@ test('copies symbols', () => { expect(deepCyclicCopyReplaceable(obj)[symbol]).toBe(42); }); +test('copies value of inherited getters', () => { + class Foo { + #foo = 42; + get foo() { + return this.#foo; + } + } + const obj = new Foo(); + + expect(deepCyclicCopyReplaceable(obj).foo).toBe(42); +}); + test('copies arrays as array objects', () => { const array = [null, 42, 'foo', 'bar', [], {}]; diff --git a/packages/jest-matcher-utils/src/deepCyclicCopyReplaceable.ts b/packages/jest-matcher-utils/src/deepCyclicCopyReplaceable.ts index 8c7c520c2168..cd72d2cc7adc 100644 --- a/packages/jest-matcher-utils/src/deepCyclicCopyReplaceable.ts +++ b/packages/jest-matcher-utils/src/deepCyclicCopyReplaceable.ts @@ -57,9 +57,11 @@ export default function deepCyclicCopyReplaceable( function deepCyclicCopyObject(object: T, cycles: WeakMap): T { const newObject = Object.create(Object.getPrototypeOf(object)); - const descriptors: { - [x: string]: PropertyDescriptor; - } = Object.getOwnPropertyDescriptors(object); + let descriptors: Record = {}; + let obj = object; + do { + descriptors = Object.assign({}, Object.getOwnPropertyDescriptors(obj), descriptors) + } while ( (obj = Object.getPrototypeOf( obj )) && obj !== Object.getPrototypeOf({}) ); cycles.set(object, newObject);