diff options
author | Sriram Viswanathan <sriramv@thoughtworks.com> | 2017-03-22 16:26:50 -0300 |
---|---|---|
committer | Sriram Viswanathan <sriramv@thoughtworks.com> | 2017-03-23 17:16:40 -0300 |
commit | c56bf133feddfcfed9487c16229138fcdb046983 (patch) | |
tree | 44ebc2038d66c81b7b5a6911c3cd429cb7ef3ee1 /web-ui/src/common/logout | |
parent | fc074ea9f9b7cd6708a5a878a7b56a4d76a9124e (diff) |
|#973| Thais + Sriram | Adds logout component to be shown on the header
Diffstat (limited to 'web-ui/src/common/logout')
-rw-r--r-- | web-ui/src/common/logout/logout.js | 48 | ||||
-rw-r--r-- | web-ui/src/common/logout/logout.spec.js | 49 |
2 files changed, 97 insertions, 0 deletions
diff --git a/web-ui/src/common/logout/logout.js b/web-ui/src/common/logout/logout.js new file mode 100644 index 00000000..12db1067 --- /dev/null +++ b/web-ui/src/common/logout/logout.js @@ -0,0 +1,48 @@ +/* + * Copyright (c) 2017 ThoughtWorks, Inc. + * + * Pixelated is free software: you can redistribute it and/or modify + * it under the terms of the GNU Affero General Public License as published by + * the Free Software Foundation, either version 3 of the License, or + * (at your option) any later version. + * + * Pixelated is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU Affero General Public License for more details. + * + * You should have received a copy of the GNU Affero General Public License + * along with Pixelated. If not, see <http://www.gnu.org/licenses/>. + */ + +import React from 'react'; +import { translate } from 'react-i18next'; +import browser from 'helpers/browser'; + +import SubmitFlatButton from 'src/common/flat_button/flat_button'; + +export class Logout extends React.Component { + + constructor(props) { + super(props); + this.state = { csrf_token: browser.getCookie('XSRF-TOKEN') }; + } + + render() { + const t = this.props.t; + return ( + <div className='logout-container'> + <form id='logout-form' method='POST' action='logout'> + <input type='hidden' name='csrftoken' value={this.state.csrf_token} /> + <SubmitFlatButton buttonText={t('logout')} fontIconClass='fa fa-sign-out' /> + </form> + </div> + ); + } +} + +Logout.propTypes = { + t: React.PropTypes.func.isRequired +}; + +export default translate('', { wait: true })(Logout); diff --git a/web-ui/src/common/logout/logout.spec.js b/web-ui/src/common/logout/logout.spec.js new file mode 100644 index 00000000..ba228e61 --- /dev/null +++ b/web-ui/src/common/logout/logout.spec.js @@ -0,0 +1,49 @@ +import { shallow } from 'enzyme'; +import expect from 'expect'; +import React from 'react'; +import { Logout } from 'src/common/logout/logout'; + +describe('Logout', () => { + let logout; + + beforeEach(() => { + const mockTranslations = key => key; + logout = shallow(<Logout t={mockTranslations} fontIconClass='fa fa-sign-out' />); + }); + + it('renders the logout container', () => { + expect(logout.find('div.logout-container')).toExist(); + }); + + describe('logout form', () => { + let logoutForm; + + beforeEach(() => { + logoutForm = logout.find('form#logout-form'); + }); + + it('renders logout form', () => { + expect(logoutForm).toExist(); + }); + + it('renders logout form with POST method', () => { + expect(logoutForm.props().method).toEqual('POST'); + }); + + it('renders logout form with action as logout', () => { + expect(logoutForm.props().action).toEqual('logout'); + }); + + it('renders csrf hidden input', () => { + expect(logoutForm.find('input[name="csrftoken"]')).toExist(); + }); + + it('renders SubmitFlatButton for logout', () => { + expect(logoutForm.find('SubmitFlatButton').props().buttonText).toEqual('logout'); + }); + + it('renders SubmitFlatButton for logout with fontIcon', () => { + expect(logoutForm.find('SubmitFlatButton').props().fontIconClass).toEqual('fa fa-sign-out'); + }); + }); +}); |