Я, похоже, не могу понять это. Я использую приложение create-react-app, и он встроен в тестовый runner Jest. Для всего синхронного кода это работает очень хорошо, но, когда насмехаются обещания, я не могу заставить его работать.Тестирование React Async with Jest и create-react-app
Реактивный компонент имеет форму, в которой я могу моделировать подачу.
Восстановить фрагменты кода компонента.
//Top of the page
import {auth} from '../../lib/API_V2'
// ... //
// Handle submit runs when the form is submitted
handleSubmit = (event) => {
console.log('submit')
event.preventDefault()
this.setState(prevState => ({
...prevState,
loading: true
}))
console.log('stateSet')
auth(this.state.userName, this.state.password)
.then(results => {
// NEVER RUNS
console.log('then')
// stuff omitted
this.setState(prevState => ({
...prevState,
loading: false
}))
this.props.afterAuth()
})
.catch(() => {
// also never runs
// omitted
this.setState(prevState => ({
...prevState,
loading: false
}))
this.props.afterAuth()
})
}
Код испытания
jest.mock('../../lib/API_V2')
it.only(`should mock a login`,() => {
const myMock = jest.fn()
const authComp = mount(<AuthComponent afterAuth={myMock}/>)
authComp.find('.userName').simulate('change', {target: {value: 'userName'}})
authComp.find('.password').simulate('change', {target: {value: 'password'}})
expect(authComp.state().userName).toEqual('userName')
expect(authComp.state().password).toEqual('password')
authComp.find('[type="submit"]').get(0).click()
expect(myMock.mock.calls.length).toBe(1) // FAILS
})
В API Lib возвращает обещание. Вместо этого у меня есть __mocks__/API_V2.js
рядом с ним. Это выглядит так:
function auth (lastname, accountNumber) {
console.log('yay!?')
return new Promise((resolve) => {
resolve({
accountNumber,
lastName: lastname
})
})
}
Мой тестовый код никогда не запускается. Если я вхожу в фальшивую функцию, я получаю function auth() {return mockConstructor.apply(this,arguments);}
Я попытался выполнить инструкции https://facebook.github.io/jest/docs/tutorial-async.html, но кажется, что мои макетные методы не вызываются. И ни один из них не является реальным методом. Вместо этого мой вызов auth()
возвращает неопределенный.
У кого-нибудь есть идеи?
- Дополнительная информация -
src
Components
AuthComponent
AuthComponent.js
AuthComponent.test.js
index.js
Lib
API_V2
API_V2.js
index.js
__mocks__
API_V2.js
Я закончил вручную насмешливый его вместо того, чтобы использовать каталог __mocks__. jest.mock ('../../ lib/API_V2,() => {auth: function ...}) – TheMcMurder