В одном из моих проектов, React-Instagram-Clone-2.0 , я добавил функцию, позволяющую пользователям добавлять других пользователей в избранное.
У меня есть тест, которыйимитирует событие нажатия кнопки, которая отправляет запрос POST и добавляет пользователя в избранное.Но он не достигает сервера и тест всегда проходит.
Вот код.
Add-to-favourites.js
const AddToFavourites = ({ user, username }) => {
let add = e => {
e.preventDefault()
addToFavourites(user) // util function
new d('.af_btn').blur()
}
return (
<div>
<div className='recomm_teaser'>
<span>Wanna add {username} to your favourites list.</span>
<SecondaryButton
label='Add'
onClick={add}
/>
</div>
</div>
)
}
функция addToFavourites
export const addToFavourites = async user => {
let {
data: { success, mssg }
} = await post('/api/add-to-favourites', { user }) // POST request
if (success) {
insta_notify({
to: user,
type: 'favourites'
})
}
console.log('Test debugging') // Never logged
// But I remove the request, The above message is logged out.
Notify({ value: mssg })
}
И мой тестовый файл
describe('AddToFavourites Component', () => {
const comp = (
<AddToFavourites
user={7}
username='ghalib'
/>
)
it('should match snapshot', () => {
const tree = create(comp).toJSON()
expect(tree).toMatchSnapshot()
})
it('should add user to favs when clicked', () => {
const wrapper = mount(comp)
wrapper.find('SecondaryButton').simulate(
'click',
{ preventDefault() {} }
)
expect(true).toBe(true)
})
})
Любое решение?
Thnx взаранее:)