Модульное тестирование: Ошибка: TypeError: Невозможно прочитать свойство 'displayName' из неопределенного - PullRequest
0 голосов
/ 26 декабря 2018

Тест обновлен.Возможность сделать некоторые другие тесты, используя тот же формат.Это то, что у меня есть. Headers.test.js

import React, {Component} from 'react';
import   {Headers}  from './Headers';
import {configure} from 'enzyme';
import Adapter from 'enzyme-adapter-react-15';
import  renderer from 'react-test-renderer';

configure({adapter: new Adapter()});

describe('Headers', () => {

let tree;
let baseProps;
let mockauthKeyValues;
let mockheaderKeyValues;       
let mockaddNewKeyValue;

beforeEach(() => {
    baseProps = { // assing all of the props into MOCK
       authKeyValues: mockauthKeyValues,
       headerKeyValues: mockheaderKeyValues,
       addNewKeyValue: mockaddNewKeyValue
    }
})

 it('should render with all of the props', () => {  
    tree = renderer.create(<Headers {...baseProps} />)
    let treeJson = tree.toJSON()
    expect(treeJson).toMatchSnapshot();
    tree.unmount()
  });
});

Я буду тестировать каждый реквизит и проверять, что он рендерится без него.Я считаю, что я делаю по ошибке, когда я высмеиваю все это. Реквизит.Особенно mockheaderKeyValues.Я не думаю, что я настраиваю правильно.

Это текущий код: headers.js

export class Headers extends Component {

 componentDidMount () {
if (this.props.authKeyValues == null) {
  this.setState({
    useDefaultData: false
  })
} else {
  this.setState({
    useDefaultData: true
  })
}
 }

generateKeyValues = () => {
if (this.props.headerKeyValues == null) {
  return (
    <KeyValue
      id={shortid.generate()}
      type='headers'
      addNewKeyValue={this.props.addNewKeyValue}
    />
  )
} else {
  let defaultKeyValues = Object.keys(this.props.headerKeyValues).map   ((headerKey, idx) => {
    return (
      <KeyValue
        key={headerKey}
        id={headerKey}
        type={this.props.headerKeyValues[headerKey].type}
        addNewKeyValue={this.props.addNewKeyValue}
        defaultData={this.props.headerKeyValues[headerKey]}
      />
    )
  })
  defaultKeyValues.push(
    <KeyValue
      id={shortid.generate()}
      type='headers'
      addNewKeyValue={this.props.addNewKeyValue}
    />
  )
  return defaultKeyValues
 }
 }

 render () {
 return (
  <div>
    {this.generateKeyValues()}
  </div>
)

}}

1 Ответ

0 голосов
/ 25 января 2019

Обнаружена проблема - пришлось удалить {} из импорта {Заголовки}, так как Заголовки импортируют еще 2 файла, поэтому он импортировался неправильно

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...