logo

mastofe

My custom branche(s) on git.pleroma.social/pleroma/mastofe
commit: 08fce0821706a3c84b70fd513eb75c0ad7014c04
parent: 3064ef96a12c418281789ee43408fb608d3e9bd2
Author: Henry Smith <henry@henrysmith.org>
Date:   Wed, 12 Apr 2017 17:16:59 +0200

Add unit tests for https://github.com/tootsuite/mastodon/pull/1574 (#1584)


Diffstat:

Aspec/javascript/components/features/ui/components/column.test.jsx30++++++++++++++++++++++++++++++
1 file 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 @@ -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); + }); + }); +});