From 368899a656aeba5a7b76b24f9f6cbf7c99e754e2 Mon Sep 17 00:00:00 2001 From: Toru Kobayashi Date: Mon, 16 Oct 2017 22:57:31 +0900 Subject: [PATCH] Support an object property function --- .../enzyme-test-suite/test/Utils-spec.jsx | 30 +++++++++++++------ packages/enzyme/src/Utils.js | 16 +++++++--- 2 files changed, 33 insertions(+), 13 deletions(-) diff --git a/packages/enzyme-test-suite/test/Utils-spec.jsx b/packages/enzyme-test-suite/test/Utils-spec.jsx index d10c5aaa3..74fda90b3 100644 --- a/packages/enzyme-test-suite/test/Utils-spec.jsx +++ b/packages/enzyme-test-suite/test/Utils-spec.jsx @@ -555,15 +555,27 @@ describe('Utils', () => { return this.count; } } - const counter = new Counter(); - const original = counter.incrementAndGet; - const spy = spyMethod(counter, 'incrementAndGet'); - counter.incrementAndGet(); - counter.incrementAndGet(); - expect(spy.lastReturnValue).to.equal(3); - spy.restore(); - expect(counter.incrementAndGet).to.equal(original); - expect(counter.incrementAndGet()).to.equal(4); + const instance = new Counter(); + const obj = { + count: 1, + incrementAndGet() { + this.count = this.count + 1; + return this.count; + }, + }; + + // test an instance method and an object property function + const targets = [instance, obj]; + targets.forEach((target) => { + const original = target.incrementAndGet; + const spy = spyMethod(target, 'incrementAndGet'); + target.incrementAndGet(); + target.incrementAndGet(); + expect(spy.lastReturnValue).to.equal(3); + spy.restore(); + expect(target.incrementAndGet).to.equal(original); + expect(target.incrementAndGet()).to.equal(4); + }); }); }); }); diff --git a/packages/enzyme/src/Utils.js b/packages/enzyme/src/Utils.js index 259edee19..37b6d965c 100644 --- a/packages/enzyme/src/Utils.js +++ b/packages/enzyme/src/Utils.js @@ -269,20 +269,28 @@ export function cloneElement(adapter, el, props) { export function spyMethod(instance, methodName) { let lastReturnValue; + const originalMethod = instance[methodName]; + const hasOwn = Object.hasOwnProperty.call(instance, methodName); Object.defineProperty(instance, methodName, { configurable: true, enumerable: false, value(...args) { - const result = this.constructor.prototype[methodName].apply(this, args); + const result = originalMethod.apply(this, args); lastReturnValue = result; return result; }, }); return { restore() { - /* eslint-disable no-param-reassign */ - delete instance[methodName]; - /* eslint-enable no-param-reassign */ + if (hasOwn) { + /* eslint-disable no-param-reassign */ + instance[methodName] = originalMethod; + /* eslint-enable no-param-reassign */ + } else { + /* eslint-disable no-param-reassign */ + delete instance[methodName]; + /* eslint-enable no-param-reassign */ + } }, get lastReturnValue() { return lastReturnValue;