Я пытаюсь написать несколько интеграционных тестов в своем приложении.
У меня есть пара API-вызовов, которые вызываются для componentDidMount и при нажатии кнопки. Ответ API сохраняется в Store, что обновляет представление.
Как проверить эту интеграцию с API?
Это мой код WIP:
let wrapped
const options = {
disableLifecycleMethods: true
}
const mockPlanet = {
name: "Yavin IV",
climate: "temperate, tropical",
terrain: "jungle, rainforests",
population: "1000",
films: ["A New Hope"],
url: "https://swapi.co/api/planets/3/"
}
const initialPlanet = {
name: "Alderaan",
climate: "temperate",
terrain: "grasslands, mountains",
population: "2000000000",
films: ["A New Hope", "Revenge of the Sith"],
url: "https://swapi.co/api/planets/2/"
}
const mockStore = configureMockStore([thunk])
const store = mockStore({
planets:{
planetCount: 1,
activePlanet: initialPlanet,
planetCache: [],
loading: false,
error: null
}
})
const address = /https:\/\/swapi.co\/api\/planets/[0-9]/
beforeEach(()=>{
moxios.install()
moxios.stubRequest(
address,
{
status: 200,
response: mockPlanet
}
)
})
afterEach(()=>{
moxios.uninstall()
})
it('Fetch planet on click',()=>{
wrapped = mount(
<Provider store={store}>
<App/>
</Provider>, options
)
wrapped.find('.button-get-planet').first().simulate('click')
wrapped.update()
// What should I test here?
})
Заранее спасибо.