diff options
Diffstat (limited to 'spec')
-rw-r--r-- | spec/javascript/components/features/ui/components/column.test.jsx | 30 |
1 files changed, 30 insertions, 0 deletions
diff --git a/spec/javascript/components/features/ui/components/column.test.jsx b/spec/javascript/components/features/ui/components/column.test.jsx new file mode 100644 index 000000000..b7e257757 --- /dev/null +++ b/spec/javascript/components/features/ui/components/column.test.jsx @@ -0,0 +1,30 @@ +import { expect } from 'chai'; +import { mount } from 'enzyme'; +import sinon from 'sinon'; + +import Column from '../../../../../../app/assets/javascripts/components/features/ui/components/column'; +import ColumnHeader from '../../../../../../app/assets/javascripts/components/features/ui/components/column_header'; + +describe('<Column />', () => { + describe('<ColumnHeader /> click handler', () => { + beforeEach(() => { + global.requestAnimationFrame = sinon.spy(); + }); + + it('runs the scroll animation if the column contains scrollable content', () => { + const wrapper = mount( + <Column heading="notifications"> + <div className="scrollable" /> + </Column> + ); + wrapper.find(ColumnHeader).simulate('click'); + expect(global.requestAnimationFrame.called).to.equal(true); + }); + + it('does not try to scroll if there is no scrollable content', () => { + const wrapper = mount(<Column heading="notifications" />); + wrapper.find(ColumnHeader).simulate('click'); + expect(global.requestAnimationFrame.called).to.equal(false); + }); + }); +}); |