Я использую Jest и Enzyme для тестирования компонентов React, но я столкнулся с трудностями при тестировании простого компонента без сохранения состояния, который состоит из результата функции javascript карты.
MovieCard.js Компонент:
import React from 'react'
import PropTypes from 'prop-types'
const MovieCard = ({ resultsForSubmit }) =>
(
resultsForSubmit.map(r => (
<article className="card" key={r.imdbID}>
<a href={r.Poster}>
<picture className="thumbnail">
<img src={(r.Poster !== "N/A")? r.Poster : "src/assets/not-found.png"} alt={r.Title} />
</picture>
</a>
<div className="card-content clearfix">
<div className="review">
<h2>{r.Title}</h2>
<p>{r.Type}</p>
</div>
<div className="reviewer">
</div>
</div>
</article>
)
)
)
export default MovieCard;
MovieCard.propTypes = {
resultsForSubmit: PropTypes.array,
}
MovieCard.test.js
import React from 'react'
import { mount } from 'enzyme'
import MovieCard from './MovieCard';
describe('<MovieCard /><MovieCard />', () => {
const data = [
{ imdbId: '2', Poster: 'poster2', Title: 'title2', Type: 'type2' }
];
it('renders 2 <MovieCard /> components', () => {
mount(<MovieCard data={ data } />);
});
})
прия запускаю тест, эта ошибка отображается:
**<MovieCard /><MovieCard /> › renders 2 <MovieCard /> components
TypeError: Cannot read property 'map' of undefined
4 | const MovieCard = ({ resultsForSubmit }) =>
5 | (
> 6 | resultsForSubmit.map(r => (
| ^
7 | <article className="card" key={r.imdbID}>
8 | <a href={r.Poster}>
9 | <picture className="thumbnail">**
Пока я просто хочу проверить, отображается ли компонент, но я открыт для предложения использовать другие функции тестирования на нем.