TypeError: предоставленное значение не относится к типу Element при тестировании моментального снимка с помощью дополнений React, Storybook и Storyshots.
Я получаю сообщение об ошибке при тестировании моего
IndeterminateCheckbox
компонент ниже:
import { Checkbox } from '@chakra-ui/core';
import React from 'react';
export interface IndeterminateCheckboxProps {
indeterminate: boolean;
checked: boolean;
title: string;
onChange: () => void;
}
const IndeterminateCheckbox = React.forwardRef(
(
{ indeterminate, checked, title, onChange }: IndeterminateCheckboxProps,
forwardedRef: any
): JSX.Element => {
return (
<Checkbox
colorScheme="brand.blue"
isIndeterminate={indeterminate}
isChecked={checked}
onChange={onChange}
name={title}
sx={{ mt: '4px', borderColor: 'brand.grey.100' }}
/>
);
}
);
export default IndeterminateCheckbox;
Я тестирую снимок с помощью аддона Storyshots со следующей историей:
/* eslint-disable react/jsx-props-no-spreading */
import React from 'react';
import { Meta, Story } from '@storybook/react/types-6-0';
import IndeterminateCheckbox, {
IndeterminateCheckboxProps,
} from './IndeterminateCheckbox';
export default {
title: 'IndeterminateCheckbox',
component: IndeterminateCheckbox,
argTypes: {
indeterminate: {
control: {
type: 'boolean',
},
},
checked: {
control: {
type: 'boolean',
},
},
title: {
control: {
type: 'string',
},
},
},
} as Meta;
const Template: Story<IndeterminateCheckboxProps> = args => (
<IndeterminateCheckbox {...args} />
);
export const Unchecked = Template.bind({});
Unchecked.args = {
indeterminate: false,
title: 'unchecked',
checked: false,
onChange: () => null,
};
export const Checked = Template.bind({});
Checked.args = {
indeterminate: false,
title: 'checked',
checked: true,
onChange: () => null,
};
export const Indeterminate = Template.bind({});
Indeterminate.args = {
indeterminate: true,
title: 'indeterminate',
checked: false,
onChange: () => null,
};
есть идеи, что может быть причиной этого?
1 ответ
Вы должны обновить конфигурацию storyshots для поддержки элементов, которым переданы ссылки:
react-test-renderer не предоставляет ссылки для визуализированных компонентов. По умолчанию он возвращает null, когда ссылаются на ссылки. Чтобы имитировать элементы, которые полагаются на ссылки, вам нужно будет использовать опцию createNodeMock, добавленную в React, начиная с версии 15.4.0.https://www.npmjs.com/package/@storybook/addon-storyshots#using-createnodemock-to-mock-refs