Skip to content

Commit

Permalink
Fix implementation function context
Browse files Browse the repository at this point in the history
  • Loading branch information
3y3k0 committed Oct 20, 2022
1 parent 781bfce commit d849ccb
Show file tree
Hide file tree
Showing 2 changed files with 57 additions and 8 deletions.
17 changes: 9 additions & 8 deletions src/when.js
Original file line number Diff line number Diff line change
Expand Up @@ -84,9 +84,10 @@ class WhenMock {

this.nextCallMockId++

this.fn.mockImplementation((...args) => {
for (let i = 0; i < this.callMocks.length; i++) {
const { matchers, mockImplementation, expectCall, once, called } = this.callMocks[i]
const instance = this
this.fn.mockImplementation(function (...args) {
for (let i = 0; i < instance.callMocks.length; i++) {
const { matchers, mockImplementation, expectCall, once, called } = instance.callMocks[i]

// Do not let a once mock match more than once
if (once && called) continue
Expand All @@ -110,16 +111,16 @@ class WhenMock {
}

if (isMatch && typeof mockImplementation === 'function') {
this.callMocks[i].called = true
return mockImplementation(...args)
instance.callMocks[i].called = true
return mockImplementation.call(this, ...args)
}
}

if (this._defaultImplementation) {
return this._defaultImplementation(...args)
if (instance._defaultImplementation) {
return instance._defaultImplementation.call(this, ...args)
}
if (typeof fn.__whenMock__._origMock === 'function') {
return fn.__whenMock__._origMock(...args)
return fn.__whenMock__._origMock.call(this, ...args)
}
return undefined
})
Expand Down
48 changes: 48 additions & 0 deletions src/when.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -1025,6 +1025,54 @@ describe('When', () => {
expect(fn(2)).toEqual('b')
})

it('keeps call context when not matched', () => {
class TheClass {
call () {
return 'ok'
}

request (...args) {
return this.call(...args)
}
}

const theInstance = new TheClass()

const theSpiedMethod = jest.spyOn(theInstance, 'request')

when(theSpiedMethod)
.calledWith(1)
.mockReturnValue('mock')

const unhandledCall = theInstance.request()
expect(unhandledCall).toBe('ok')
})

it('keeps call context when matched', () => {
class TheClass {
call () {
return 'ok'
}

request (...args) {
return this.call(...args)
}
}

const theInstance = new TheClass()

const theSpiedMethod = jest.spyOn(theInstance, 'request')

when(theSpiedMethod)
.calledWith(1)
.mockImplementation(function () {
return this.call() + '!'
})

const unhandledCall = theInstance.request(1)
expect(unhandledCall).toBe('ok!')
})

it('does not add to the number of assertion calls', () => {
expect.assertions(0)
})
Expand Down

0 comments on commit d849ccb

Please sign in to comment.