2016-11-25 33 views
0

我有以下部件:無法獲得孩子的反應測試

GenericButton:

render() { 
    return(
     <span> 
      <Button ... props... /> 
      {this.renderModalIfNeeded()} 
     </span>); 

} 

renderModalIfNeeded() { 
    if (this.props.modalConfirm) { 
     return <BasicModal ref={(component) => this.modal = component} 
          title="Confirm" 
          body={this.props.modalText} 
          buttons={[ 
             { 
              id: "Cancel_"+this.props.id, 
              text : 'Cancel', 
              style : 'grey' 
             }, 
             { 
              id: "Confirm"+this.props.id, 
              text : 'OK', 
              action :() => this.props.action() 
             } 
            ]}/>; 
    } 

} 

BasicModal:

renderButtons() { 
    return this.props.buttons 
        .map((button) => { 
         const previousAction = button.action; 
         button.action =() => { 
          if (previousAction) { 
           previousAction(); 
          } 
          this.close(); 
         }; 
         return button; 
        }) 
        .map((button, count) => <GenericButton key={"Button_"+count+"_"+this.props.id} {...button} />); 
} 

render() { 
     return (
      <Modal show={this.state.showModal} onHide={::this.close}> 
       <Modal.Header closeButton> 
        <Modal.Title>{this.props.title}</Modal.Title> 
       </Modal.Header> 
       <Modal.Body> 
        {this.props.body} 
       </Modal.Body> 
       <Modal.Footer> 
        {this.renderButtons()} 
       </Modal.Footer> 
      </Modal> 
     ); 
    } 

我有這樣的試驗,其中我是試圖驗證模式中的按鈕是否正確顯示(this.renderButtons()中的按鈕)

describe('Given modal requirements',() => { 
      const text = "Ne me mori facias"; 
      const id = "Generosa"; 
      const innerModal = mount(<GenericButton id={id} modalConfirm={true} modalText={text}/>).find('BasicModal').first(); 
      it('has two buttons',() => { 
       const cancelButton = <GenericButton id={"Cancel_"+id} text="Cancel" style="grey"/>; 
       const okButton = <GenericButton id={"Confirm_"+id} text="OK" action={() => {}} />; 

       const extractModalBody = (modal) => { 
        return modal.find('BasicModal').first().find('Modal'); 
       }; 
       expect(extractModalBody(innerModal)).toContainReact(cancelButton); 
       expect(extractModalBody(innerModal)).toContainReact(okButton); 
      }); 
     }); 

如果測試我嘗試使用.debug()我去檢查BasicModal組件的內容如下內:

<BasicModal title="Confirm" body="Ne me mori facias" buttons={{...}}> 
    <Modal show={false} onHide={[Function]}> 
    <Modal show={false} onHide={[Function]} backdrop={true} keyboard={true} autoFocus={true} enforceFocus={true} manager={{...}} renderBackdrop={[Function]} animation={true} dialogComponentClass={[Function]} bsClass="modal"> 
     <Modal onHide={[Function]} keyboard={true} autoFocus={true} enforceFocus={true} manager={{...}} renderBackdrop={[Function]} show={false} onEntering={[Function]} onExited={[Function]} backdrop={true} backdropClassName="modal-backdrop" containerClassName="modal-open" transition={[Function]} dialogTransitionTimeout={300} backdropTransitionTimeout={150} /> 
    </Modal> 
    </Modal> 
</BasicModal> 

我應該怎樣來檢查按鈕實際上是渲染?

回答

0

嘗試使用.render()它返回一個cheerio來渲染一個陣營組件DOM ..

https://github.com/airbnb/enzyme/blob/master/docs/api/ReactWrapper/render.md

在文檔

.render() => CheerioWrapper 

返回圍繞當前的HTML渲染一個CheerioWrapper 節點的子樹。

注意:只能在單個節點的包裝上調用。

返回

字符串:將得到的HTML字符串

實施例:

const wrapper = mount(<Bar />); 
expect(wrapper.find(Foo).render().find('.in-foo')).to.have.length(1);