测试组件在使用酶传递某个属性值时不呈现
Test that a component does not render when passed a certain prop value with enzyme
我想测试我的 LoadingIndicator 组件是否在状态 属性 设置为 FETCHING 时加载到 DOM 中,并且在就绪时不加载。现在我有这个:
import React from 'react';
import { assert } from 'chai';
import { shallow, mount } from 'enzyme';
import LoadingIndicator from '../../src/components/LoadingIndicator';
import { STATUSES } from '../../src/reducers/status';
describe('LoadingIndicator', () => {
it('should render when the status is FETCHING', () => {
const wrapper = shallow(<LoadingIndicator status={STATUSES.FETCHING} />);
assert.ok(wrapper);
});
it('should not render when the status is READY', () => {
const wrapper = mount(<LoadingIndicator status={STATUSES.READY} />);
assert.isNotOkay(wrapper);
});
});
组件本身如下所示:
import React, { PropTypes } from 'react';
import CircularProgress from 'material-ui/CircularProgress';
import { STATUSES } from '../reducers/status';
import '../styles/LoadingIndicator.scss';
export default class LoadingIndicator extends React.Component {
render() {
return (
this.props.status === STATUSES.READY ? null :
<div className="loader-div">
<CircularProgress className="loader" />
</div>
);
}
}
LoadingIndicator.propTypes = {
status: PropTypes.string.isRequired,
};
这似乎不是检查它是否呈现的正确方法,但我明白了
1) LoadingIndicator should not render when the status is READY:
AssertionError: expected { Object (component, root, ...) } to be falsy
知道如何根据给定的 属性 正确测试此组件是否加载吗?
谢谢。
您可以查看 The Component Lifecycle。
特别是 shouldComponentUpdate()
.
由此,您可以简单地添加
shouldComponentUpdate(nextProps, nextState) {
if (...) {
return true;
}
else {
return false;
}
}
决定是否渲染这个组件。
你好,最后我自己解决了这个问题。我应该考虑这样一个事实,因为我正在进行浅层渲染,所以我可以只查看 div 是否渲染,所以我最终得到:
import React from 'react';
import { expect } from 'chai';
import { shallow } from 'enzyme';
import LoadingIndicator from '../../src/components/LoadingIndicator';
import { STATUSES } from '../../src/reducers/status';
describe('LoadingIndicator', () => {
it('should render when the status is FETCHING', () => {
const wrapper = shallow(<LoadingIndicator status={STATUSES.FETCHING} />);
expect(wrapper.find('div')).to.have.length(1);
});
it('should not render when the status is READY', () => {
const wrapper = shallow(<LoadingIndicator status={STATUSES.READY} />);
expect(wrapper.find('div')).to.have.length(0);
});
});
并且有效(对两者都进行了 positive/negative 测试)。
我想测试我的 LoadingIndicator 组件是否在状态 属性 设置为 FETCHING 时加载到 DOM 中,并且在就绪时不加载。现在我有这个:
import React from 'react';
import { assert } from 'chai';
import { shallow, mount } from 'enzyme';
import LoadingIndicator from '../../src/components/LoadingIndicator';
import { STATUSES } from '../../src/reducers/status';
describe('LoadingIndicator', () => {
it('should render when the status is FETCHING', () => {
const wrapper = shallow(<LoadingIndicator status={STATUSES.FETCHING} />);
assert.ok(wrapper);
});
it('should not render when the status is READY', () => {
const wrapper = mount(<LoadingIndicator status={STATUSES.READY} />);
assert.isNotOkay(wrapper);
});
});
组件本身如下所示:
import React, { PropTypes } from 'react';
import CircularProgress from 'material-ui/CircularProgress';
import { STATUSES } from '../reducers/status';
import '../styles/LoadingIndicator.scss';
export default class LoadingIndicator extends React.Component {
render() {
return (
this.props.status === STATUSES.READY ? null :
<div className="loader-div">
<CircularProgress className="loader" />
</div>
);
}
}
LoadingIndicator.propTypes = {
status: PropTypes.string.isRequired,
};
这似乎不是检查它是否呈现的正确方法,但我明白了
1) LoadingIndicator should not render when the status is READY:
AssertionError: expected { Object (component, root, ...) } to be falsy
知道如何根据给定的 属性 正确测试此组件是否加载吗?
谢谢。
您可以查看 The Component Lifecycle。
特别是 shouldComponentUpdate()
.
由此,您可以简单地添加
shouldComponentUpdate(nextProps, nextState) {
if (...) {
return true;
}
else {
return false;
}
}
决定是否渲染这个组件。
你好,最后我自己解决了这个问题。我应该考虑这样一个事实,因为我正在进行浅层渲染,所以我可以只查看 div 是否渲染,所以我最终得到:
import React from 'react';
import { expect } from 'chai';
import { shallow } from 'enzyme';
import LoadingIndicator from '../../src/components/LoadingIndicator';
import { STATUSES } from '../../src/reducers/status';
describe('LoadingIndicator', () => {
it('should render when the status is FETCHING', () => {
const wrapper = shallow(<LoadingIndicator status={STATUSES.FETCHING} />);
expect(wrapper.find('div')).to.have.length(1);
});
it('should not render when the status is READY', () => {
const wrapper = shallow(<LoadingIndicator status={STATUSES.READY} />);
expect(wrapper.find('div')).to.have.length(0);
});
});
并且有效(对两者都进行了 positive/negative 测试)。