Итак, я пытался узнать о тестировании в React, и у меня есть это: Button.js
и Button.test.js
Вопрос комментируется вместе с кодом ниже:
// Button.js
import React from 'react';
import { string, bool, func } from 'prop-types';
import { StyledButton } from './styled'
const Button = ({
size,
text,
}) => (
<StyledButton
size={size}
// the test will alway fail with result:
// Expected value to be: "Join us"
// Received: undefined
// Unless I add add this line below
text={text}
>
{text} // but the text props is here. That is my current practice of passing the props to the children, am I missing anything?
</StyledButton>
);
Button.propTypes = {
size: string,
text: string,
};
Button.defaultProps = {
size: '',
text: '',
};
export default Button;
// Button.test.js
import React from 'react';
import { shallow } from 'enzyme';
import Button from '../../components/Button/Button';
describe('Component: Button', () => {
const minProps = {
text: '',
size: '',
};
it('renders a button in size of "small" with text in it', () => {
const wrapper = shallow(
<Button {...minProps} size="small" text="Join us" />
);
expect(wrapper.prop('size')).toBe('small');
expect(wrapper.prop('text')).toBe('Join us');
});
});
// StyledButton
import Button from 'antd/lib/button';
const StyledButton = styled(Button)`
&.ant-btn {
padding: 0 24px;
${({ size }) => {
if (size === 'small') {
return css`
font-size: 14px;
line-height: 32px;
`;
}
return null;
}};
`;
export { StyledButton };
Кто-нибудь знает, почему тест не пройдет, если я не передам реквизиты на StyledButton
?