rsuite
Version:
A suite of react components
191 lines (159 loc) • 5.6 kB
JavaScript
import React from 'react';
import ReactTestUtils from 'react-dom/test-utils';
import { findDOMNode } from 'react-dom';
import Cascader from '../Cascader';
import Button from '../../Button';
import { getDOMNode, getInstance } from '@test/testUtils';
const items = [
{
value: 'abc',
label: 'abc'
},
{
value: 'abcd',
label: 'abcd'
},
{
value: 'abcde',
label: 'abcde',
children: [
{
value: 'vv-abc',
label: 'vv-abc'
},
{
value: 'vv-abcd',
label: 'vv-abcd'
}
]
}
];
describe('Cascader', () => {
it('Should output a dropdown', () => {
const Title = 'Title';
const instance = getDOMNode(<Cascader>{Title}</Cascader>);
assert.ok(instance.className.match(/\bpicker-cascader\b/));
});
it('Should be disabled', () => {
const instance = getDOMNode(<Cascader disabled />);
assert.ok(instance.className.match(/\bdisabled\b/));
});
it('Should output a placeholder', () => {
const placeholder = 'foobar';
const instance = getDOMNode(<Cascader placeholder={placeholder} />);
assert.equal(instance.querySelector('.rs-picker-toggle-placeholder').innerText, placeholder);
});
it('Should output a button', () => {
const instance = getInstance(<Cascader toggleComponentClass="button" />);
assert.ok(ReactTestUtils.findRenderedDOMComponentWithTag(instance, 'button'));
});
it('Should be block', () => {
const instance = getDOMNode(<Cascader block />);
assert.ok(instance.className.match(/\bblock\b/));
});
it('Should output a placeholder by renderValue()', () => {
const placeholder = 'foobar';
const instance = getDOMNode(
<Cascader renderValue={() => placeholder} data={items} value={'abc'} />
);
assert.equal(instance.querySelector('.rs-picker-toggle-value').innerText, placeholder);
const instance2 = getDOMNode(<Cascader renderValue={() => placeholder} />);
assert.equal(instance2.querySelector('.rs-picker-toggle-placeholder').innerText, 'Select');
});
it('Should be active by value', () => {
const value = 'abcd';
const instance = getInstance(<Cascader defaultOpen data={items} value={value} />);
const menu = findDOMNode(instance.menuContainerRef.current);
assert.equal(menu.querySelector('.rs-picker-cascader-menu-item-active').innerText, value);
});
it('Should be active by defaultValue', () => {
const value = 'abcd';
const instance = getInstance(<Cascader defaultOpen data={items} defaultValue={value} />);
const menu = findDOMNode(instance.menuContainerRef.current);
assert.equal(menu.querySelector('.rs-picker-cascader-menu-item-active').innerText, value);
});
it('Should call onSelect callback ', done => {
const doneOp = node => {
if (node.value === 'abcd') {
done();
}
};
const instance = getInstance(<Cascader data={items} defaultOpen onSelect={doneOp} />);
const menu = findDOMNode(instance.menuContainerRef.current);
ReactTestUtils.Simulate.click(menu.querySelectorAll('.rs-picker-cascader-menu-item')[1]);
});
it('Should call onChange callback ', done => {
const doneOp = value => {
if (value === 'abcd') {
done();
}
};
const instance = getInstance(<Cascader data={items} defaultOpen onChange={doneOp} />);
const menu = findDOMNode(instance.menuContainerRef.current);
ReactTestUtils.Simulate.click(menu.querySelectorAll('.rs-picker-cascader-menu-item')[1]);
});
it('Should call onClean callback', done => {
const doneOp = () => {
done();
};
const instance = getDOMNode(
<Cascader data={items} defaultValue={['vv-abc']} onClean={doneOp} />
);
ReactTestUtils.Simulate.click(instance.querySelector('.rs-picker-toggle-clean'));
});
it('Should call `onOpen` callback', done => {
const doneOp = key => {
done();
};
let picker = null;
getDOMNode(
<Cascader
ref={ref => {
picker = ref;
}}
onOpen={doneOp}
data={items}
/>
);
picker.open();
});
it('Should call `onClose` callback', done => {
const doneOp = key => {
done();
};
let picker = null;
getDOMNode(
<Cascader
defaultOpen
ref={ref => {
picker = ref;
}}
onClose={doneOp}
data={items}
/>
);
picker.close();
});
it('Should clean selected default value', () => {
const instance = getDOMNode(<Cascader defaultOpen data={items} defaultValue={['vv-abc']} />);
ReactTestUtils.Simulate.click(instance.querySelector('.rs-picker-toggle-clean'));
expect(instance.querySelector('.rs-picker-toggle-placeholder').innerText).to.equal('Select');
});
it('Should have a custom className', () => {
const instance = getDOMNode(<Cascader className="custom" />);
assert.ok(instance.className.match(/\bcustom\b/));
});
it('Should have a custom style', () => {
const fontSize = '12px';
const instance = getDOMNode(<Cascader style={{ fontSize }} />);
assert.equal(instance.style.fontSize, fontSize);
});
it('Should have a custom className prefix', () => {
const instance = getDOMNode(<Cascader classPrefix="custom-prefix" />);
assert.ok(instance.className.match(/\bcustom-prefix\b/));
});
it('Should render a button by toggleComponentClass={Button}', () => {
const instance = getInstance(<Cascader open data={items} toggleComponentClass={Button} />);
ReactTestUtils.findRenderedDOMComponentWithClass(instance, 'rs-btn');
});
});