From 13d76a0cb2cd08357b7667020410e4615732aabd Mon Sep 17 00:00:00 2001 From: n1aba Date: Fri, 18 Aug 2017 14:06:32 -0500 Subject: PLT-6451 Migrate installed_oauth_app.jsx to be pure and use Redux (#7190) * Migrate installed_oauth_app.jsx to be pure and use Redux, add test * Fix behavior for the error case --- .../installed_oauth_app.test.jsx.snap | 155 +++++++++++++++++++++ .../installed_oauth_apps.test.jsx.snap | 2 + .../integrations/installed_oauth_app.test.jsx | 71 ++++++++++ .../integrations/installed_oauth_apps.test.jsx | 6 +- 4 files changed, 233 insertions(+), 1 deletion(-) create mode 100644 webapp/tests/components/integrations/__snapshots__/installed_oauth_app.test.jsx.snap create mode 100644 webapp/tests/components/integrations/installed_oauth_app.test.jsx (limited to 'webapp/tests/components') diff --git a/webapp/tests/components/integrations/__snapshots__/installed_oauth_app.test.jsx.snap b/webapp/tests/components/integrations/__snapshots__/installed_oauth_app.test.jsx.snap new file mode 100644 index 000000000..f4e8fb464 --- /dev/null +++ b/webapp/tests/components/integrations/__snapshots__/installed_oauth_app.test.jsx.snap @@ -0,0 +1,155 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`components/integrations/InstalledOAuthApp should filter out OAuthApp 1`] = `null`; + +exports[`components/integrations/InstalledOAuthApp should match snapshot 1`] = ` +
+
+ +
+
+
+ + testApp + +
+
+ + testing + +
+
+ + + +
+
+ + + +
+
+ + + +
+
+ + + +
+
+ + + +
+
+
+ + + + - + + + + - + +
+
+`; diff --git a/webapp/tests/components/integrations/__snapshots__/installed_oauth_apps.test.jsx.snap b/webapp/tests/components/integrations/__snapshots__/installed_oauth_apps.test.jsx.snap index 022bc1476..c6ef12112 100644 --- a/webapp/tests/components/integrations/__snapshots__/installed_oauth_apps.test.jsx.snap +++ b/webapp/tests/components/integrations/__snapshots__/installed_oauth_apps.test.jsx.snap @@ -72,6 +72,7 @@ exports[`components/integrations/InstalledOAuthApps should match snapshot 1`] = } } onDelete={[Function]} + onRegenerateSecret={[Function]} /> `; diff --git a/webapp/tests/components/integrations/installed_oauth_app.test.jsx b/webapp/tests/components/integrations/installed_oauth_app.test.jsx new file mode 100644 index 000000000..ff27a5768 --- /dev/null +++ b/webapp/tests/components/integrations/installed_oauth_app.test.jsx @@ -0,0 +1,71 @@ +// Copyright (c) 2017-present Mattermost, Inc. All Rights Reserved. +// See License.txt for license information. + +import React from 'react'; +import {shallow} from 'enzyme'; + +import InstalledOAuthApp from 'components/integrations/components/installed_oauth_app.jsx'; + +describe('components/integrations/InstalledOAuthApp', () => { + const emptyFunction = jest.fn(); + const app = { + id: 'facxd9wpzpbpfp8pad78xj75pr', + name: 'testApp', + client_secret: '88cxd9wpzpbpfp8pad78xj75pr', + create_at: 1501365458934, + creator_id: '88oybd1dwfdoxpkpw1h5kpbyco', + description: 'testing', + homepage: 'https://test.com', + icon_url: 'https://test.com/icon', + is_trusted: true, + update_at: 1501365458934, + callback_urls: ['https://test.com/callback', 'https://test.com/callback2'] + }; + + test('should match snapshot', () => { + const wrapper = shallow( + + ); + expect(wrapper).toMatchSnapshot(); + }); + + test('should call onRegenerateSecret function', () => { + const onRegenerateSecret = jest.genMockFunction().mockImplementation( + () => { + return new Promise((resolve) => { + process.nextTick(() => resolve()); + }); + } + ); + + const wrapper = shallow( + + ); + wrapper.find('div.item-actions a').at(1).simulate('click', {preventDefault() { + return jest.fn(); + }}); + expect(onRegenerateSecret).toBeCalled(); + }); + + test('should filter out OAuthApp', () => { + const wrapper = shallow( + + ); + expect(wrapper).toMatchSnapshot(); + }); +}); \ No newline at end of file diff --git a/webapp/tests/components/integrations/installed_oauth_apps.test.jsx b/webapp/tests/components/integrations/installed_oauth_apps.test.jsx index 4f3ca6ba8..2e5ccad7a 100644 --- a/webapp/tests/components/integrations/installed_oauth_apps.test.jsx +++ b/webapp/tests/components/integrations/installed_oauth_apps.test.jsx @@ -44,7 +44,11 @@ describe('components/integrations/InstalledOAuthApps', () => { team={{name: 'test'}} oauthApps={oauthApps} isSystemAdmin={true} - actions={{getOAuthApps: emptyFunction, deleteOAuthApp: emptyFunction}} + actions={{ + getOAuthApps: emptyFunction, + regenOAuthAppSecret: emptyFunction, + deleteOAuthApp: emptyFunction + }} /> ); expect(wrapper.find('InstalledOAuthApp').length).toBe(2); -- cgit v1.2.3-1-g7c22