@tonder.io/ionic-lite-sdk 0.0.35-beta.7 → 0.0.36-beta.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.gitlab-ci.yml +28 -28
- package/README.md +221 -202
- package/dist/classes/errorResponse.d.ts +1 -1
- package/dist/classes/liteCheckout.d.ts +32 -56
- package/dist/data/api.d.ts +1 -1
- package/dist/helpers/utils.d.ts +4 -8
- package/dist/index.d.ts +1 -2
- package/dist/index.js +1 -1
- package/dist/types/commons.d.ts +0 -37
- package/dist/types/requests.d.ts +3 -12
- package/dist/types/responses.d.ts +3 -0
- package/jest.config.ts +14 -14
- package/package.json +38 -38
- package/rollup.config.js +16 -16
- package/src/classes/3dsHandler.ts +237 -237
- package/src/classes/errorResponse.ts +16 -16
- package/src/classes/liteCheckout.ts +575 -598
- package/src/data/api.ts +20 -20
- package/src/helpers/constants.ts +63 -63
- package/src/helpers/mercadopago.ts +15 -15
- package/src/helpers/utils.ts +320 -120
- package/src/index.ts +4 -10
- package/src/types/commons.ts +83 -125
- package/src/types/requests.ts +105 -114
- package/src/types/responses.ts +193 -189
- package/src/types/skyflow.ts +17 -17
- package/tests/classes/liteCheckout.test.ts +57 -57
- package/tests/methods/createOrder.test.ts +142 -142
- package/tests/methods/createPayment.test.ts +122 -122
- package/tests/methods/customerRegister.test.ts +119 -119
- package/tests/methods/getBusiness.test.ts +115 -115
- package/tests/methods/getCustomerCards.test.ts +119 -113
- package/tests/methods/getOpenpayDeviceSessionID.test.ts +95 -0
- package/tests/methods/getSkyflowToken.test.ts +155 -0
- package/tests/methods/getVaultToken.test.ts +107 -0
- package/tests/methods/registerCustomerCard.test.ts +117 -117
- package/tests/methods/startCheckoutRouter.test.ts +119 -119
- package/tests/methods/startCheckoutRouterFull.test.ts +138 -138
- package/tests/utils/defaultMock.ts +20 -21
- package/tests/utils/mockClasses.ts +656 -659
- package/tsconfig.json +18 -18
- package/.idea/aws.xml +0 -17
- package/.idea/inspectionProfiles/Project_Default.xml +0 -6
- package/.idea/prettier.xml +0 -6
- package/.idea/vcs.xml +0 -6
- package/.idea/workspace.xml +0 -132
- package/dist/classes/BaseInlineCheckout.d.ts +0 -45
- package/dist/data/businessApi.d.ts +0 -2
- package/dist/data/cardApi.d.ts +0 -4
- package/dist/data/checkoutApi.d.ts +0 -4
- package/dist/data/customerApi.d.ts +0 -2
- package/dist/data/openPayApi.d.ts +0 -1
- package/dist/data/paymentMethodApi.d.ts +0 -5
- package/dist/data/skyflowApi.d.ts +0 -1
- package/dist/helpers/skyflow.d.ts +0 -3
- package/dist/helpers/validations.d.ts +0 -6
- package/dist/shared/catalog/paymentMethodsCatalog.d.ts +0 -1
- package/dist/shared/constants/messages.d.ts +0 -11
- package/dist/shared/constants/paymentMethodAPM.d.ts +0 -62
- package/dist/shared/constants/tonderUrl.d.ts +0 -7
- package/dist/types/card.d.ts +0 -29
- package/dist/types/checkout.d.ts +0 -103
- package/dist/types/customer.d.ts +0 -12
- package/dist/types/paymentMethod.d.ts +0 -22
- package/src/classes/BaseInlineCheckout.ts +0 -356
- package/src/data/businessApi.ts +0 -18
- package/src/data/cardApi.ts +0 -89
- package/src/data/checkoutApi.ts +0 -87
- package/src/data/customerApi.ts +0 -31
- package/src/data/openPayApi.ts +0 -12
- package/src/data/paymentMethodApi.ts +0 -37
- package/src/data/skyflowApi.ts +0 -20
- package/src/helpers/skyflow.ts +0 -91
- package/src/helpers/validations.ts +0 -55
- package/src/shared/catalog/paymentMethodsCatalog.ts +0 -248
- package/src/shared/constants/messages.ts +0 -11
- package/src/shared/constants/paymentMethodAPM.ts +0 -63
- package/src/shared/constants/tonderUrl.ts +0 -8
- package/src/types/card.ts +0 -34
- package/src/types/checkout.ts +0 -118
- package/src/types/customer.ts +0 -12
- package/src/types/index.d.ts +0 -10
- package/src/types/liteInlineCheckout.d.ts +0 -191
- package/src/types/paymentMethod.ts +0 -24
- package/src/types/validations.d.ts +0 -11
|
@@ -1,118 +1,118 @@
|
|
|
1
|
-
import "../utils/defaultMock";
|
|
2
|
-
import { LiteCheckout } from "../../src";
|
|
3
|
-
import { LiteCheckoutConstructor } from "../../src/classes/liteCheckout";
|
|
4
|
-
import { constructorFields } from "../utils/defaultMock";
|
|
5
|
-
import { RegisterCustomerCardRequestClass, RegisterCustomerCardResponseClass } from "../utils/mockClasses";
|
|
6
|
-
import { ErrorResponse } from "../../src/classes/errorResponse";
|
|
7
|
-
import { IErrorResponse } from "../../src/types/responses";
|
|
8
|
-
|
|
9
|
-
declare global {
|
|
10
|
-
interface Window {
|
|
11
|
-
OpenPay: any;
|
|
12
|
-
Skyflow: any;
|
|
13
|
-
}
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
describe("registerCustomerCard", () => {
|
|
17
|
-
let checkoutConstructor: LiteCheckoutConstructor,
|
|
18
|
-
liteCheckout: LiteCheckout,
|
|
19
|
-
fetchSpy: jest.SpyInstance,
|
|
20
|
-
liteCheckoutSpy: jest.SpyInstance;
|
|
21
|
-
|
|
22
|
-
beforeEach(async () => {
|
|
23
|
-
window.fetch = jest.fn();
|
|
24
|
-
|
|
25
|
-
checkoutConstructor = {
|
|
26
|
-
...constructorFields,
|
|
27
|
-
};
|
|
28
|
-
|
|
29
|
-
liteCheckout = new LiteCheckout(constructorFields);
|
|
30
|
-
|
|
31
|
-
fetchSpy = jest.spyOn(global, "fetch");
|
|
32
|
-
});
|
|
33
|
-
|
|
34
|
-
afterEach(() => {
|
|
35
|
-
jest.restoreAllMocks();
|
|
36
|
-
});
|
|
37
|
-
|
|
38
|
-
it("registerCustomerCard success", async () => {
|
|
39
|
-
liteCheckoutSpy = jest.spyOn(liteCheckout, "registerCustomerCard");
|
|
40
|
-
|
|
41
|
-
fetchSpy.mockImplementation(() =>
|
|
42
|
-
Promise.resolve({
|
|
43
|
-
json: () =>
|
|
44
|
-
Promise.resolve({
|
|
45
|
-
...new RegisterCustomerCardResponseClass(),
|
|
46
|
-
}),
|
|
47
|
-
ok: true,
|
|
48
|
-
})
|
|
49
|
-
);
|
|
50
|
-
|
|
51
|
-
const response = await liteCheckout.registerCustomerCard("1234", { ...new RegisterCustomerCardRequestClass() });
|
|
52
|
-
|
|
53
|
-
expect(response).toStrictEqual({ ...new RegisterCustomerCardResponseClass() });
|
|
54
|
-
expect(liteCheckoutSpy).toHaveBeenCalled();
|
|
55
|
-
expect(liteCheckoutSpy).toHaveBeenCalledWith("1234", { ...new RegisterCustomerCardRequestClass() });
|
|
56
|
-
});
|
|
57
|
-
|
|
58
|
-
it("registerCustomerCard empty", async () => {
|
|
59
|
-
liteCheckoutSpy = jest.spyOn(liteCheckout, "registerCustomerCard");
|
|
60
|
-
|
|
61
|
-
fetchSpy.mockImplementation(() =>
|
|
62
|
-
Promise.resolve({
|
|
63
|
-
json: () => Promise.resolve(),
|
|
64
|
-
ok: true,
|
|
65
|
-
})
|
|
66
|
-
);
|
|
67
|
-
|
|
68
|
-
const response = await liteCheckout.registerCustomerCard("1234", { ...new RegisterCustomerCardRequestClass() });
|
|
69
|
-
expect(liteCheckoutSpy).toHaveBeenCalled();
|
|
70
|
-
expect(liteCheckoutSpy).toHaveReturned();
|
|
71
|
-
expect(response).toBeUndefined();
|
|
72
|
-
});
|
|
73
|
-
|
|
74
|
-
it("registerCustomerCard errorResponse", async () => {
|
|
75
|
-
liteCheckoutSpy = jest.spyOn(liteCheckout, "registerCustomerCard");
|
|
76
|
-
|
|
77
|
-
fetchSpy.mockImplementation(() =>
|
|
78
|
-
Promise.resolve({
|
|
79
|
-
json: () => Promise.resolve(),
|
|
80
|
-
ok: false,
|
|
81
|
-
status: 400,
|
|
82
|
-
})
|
|
83
|
-
);
|
|
84
|
-
|
|
85
|
-
let error: ErrorResponse;
|
|
86
|
-
|
|
87
|
-
try {
|
|
88
|
-
const response = (await liteCheckout.registerCustomerCard(
|
|
89
|
-
"1234", { ...new RegisterCustomerCardRequestClass() }
|
|
90
|
-
)) as IErrorResponse;
|
|
91
|
-
} catch (e: any) {
|
|
92
|
-
error = e;
|
|
93
|
-
expect(error.code).toStrictEqual("400");
|
|
94
|
-
expect(error).toBeInstanceOf(ErrorResponse);
|
|
95
|
-
}
|
|
96
|
-
});
|
|
97
|
-
|
|
98
|
-
it("registerCustomerCard errorCatch", async () => {
|
|
99
|
-
liteCheckoutSpy = jest.spyOn(liteCheckout, "registerCustomerCard");
|
|
100
|
-
|
|
101
|
-
fetchSpy.mockRejectedValue("error");
|
|
102
|
-
|
|
103
|
-
let error: ErrorResponse;
|
|
104
|
-
|
|
105
|
-
try {
|
|
106
|
-
const response = (await liteCheckout.registerCustomerCard(
|
|
107
|
-
"1234", { ...new RegisterCustomerCardRequestClass() }
|
|
108
|
-
)) as IErrorResponse;
|
|
109
|
-
} catch (e: any) {
|
|
110
|
-
error = e;
|
|
111
|
-
expect(error.message).toStrictEqual("error");
|
|
112
|
-
expect(error.name).toStrictEqual("catch");
|
|
113
|
-
}
|
|
114
|
-
|
|
115
|
-
expect(liteCheckoutSpy).toHaveBeenCalled();
|
|
116
|
-
expect(liteCheckoutSpy).rejects.toThrow();
|
|
117
|
-
});
|
|
1
|
+
import "../utils/defaultMock";
|
|
2
|
+
import { LiteCheckout } from "../../src";
|
|
3
|
+
import { LiteCheckoutConstructor } from "../../src/classes/liteCheckout";
|
|
4
|
+
import { constructorFields } from "../utils/defaultMock";
|
|
5
|
+
import { RegisterCustomerCardRequestClass, RegisterCustomerCardResponseClass } from "../utils/mockClasses";
|
|
6
|
+
import { ErrorResponse } from "../../src/classes/errorResponse";
|
|
7
|
+
import { IErrorResponse } from "../../src/types/responses";
|
|
8
|
+
|
|
9
|
+
declare global {
|
|
10
|
+
interface Window {
|
|
11
|
+
OpenPay: any;
|
|
12
|
+
Skyflow: any;
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
describe("registerCustomerCard", () => {
|
|
17
|
+
let checkoutConstructor: LiteCheckoutConstructor,
|
|
18
|
+
liteCheckout: LiteCheckout,
|
|
19
|
+
fetchSpy: jest.SpyInstance,
|
|
20
|
+
liteCheckoutSpy: jest.SpyInstance;
|
|
21
|
+
|
|
22
|
+
beforeEach(async () => {
|
|
23
|
+
window.fetch = jest.fn();
|
|
24
|
+
|
|
25
|
+
checkoutConstructor = {
|
|
26
|
+
...constructorFields,
|
|
27
|
+
};
|
|
28
|
+
|
|
29
|
+
liteCheckout = new LiteCheckout(constructorFields);
|
|
30
|
+
|
|
31
|
+
fetchSpy = jest.spyOn(global, "fetch");
|
|
32
|
+
});
|
|
33
|
+
|
|
34
|
+
afterEach(() => {
|
|
35
|
+
jest.restoreAllMocks();
|
|
36
|
+
});
|
|
37
|
+
|
|
38
|
+
it("registerCustomerCard success", async () => {
|
|
39
|
+
liteCheckoutSpy = jest.spyOn(liteCheckout, "registerCustomerCard");
|
|
40
|
+
|
|
41
|
+
fetchSpy.mockImplementation(() =>
|
|
42
|
+
Promise.resolve({
|
|
43
|
+
json: () =>
|
|
44
|
+
Promise.resolve({
|
|
45
|
+
...new RegisterCustomerCardResponseClass(),
|
|
46
|
+
}),
|
|
47
|
+
ok: true,
|
|
48
|
+
})
|
|
49
|
+
);
|
|
50
|
+
|
|
51
|
+
const response = await liteCheckout.registerCustomerCard("123456", "1234", { ...new RegisterCustomerCardRequestClass() });
|
|
52
|
+
|
|
53
|
+
expect(response).toStrictEqual({ ...new RegisterCustomerCardResponseClass() });
|
|
54
|
+
expect(liteCheckoutSpy).toHaveBeenCalled();
|
|
55
|
+
expect(liteCheckoutSpy).toHaveBeenCalledWith("123456", "1234", { ...new RegisterCustomerCardRequestClass() });
|
|
56
|
+
});
|
|
57
|
+
|
|
58
|
+
it("registerCustomerCard empty", async () => {
|
|
59
|
+
liteCheckoutSpy = jest.spyOn(liteCheckout, "registerCustomerCard");
|
|
60
|
+
|
|
61
|
+
fetchSpy.mockImplementation(() =>
|
|
62
|
+
Promise.resolve({
|
|
63
|
+
json: () => Promise.resolve(),
|
|
64
|
+
ok: true,
|
|
65
|
+
})
|
|
66
|
+
);
|
|
67
|
+
|
|
68
|
+
const response = await liteCheckout.registerCustomerCard("123456", "1234", { ...new RegisterCustomerCardRequestClass() });
|
|
69
|
+
expect(liteCheckoutSpy).toHaveBeenCalled();
|
|
70
|
+
expect(liteCheckoutSpy).toHaveReturned();
|
|
71
|
+
expect(response).toBeUndefined();
|
|
72
|
+
});
|
|
73
|
+
|
|
74
|
+
it("registerCustomerCard errorResponse", async () => {
|
|
75
|
+
liteCheckoutSpy = jest.spyOn(liteCheckout, "registerCustomerCard");
|
|
76
|
+
|
|
77
|
+
fetchSpy.mockImplementation(() =>
|
|
78
|
+
Promise.resolve({
|
|
79
|
+
json: () => Promise.resolve(),
|
|
80
|
+
ok: false,
|
|
81
|
+
status: 400,
|
|
82
|
+
})
|
|
83
|
+
);
|
|
84
|
+
|
|
85
|
+
let error: ErrorResponse;
|
|
86
|
+
|
|
87
|
+
try {
|
|
88
|
+
const response = (await liteCheckout.registerCustomerCard(
|
|
89
|
+
"123456", "1234", { ...new RegisterCustomerCardRequestClass() }
|
|
90
|
+
)) as IErrorResponse;
|
|
91
|
+
} catch (e: any) {
|
|
92
|
+
error = e;
|
|
93
|
+
expect(error.code).toStrictEqual("400");
|
|
94
|
+
expect(error).toBeInstanceOf(ErrorResponse);
|
|
95
|
+
}
|
|
96
|
+
});
|
|
97
|
+
|
|
98
|
+
it("registerCustomerCard errorCatch", async () => {
|
|
99
|
+
liteCheckoutSpy = jest.spyOn(liteCheckout, "registerCustomerCard");
|
|
100
|
+
|
|
101
|
+
fetchSpy.mockRejectedValue("error");
|
|
102
|
+
|
|
103
|
+
let error: ErrorResponse;
|
|
104
|
+
|
|
105
|
+
try {
|
|
106
|
+
const response = (await liteCheckout.registerCustomerCard(
|
|
107
|
+
"123456", "1234", { ...new RegisterCustomerCardRequestClass() }
|
|
108
|
+
)) as IErrorResponse;
|
|
109
|
+
} catch (e: any) {
|
|
110
|
+
error = e;
|
|
111
|
+
expect(error.message).toStrictEqual("error");
|
|
112
|
+
expect(error.name).toStrictEqual("catch");
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
expect(liteCheckoutSpy).toHaveBeenCalled();
|
|
116
|
+
expect(liteCheckoutSpy).rejects.toThrow();
|
|
117
|
+
});
|
|
118
118
|
});
|
|
@@ -1,120 +1,120 @@
|
|
|
1
|
-
import "../utils/defaultMock";
|
|
2
|
-
import { LiteCheckout } from "../../src";
|
|
3
|
-
import { ErrorResponse } from "../../src/classes/errorResponse";
|
|
4
|
-
import { LiteCheckoutConstructor } from "../../src/classes/liteCheckout";
|
|
5
|
-
import { IErrorResponse } from "../../src/types/responses";
|
|
6
|
-
import { constructorFields } from "../utils/defaultMock";
|
|
7
|
-
import { StartCheckoutResponseClass, StartCheckoutRequestClass, CreatePaymentRequestClass } from "../utils/mockClasses";
|
|
8
|
-
|
|
9
|
-
declare global {
|
|
10
|
-
interface Window {
|
|
11
|
-
OpenPay: any;
|
|
12
|
-
Skyflow: any;
|
|
13
|
-
}
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
describe("startCheckoutRouter", () => {
|
|
17
|
-
let checkoutConstructor: LiteCheckoutConstructor,
|
|
18
|
-
liteCheckout: LiteCheckout,
|
|
19
|
-
fetchSpy: jest.SpyInstance,
|
|
20
|
-
liteCheckoutSpy: jest.SpyInstance;
|
|
21
|
-
|
|
22
|
-
beforeEach(async () => {
|
|
23
|
-
window.fetch = jest.fn();
|
|
24
|
-
|
|
25
|
-
checkoutConstructor = {
|
|
26
|
-
...constructorFields,
|
|
27
|
-
};
|
|
28
|
-
|
|
29
|
-
liteCheckout = new LiteCheckout(constructorFields);
|
|
30
|
-
|
|
31
|
-
fetchSpy = jest.spyOn(global, "fetch");
|
|
32
|
-
});
|
|
33
|
-
|
|
34
|
-
afterEach(() => {
|
|
35
|
-
jest.restoreAllMocks();
|
|
36
|
-
});
|
|
37
|
-
|
|
38
|
-
it("startCheckoutRouter success", async () => {
|
|
39
|
-
liteCheckoutSpy = jest.spyOn(liteCheckout, "startCheckoutRouter");
|
|
40
|
-
|
|
41
|
-
fetchSpy.mockImplementation(() =>
|
|
42
|
-
Promise.resolve({
|
|
43
|
-
json: () => Promise.resolve([{ ...new StartCheckoutResponseClass() }]),
|
|
44
|
-
ok: true,
|
|
45
|
-
})
|
|
46
|
-
);
|
|
47
|
-
|
|
48
|
-
const response = await liteCheckout.startCheckoutRouter({
|
|
49
|
-
...new StartCheckoutRequestClass(),
|
|
50
|
-
});
|
|
51
|
-
expect(response).toStrictEqual([{ ...new StartCheckoutResponseClass() }]);
|
|
52
|
-
expect(liteCheckoutSpy).toHaveBeenCalled();
|
|
53
|
-
expect(liteCheckoutSpy).toHaveBeenCalledWith({
|
|
54
|
-
...new CreatePaymentRequestClass(),
|
|
55
|
-
});
|
|
56
|
-
});
|
|
57
|
-
|
|
58
|
-
it("startCheckoutRouter empty", async () => {
|
|
59
|
-
liteCheckoutSpy = jest.spyOn(liteCheckout, "startCheckoutRouter");
|
|
60
|
-
|
|
61
|
-
fetchSpy.mockImplementation(() =>
|
|
62
|
-
Promise.resolve({
|
|
63
|
-
json: () => Promise.resolve(),
|
|
64
|
-
ok: true,
|
|
65
|
-
})
|
|
66
|
-
);
|
|
67
|
-
|
|
68
|
-
const response = await liteCheckout.startCheckoutRouter({
|
|
69
|
-
...new StartCheckoutRequestClass(),
|
|
70
|
-
});
|
|
71
|
-
expect(liteCheckoutSpy).toHaveBeenCalled();
|
|
72
|
-
expect(liteCheckoutSpy).toHaveReturned();
|
|
73
|
-
expect(response).toBeUndefined();
|
|
74
|
-
});
|
|
75
|
-
|
|
76
|
-
it("startCheckoutRouter errorResponse", async () => {
|
|
77
|
-
liteCheckoutSpy = jest.spyOn(liteCheckout, "startCheckoutRouter");
|
|
78
|
-
|
|
79
|
-
fetchSpy.mockImplementation(() =>
|
|
80
|
-
Promise.resolve({
|
|
81
|
-
json: () => Promise.resolve(),
|
|
82
|
-
ok: false,
|
|
83
|
-
status: 400,
|
|
84
|
-
})
|
|
85
|
-
);
|
|
86
|
-
|
|
87
|
-
let error: ErrorResponse;
|
|
88
|
-
|
|
89
|
-
try {
|
|
90
|
-
const response = (await liteCheckout.startCheckoutRouter({
|
|
91
|
-
...new StartCheckoutRequestClass(),
|
|
92
|
-
})) as IErrorResponse;
|
|
93
|
-
} catch (e: any) {
|
|
94
|
-
error = e;
|
|
95
|
-
expect(error.code).toStrictEqual("400");
|
|
96
|
-
expect(error).toBeInstanceOf(ErrorResponse);
|
|
97
|
-
}
|
|
98
|
-
});
|
|
99
|
-
|
|
100
|
-
it("startCheckoutRouter errorCatch", async () => {
|
|
101
|
-
liteCheckoutSpy = jest.spyOn(liteCheckout, "startCheckoutRouter");
|
|
102
|
-
|
|
103
|
-
fetchSpy.mockRejectedValue("error");
|
|
104
|
-
|
|
105
|
-
let error: ErrorResponse;
|
|
106
|
-
|
|
107
|
-
try {
|
|
108
|
-
const response = (await liteCheckout.startCheckoutRouter({
|
|
109
|
-
...new StartCheckoutRequestClass(),
|
|
110
|
-
})) as IErrorResponse;
|
|
111
|
-
} catch (e: any) {
|
|
112
|
-
error = e;
|
|
113
|
-
expect(error.message).toStrictEqual("error");
|
|
114
|
-
expect(error.name).toStrictEqual("catch");
|
|
115
|
-
}
|
|
116
|
-
|
|
117
|
-
expect(liteCheckoutSpy).toHaveBeenCalled();
|
|
118
|
-
expect(liteCheckoutSpy).rejects.toThrow();
|
|
119
|
-
});
|
|
1
|
+
import "../utils/defaultMock";
|
|
2
|
+
import { LiteCheckout } from "../../src";
|
|
3
|
+
import { ErrorResponse } from "../../src/classes/errorResponse";
|
|
4
|
+
import { LiteCheckoutConstructor } from "../../src/classes/liteCheckout";
|
|
5
|
+
import { IErrorResponse } from "../../src/types/responses";
|
|
6
|
+
import { constructorFields } from "../utils/defaultMock";
|
|
7
|
+
import { StartCheckoutResponseClass, StartCheckoutRequestClass, CreatePaymentRequestClass } from "../utils/mockClasses";
|
|
8
|
+
|
|
9
|
+
declare global {
|
|
10
|
+
interface Window {
|
|
11
|
+
OpenPay: any;
|
|
12
|
+
Skyflow: any;
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
describe("startCheckoutRouter", () => {
|
|
17
|
+
let checkoutConstructor: LiteCheckoutConstructor,
|
|
18
|
+
liteCheckout: LiteCheckout,
|
|
19
|
+
fetchSpy: jest.SpyInstance,
|
|
20
|
+
liteCheckoutSpy: jest.SpyInstance;
|
|
21
|
+
|
|
22
|
+
beforeEach(async () => {
|
|
23
|
+
window.fetch = jest.fn();
|
|
24
|
+
|
|
25
|
+
checkoutConstructor = {
|
|
26
|
+
...constructorFields,
|
|
27
|
+
};
|
|
28
|
+
|
|
29
|
+
liteCheckout = new LiteCheckout(constructorFields);
|
|
30
|
+
|
|
31
|
+
fetchSpy = jest.spyOn(global, "fetch");
|
|
32
|
+
});
|
|
33
|
+
|
|
34
|
+
afterEach(() => {
|
|
35
|
+
jest.restoreAllMocks();
|
|
36
|
+
});
|
|
37
|
+
|
|
38
|
+
it("startCheckoutRouter success", async () => {
|
|
39
|
+
liteCheckoutSpy = jest.spyOn(liteCheckout, "startCheckoutRouter");
|
|
40
|
+
|
|
41
|
+
fetchSpy.mockImplementation(() =>
|
|
42
|
+
Promise.resolve({
|
|
43
|
+
json: () => Promise.resolve([{ ...new StartCheckoutResponseClass() }]),
|
|
44
|
+
ok: true,
|
|
45
|
+
})
|
|
46
|
+
);
|
|
47
|
+
|
|
48
|
+
const response = await liteCheckout.startCheckoutRouter({
|
|
49
|
+
...new StartCheckoutRequestClass(),
|
|
50
|
+
});
|
|
51
|
+
expect(response).toStrictEqual([{ ...new StartCheckoutResponseClass() }]);
|
|
52
|
+
expect(liteCheckoutSpy).toHaveBeenCalled();
|
|
53
|
+
expect(liteCheckoutSpy).toHaveBeenCalledWith({
|
|
54
|
+
...new CreatePaymentRequestClass(),
|
|
55
|
+
});
|
|
56
|
+
});
|
|
57
|
+
|
|
58
|
+
it("startCheckoutRouter empty", async () => {
|
|
59
|
+
liteCheckoutSpy = jest.spyOn(liteCheckout, "startCheckoutRouter");
|
|
60
|
+
|
|
61
|
+
fetchSpy.mockImplementation(() =>
|
|
62
|
+
Promise.resolve({
|
|
63
|
+
json: () => Promise.resolve(),
|
|
64
|
+
ok: true,
|
|
65
|
+
})
|
|
66
|
+
);
|
|
67
|
+
|
|
68
|
+
const response = await liteCheckout.startCheckoutRouter({
|
|
69
|
+
...new StartCheckoutRequestClass(),
|
|
70
|
+
});
|
|
71
|
+
expect(liteCheckoutSpy).toHaveBeenCalled();
|
|
72
|
+
expect(liteCheckoutSpy).toHaveReturned();
|
|
73
|
+
expect(response).toBeUndefined();
|
|
74
|
+
});
|
|
75
|
+
|
|
76
|
+
it("startCheckoutRouter errorResponse", async () => {
|
|
77
|
+
liteCheckoutSpy = jest.spyOn(liteCheckout, "startCheckoutRouter");
|
|
78
|
+
|
|
79
|
+
fetchSpy.mockImplementation(() =>
|
|
80
|
+
Promise.resolve({
|
|
81
|
+
json: () => Promise.resolve(),
|
|
82
|
+
ok: false,
|
|
83
|
+
status: 400,
|
|
84
|
+
})
|
|
85
|
+
);
|
|
86
|
+
|
|
87
|
+
let error: ErrorResponse;
|
|
88
|
+
|
|
89
|
+
try {
|
|
90
|
+
const response = (await liteCheckout.startCheckoutRouter({
|
|
91
|
+
...new StartCheckoutRequestClass(),
|
|
92
|
+
})) as IErrorResponse;
|
|
93
|
+
} catch (e: any) {
|
|
94
|
+
error = e;
|
|
95
|
+
expect(error.code).toStrictEqual("400");
|
|
96
|
+
expect(error).toBeInstanceOf(ErrorResponse);
|
|
97
|
+
}
|
|
98
|
+
});
|
|
99
|
+
|
|
100
|
+
it("startCheckoutRouter errorCatch", async () => {
|
|
101
|
+
liteCheckoutSpy = jest.spyOn(liteCheckout, "startCheckoutRouter");
|
|
102
|
+
|
|
103
|
+
fetchSpy.mockRejectedValue("error");
|
|
104
|
+
|
|
105
|
+
let error: ErrorResponse;
|
|
106
|
+
|
|
107
|
+
try {
|
|
108
|
+
const response = (await liteCheckout.startCheckoutRouter({
|
|
109
|
+
...new StartCheckoutRequestClass(),
|
|
110
|
+
})) as IErrorResponse;
|
|
111
|
+
} catch (e: any) {
|
|
112
|
+
error = e;
|
|
113
|
+
expect(error.message).toStrictEqual("error");
|
|
114
|
+
expect(error.name).toStrictEqual("catch");
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
expect(liteCheckoutSpy).toHaveBeenCalled();
|
|
118
|
+
expect(liteCheckoutSpy).rejects.toThrow();
|
|
119
|
+
});
|
|
120
120
|
});
|