mirror of
https://github.com/lingble/chatwoot.git
synced 2025-11-02 03:57:52 +00:00
49 lines
1.6 KiB
JavaScript
49 lines
1.6 KiB
JavaScript
import { shallowMount } from '@vue/test-utils';
|
|
import GoogleOAuthButton from './Button.vue';
|
|
|
|
function getWrapper(showSeparator) {
|
|
return shallowMount(GoogleOAuthButton, {
|
|
propsData: { showSeparator: showSeparator },
|
|
mocks: { $t: text => text },
|
|
});
|
|
}
|
|
|
|
describe('GoogleOAuthButton.vue', () => {
|
|
beforeEach(() => {
|
|
window.chatwootConfig = {
|
|
googleOAuthClientId: 'clientId',
|
|
googleOAuthCallbackUrl: 'http://localhost:3000/test-callback',
|
|
};
|
|
});
|
|
|
|
afterEach(() => {
|
|
window.chatwootConfig = {};
|
|
});
|
|
|
|
it('renders the OR separator if showSeparator is true', () => {
|
|
const wrapper = getWrapper(true);
|
|
expect(wrapper.findComponent({ ref: 'divider' }).exists()).toBe(true);
|
|
});
|
|
|
|
it('does not render the OR separator if showSeparator is false', () => {
|
|
const wrapper = getWrapper(false);
|
|
expect(wrapper.findComponent({ ref: 'divider' }).exists()).toBe(false);
|
|
});
|
|
|
|
it('generates the correct Google Auth URL', () => {
|
|
const wrapper = getWrapper();
|
|
const googleAuthUrl = new URL(wrapper.vm.getGoogleAuthUrl());
|
|
const params = googleAuthUrl.searchParams;
|
|
expect(googleAuthUrl.origin).toBe('https://accounts.google.com');
|
|
expect(googleAuthUrl.pathname).toBe('/o/oauth2/auth/oauthchooseaccount');
|
|
expect(params.get('client_id')).toBe('clientId');
|
|
expect(params.get('redirect_uri')).toBe(
|
|
'http://localhost:3000/test-callback'
|
|
);
|
|
expect(params.get('response_type')).toBe('code');
|
|
expect(params.get('scope')).toBe('email profile');
|
|
|
|
expect(wrapper.findComponent({ ref: 'divider' }).exists()).toBe(true);
|
|
});
|
|
});
|