Skip to content

Commit

Permalink
PPI-1030 - Added jest tests
Browse files Browse the repository at this point in the history
  • Loading branch information
cyl3x committed Jan 15, 2025
1 parent e681d57 commit 595a83b
Show file tree
Hide file tree
Showing 17 changed files with 2,108 additions and 0 deletions.
1 change: 1 addition & 0 deletions src/Resources/app/administration/eslint.config.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -189,6 +189,7 @@ export default tseslint.config(
'jest/prefer-to-contain': 'error',
'jest/prefer-to-have-length': 'error',
'jest/consistent-test-it': ['error', { fn: 'it', withinDescribe: 'it' }],
'@typescript-eslint/no-unsafe-member-access': 'off', // Needed for any/VueComponent typed wrappers
},
},
{
Expand Down
11 changes: 11 additions & 0 deletions src/Resources/app/administration/jest.setup.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,3 +2,14 @@ import 'SwagPayPal/mixin/swag-paypal-credentials-loader.mixin';
import 'SwagPayPal/mixin/swag-paypal-notification.mixin';
import 'SwagPayPal/mixin/swag-paypal-pos-catch-error.mixin';
import 'SwagPayPal/mixin/swag-paypal-pos-log-label.mixin';

import 'SwagPayPal/mixin/swag-paypal-settings.mixin';
import 'SwagPayPal/mixin/swag-paypal-merchant-information.mixin';

import 'SwagPayPal/app/store/swag-paypal-settings.store';
import 'SwagPayPal/app/store/swag-paypal-merchant-information.store';

afterEach(() => {
Shopware.Store.get('swagPayPalSettings').$reset();
Shopware.Store.get('swagPayPalMerchantInformation').$reset();
});
Original file line number Diff line number Diff line change
@@ -0,0 +1,231 @@
import { mount } from '@vue/test-utils';
import SwagPayPalOnboardingButton from '.';

Shopware.Component.register('swag-paypal-onboarding-button', Promise.resolve(SwagPayPalOnboardingButton));

async function loadScript(script: Element) {
window.PAYPAL = {
apps: {
// @ts-expect-error - not fully implemented on purpose
Signup: {
setup: jest.fn(),
render: jest.fn(),
},
},
};

script.dispatchEvent(new Event('load'));

await flushPromises();
}

async function createWrapper() {
const route: Record<string, unknown> = {
path: '/sw/path',
query: {},
};

return mount(
await Shopware.Component.build('swag-paypal-onboarding-button') as typeof SwagPayPalOnboardingButton,
{
global: {
mocks: {
$t: (key: string) => key,
$route: route,
$router: {
replace: jest.fn((params: Record<string, unknown>) => {
route.query = params.query;
}),
},
},
provide: {
acl: { can: () => true },
SwagPayPalSettingsService: {
getApiCredentials: jest.fn(),
},
},
},
},
);
}

describe('swag-paypal-onboarding-button', () => {
it('should be a Vue.js component', async () => {
const wrapper = await createWrapper();

expect(wrapper.vm).toBeTruthy();
});

it('should initialize component', async () => {
const wrapper = await createWrapper();

const script = document.head.querySelector('#paypal-js');
expect(script).toBeTruthy();
await loadScript(script!);

expect(typeof window.PAYPAL!.apps.Signup.render).toBe('function');
expect(window.PAYPAL!.apps.Signup.setup).not.toHaveBeenCalled();

const renderSpy = jest.spyOn(wrapper.vm, 'renderPayPalButton');

wrapper.vm.loadPayPalScript();

expect(renderSpy).not.toHaveBeenCalled();
expect(window.PAYPAL!.apps.Signup.setup).toHaveBeenCalled();
});

it('should set config', async () => {
const wrapper = await createWrapper();
const store = Shopware.Store.get('swagPayPalSettings');

store.setConfig(null, {});
wrapper.setProps({ type: 'live' });
await wrapper.vm.$nextTick();

expect(wrapper.vm.suffix).toBe('');
wrapper.vm.setConfig('client-id', 'client-secret', 'payer-id');

expect(store.allConfigs).toStrictEqual({
null: {
'SwagPayPal.settings.clientId': 'client-id',
'SwagPayPal.settings.clientSecret': 'client-secret',
'SwagPayPal.settings.merchantPayerId': 'payer-id',
'SwagPayPal.settings.sandbox': false,
},
});

store.setConfig(null, {});
wrapper.setProps({ type: 'sandbox' });
await wrapper.vm.$nextTick();

expect(wrapper.vm.suffix).toBe('Sandbox');
wrapper.vm.setConfig('client-id', 'client-secret', 'payer-id');

expect(store.allConfigs).toStrictEqual({
null: {
'SwagPayPal.settings.clientIdSandbox': 'client-id',
'SwagPayPal.settings.clientSecretSandbox': 'client-secret',
'SwagPayPal.settings.merchantPayerIdSandbox': 'payer-id',
'SwagPayPal.settings.sandbox': true,
},
});
});

it('should have right onboarding url', async () => {
const wrapper = await createWrapper();

const sharedParams = [
['channelId', 'partner'],
['product', 'ppcp'],
['secondaryProducts', 'advanced_vaulting,PAYMENT_METHODS'],
['capabilities', 'APPLE_PAY,GOOGLE_PAY,PAY_UPON_INVOICE,PAYPAL_WALLET_VAULTING_ADVANCED'],
['integrationType', 'FO'],
['features', 'PAYMENT,REFUND,READ_SELLER_DISPUTE,UPDATE_SELLER_DISPUTE,ADVANCED_TRANSACTIONS_SEARCH,ACCESS_MERCHANT_INFORMATION,TRACKING_SHIPMENT_READWRITE,VAULT,BILLING_AGREEMENT'],
['displayMode', 'minibrowser'],
['partnerLogoUrl', 'https://assets.shopware.com/media/logos/shopware_logo_blue.svg'],
];

wrapper.vm.live.sellerNonce = 'live-nonce';
wrapper.vm.sandbox.sellerNonce = 'sandbox-nonce';

wrapper.setProps({ type: 'live' });
await wrapper.vm.$nextTick();

const liveUrl = new URL(wrapper.vm.onboardingUrl);
expect(liveUrl.origin).toBe('https://www.paypal.com');
expect(liveUrl.pathname).toBe('/bizsignup/partner/entry');
expect(Array.from(liveUrl.searchParams)).toStrictEqual([
...sharedParams,
['partnerId', 'DYKPBPEAW5JNA'],
['partnerClientId', 'AR1aQ13lHxH1c6b3CDd8wSY6SWad2Lt5fv5WkNIZg-qChBoGNfHr2kT180otUmvE_xXtwkgahXUBBurW'],
['sellerNonce', 'live-nonce'],
['returnToPartnerUrl', 'http://localhost/#/sw/path?ppOnboarding=live'],
]);

wrapper.setProps({ type: 'sandbox' });
await wrapper.vm.$nextTick();

const sandboxUrl = new URL(wrapper.vm.onboardingUrl);
expect(sandboxUrl.origin).toBe('https://www.sandbox.paypal.com');
expect(sandboxUrl.pathname).toBe('/bizsignup/partner/entry');
expect(Array.from(sandboxUrl.searchParams)).toStrictEqual([
...sharedParams,
['partnerId', '45KXQA7PULGAG'],
['partnerClientId', 'AQ9g8qMYHpE8s028VCq_GO3Roy9pjeqGDjKTkR_sxzX0FtncBb3QUWbFtoQMtdpe2lG9NpnDT419dK8s'],
['sellerNonce', 'sandbox-nonce'],
['returnToPartnerUrl', 'http://localhost/#/sw/path?ppOnboarding=sandbox'],
]);
});

it('should complete onboarding', async () => {
const wrapper = await createWrapper();

const store = Shopware.Store.get('swagPayPalSettings');

store.setConfig(null, {});
wrapper.vm.$router.replace({
query: {
ppOnboarding: 'sandbox',
merchantIdInPayPal: 'payer-id-sandbox',
},
});

wrapper.vm.onMounted();

expect(wrapper.vm.$route.query).toStrictEqual({});
expect(store.allConfigs).toStrictEqual({
null: {
'SwagPayPal.settings.merchantPayerIdSandbox': 'payer-id-sandbox',
},
});

store.setConfig(null, {});
wrapper.vm.$router.replace({
query: {
ppOnboarding: 'live',
merchantIdInPayPal: 'payer-id-live',
},
});

wrapper.vm.onMounted();

expect(wrapper.vm.$route.query).toStrictEqual({});
expect(store.allConfigs).toStrictEqual({
null: {
'SwagPayPal.settings.merchantPayerId': 'payer-id-live',
},
});

store.setConfig(null, {});
wrapper.vm.$router.replace({
query: {
ppOnboarding: 'sdf-live',
merchantIdInPayPal: 'merchant-id-live',
},
});

wrapper.vm.onMounted();

expect(wrapper.vm.$route.query).toStrictEqual({});
expect(store.allConfigs).toStrictEqual({ null: {} });
});

it('should be able to change type after creation', async () => {
const wrapper = await createWrapper();

expect(wrapper.vm.suffix).toBe('');

wrapper.vm.type = 'sandbox';

expect(wrapper.vm.suffix).toBe('Sandbox');

wrapper.vm.type = 'live';

expect(wrapper.vm.suffix).toBe('');

wrapper.setProps({ type: 'sandbox' });
await wrapper.vm.$nextTick();

expect(wrapper.vm.suffix).toBe('Sandbox');
});
});
Loading

0 comments on commit 595a83b

Please sign in to comment.