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>
我應該怎樣來檢查按鈕實際上是渲染?