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

Другие вопросы по тегам