@tonder.io/ionic-lite-sdk 0.0.3

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.
Files changed (36) hide show
  1. package/.gitlab-ci.yml +29 -0
  2. package/README.md +496 -0
  3. package/dist/classes/errorResponse.d.ts +9 -0
  4. package/dist/classes/liteCheckout.d.ts +34 -0
  5. package/dist/helpers/utils.d.ts +3 -0
  6. package/dist/index.d.ts +2 -0
  7. package/dist/index.js +1 -0
  8. package/dist/types/commons.d.ts +58 -0
  9. package/dist/types/requests.d.ts +55 -0
  10. package/dist/types/responses.d.ts +177 -0
  11. package/dist/types/skyflow.d.ts +17 -0
  12. package/jest.config.ts +15 -0
  13. package/package.json +34 -0
  14. package/rollup.config.js +17 -0
  15. package/src/classes/errorResponse.ts +17 -0
  16. package/src/classes/liteCheckout.ts +301 -0
  17. package/src/helpers/utils.ts +37 -0
  18. package/src/index.ts +5 -0
  19. package/src/types/commons.ts +61 -0
  20. package/src/types/requests.ts +61 -0
  21. package/src/types/responses.ts +186 -0
  22. package/src/types/skyflow.ts +17 -0
  23. package/tests/classes/liteCheckout.test.ts +57 -0
  24. package/tests/methods/createOrder.test.ts +106 -0
  25. package/tests/methods/createPayment.test.ts +109 -0
  26. package/tests/methods/customerRegister.test.ts +106 -0
  27. package/tests/methods/getBusiness.test.ts +102 -0
  28. package/tests/methods/getCustomerCards.test.ts +105 -0
  29. package/tests/methods/getOpenpayDeviceSessionID.test.ts +95 -0
  30. package/tests/methods/getSkyflowToken.test.ts +137 -0
  31. package/tests/methods/getVaultToken.test.ts +107 -0
  32. package/tests/methods/registerCustomerCard.test.ts +105 -0
  33. package/tests/methods/startCheckoutRouter.test.ts +107 -0
  34. package/tests/utils/defaultMock.ts +21 -0
  35. package/tests/utils/mockClasses.ts +540 -0
  36. package/tsconfig.json +19 -0
@@ -0,0 +1,102 @@
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 { BusinessClass } from "../utils/mockClasses";
8
+
9
+ declare global {
10
+ interface Window {
11
+ OpenPay: any;
12
+ Skyflow: any;
13
+ }
14
+ }
15
+
16
+ describe("getBusiness", () => {
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("getBusiness success", async () => {
39
+ liteCheckoutSpy = jest.spyOn(liteCheckout, "getBusiness");
40
+
41
+ fetchSpy.mockImplementation(() =>
42
+ Promise.resolve({
43
+ json: () =>
44
+ Promise.resolve({
45
+ ...new BusinessClass(),
46
+ }),
47
+ ok: true,
48
+ })
49
+ );
50
+
51
+ const response = await liteCheckout.getBusiness();
52
+
53
+ expect(response).toStrictEqual({ ...new BusinessClass() });
54
+ expect(liteCheckoutSpy).toHaveBeenCalled();
55
+ });
56
+
57
+ it("getBusiness empty", async () => {
58
+ liteCheckoutSpy = jest.spyOn(liteCheckout, "getBusiness");
59
+
60
+ fetchSpy.mockImplementation(() =>
61
+ Promise.resolve({
62
+ json: () => Promise.resolve(),
63
+ ok: true,
64
+ })
65
+ );
66
+
67
+ const response = await liteCheckout.getBusiness();
68
+ expect(liteCheckoutSpy).toHaveBeenCalled();
69
+ expect(liteCheckoutSpy).toHaveReturned();
70
+ expect(response).toBeUndefined();
71
+ });
72
+
73
+ it("getBusiness errorResponse", async () => {
74
+ liteCheckoutSpy = jest.spyOn(liteCheckout, "getBusiness");
75
+
76
+ fetchSpy.mockImplementation(() =>
77
+ Promise.resolve({
78
+ json: () => Promise.resolve(),
79
+ ok: false,
80
+ status: 400,
81
+ })
82
+ );
83
+
84
+ const response = (await liteCheckout.getBusiness()) as IErrorResponse;
85
+ expect(response.code).toStrictEqual("400");
86
+ expect(response).toBeInstanceOf(ErrorResponse);
87
+ });
88
+
89
+ it("getBusiness errorCatch", async () => {
90
+ liteCheckoutSpy = jest.spyOn(liteCheckout, "getBusiness");
91
+
92
+ fetchSpy.mockRejectedValue("error");
93
+
94
+ const response = (await liteCheckout.getBusiness()) as ErrorResponse;
95
+ expect(liteCheckoutSpy).toHaveBeenCalled();
96
+ expect(response.message).toStrictEqual("error");
97
+ expect(response.name).toStrictEqual("catch");
98
+ expect(liteCheckoutSpy).rejects.toThrow();
99
+ });
100
+ });
101
+
102
+
@@ -0,0 +1,105 @@
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 { GetCustomerCardsResponseClass } from "../utils/mockClasses";
8
+
9
+ declare global {
10
+ interface Window {
11
+ OpenPay: any;
12
+ Skyflow: any;
13
+ }
14
+ }
15
+
16
+ describe("getCustomerCards", () => {
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("getCustomerCards success", async () => {
39
+ liteCheckoutSpy = jest.spyOn(liteCheckout, "getCustomerCards");
40
+
41
+ fetchSpy.mockImplementation(() =>
42
+ Promise.resolve({
43
+ json: () =>
44
+ Promise.resolve({
45
+ ...new GetCustomerCardsResponseClass(),
46
+ }),
47
+ ok: true,
48
+ })
49
+ );
50
+
51
+ const response = await liteCheckout.getCustomerCards("1234", "1234");
52
+
53
+ expect(response).toStrictEqual({ ...new GetCustomerCardsResponseClass() });
54
+ expect(liteCheckoutSpy).toHaveBeenCalled();
55
+ expect(liteCheckoutSpy).toHaveBeenCalledWith("1234", "1234");
56
+ });
57
+
58
+ it("getCustomerCards empty", async () => {
59
+ liteCheckoutSpy = jest.spyOn(liteCheckout, "getCustomerCards");
60
+
61
+ fetchSpy.mockImplementation(() =>
62
+ Promise.resolve({
63
+ json: () => Promise.resolve(),
64
+ ok: true,
65
+ })
66
+ );
67
+
68
+ const response = await liteCheckout.getCustomerCards("1234", "1234");
69
+ expect(liteCheckoutSpy).toHaveBeenCalled();
70
+ expect(liteCheckoutSpy).toHaveReturned();
71
+ expect(response).toBeUndefined();
72
+ });
73
+
74
+ it("getCustomerCards errorResponse", async () => {
75
+ liteCheckoutSpy = jest.spyOn(liteCheckout, "getCustomerCards");
76
+
77
+ fetchSpy.mockImplementation(() =>
78
+ Promise.resolve({
79
+ json: () => Promise.resolve(),
80
+ ok: false,
81
+ status: 400,
82
+ })
83
+ );
84
+
85
+ const response = (await liteCheckout.getCustomerCards(
86
+ "1234", "1234"
87
+ )) as IErrorResponse;
88
+ expect(response.code).toStrictEqual("400");
89
+ expect(response).toBeInstanceOf(ErrorResponse);
90
+ });
91
+
92
+ it("getCustomerCards errorCatch", async () => {
93
+ liteCheckoutSpy = jest.spyOn(liteCheckout, "getCustomerCards");
94
+
95
+ fetchSpy.mockRejectedValue("error");
96
+
97
+ const response = (await liteCheckout.getCustomerCards(
98
+ "1234", "1234"
99
+ )) as IErrorResponse;
100
+ expect(liteCheckoutSpy).toHaveBeenCalled();
101
+ expect(response.message).toStrictEqual("error");
102
+ expect(response.name).toStrictEqual("catch");
103
+ expect(liteCheckoutSpy).rejects.toThrow();
104
+ });
105
+ });
@@ -0,0 +1,95 @@
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
+
8
+ declare global {
9
+ interface Window {
10
+ OpenPay: any;
11
+ Skyflow: any;
12
+ }
13
+ }
14
+
15
+ describe("getOpenpayDeviceSessionID", () => {
16
+ let checkoutConstructor: LiteCheckoutConstructor,
17
+ liteCheckout: LiteCheckout,
18
+ fetchSpy: jest.SpyInstance,
19
+ liteCheckoutSpy: jest.SpyInstance;
20
+
21
+ beforeEach(async () => {
22
+ window.fetch = jest.fn();
23
+
24
+ checkoutConstructor = {
25
+ ...constructorFields,
26
+ };
27
+
28
+ liteCheckout = new LiteCheckout(constructorFields);
29
+
30
+ fetchSpy = jest.spyOn(global, "fetch");
31
+ });
32
+
33
+ afterEach(() => {
34
+ jest.restoreAllMocks();
35
+ });
36
+
37
+ it("getOpenpayDeviceSessionID success", async () => {
38
+ liteCheckoutSpy = jest.spyOn(liteCheckout, "getOpenpayDeviceSessionID");
39
+
40
+ window.OpenPay = {
41
+ setId: jest.fn(),
42
+ setApiKey: jest.fn(),
43
+ setSandboxMode: jest.fn(),
44
+ deviceData: {
45
+ setup: jest.fn().mockImplementation(() => Promise.resolve("test")),
46
+ },
47
+ };
48
+
49
+ expect(
50
+ liteCheckout.getOpenpayDeviceSessionID("4321", "1234")
51
+ ).resolves.toBe("test");
52
+ expect(liteCheckoutSpy).toHaveBeenCalledWith("4321", "1234");
53
+ });
54
+
55
+ it("getOpenpayDeviceSessionID empty", async () => {
56
+ liteCheckoutSpy = jest.spyOn(liteCheckout, "getOpenpayDeviceSessionID");
57
+
58
+ window.OpenPay = {
59
+ setId: jest.fn(),
60
+ setApiKey: jest.fn(),
61
+ setSandboxMode: jest.fn(),
62
+ deviceData: {
63
+ setup: jest.fn().mockImplementation(() => Promise.resolve()),
64
+ },
65
+ };
66
+
67
+ expect(
68
+ liteCheckout.getOpenpayDeviceSessionID("", "")
69
+ ).resolves.toBeUndefined();
70
+ expect(liteCheckoutSpy).toHaveBeenCalledWith("", "");
71
+ });
72
+
73
+ it("getOpenpayDeviceSessionID error", async () => {
74
+ liteCheckoutSpy = jest.spyOn(liteCheckout, "getOpenpayDeviceSessionID");
75
+
76
+ window.OpenPay = {
77
+ setId: jest.fn(),
78
+ setApiKey: jest.fn(),
79
+ setSandboxMode: jest.fn(),
80
+ deviceData: {
81
+ setup: jest.fn().mockRejectedValue("error"),
82
+ },
83
+ };
84
+
85
+ try {
86
+ await liteCheckout.getOpenpayDeviceSessionID("", "");
87
+ } catch (e) {
88
+ const error: IErrorResponse = e as IErrorResponse;
89
+ expect(liteCheckoutSpy).toHaveBeenCalledWith("", "");
90
+ expect(liteCheckoutSpy).toHaveReturned();
91
+ expect(error.message).toStrictEqual("error");
92
+ expect(error).toBeInstanceOf(ErrorResponse);
93
+ }
94
+ });
95
+ });
@@ -0,0 +1,137 @@
1
+ import "../utils/defaultMock";
2
+ import Skyflow from "skyflow-js";
3
+ import { LiteCheckout } from "../../src";
4
+ import { ErrorResponse } from "../../src/classes/errorResponse";
5
+ import { LiteCheckoutConstructor } from "../../src/classes/liteCheckout";
6
+ import { IErrorResponse } from "../../src/types/responses";
7
+ import { constructorFields } from "../utils/defaultMock";
8
+ import { TokensRequestClass } from "../utils/mockClasses";
9
+
10
+
11
+ declare global {
12
+ interface Window {
13
+ OpenPay: any;
14
+ Skyflow: any;
15
+ }
16
+ }
17
+
18
+ describe("getSkyflowToken", () => {
19
+ let checkoutConstructor: LiteCheckoutConstructor,
20
+ liteCheckout: LiteCheckout,
21
+ fetchSpy: jest.SpyInstance,
22
+ liteCheckoutSpy: jest.SpyInstance;
23
+
24
+ beforeEach(async () => {
25
+ window.fetch = jest.fn();
26
+
27
+ checkoutConstructor = {
28
+ ...constructorFields,
29
+ };
30
+
31
+ liteCheckout = new LiteCheckout(constructorFields);
32
+
33
+ fetchSpy = jest.spyOn(global, "fetch");
34
+ });
35
+
36
+ afterEach(() => {
37
+ jest.restoreAllMocks();
38
+ });
39
+
40
+ it("getSkyflowTokens success", async () => {
41
+ liteCheckout.getVaultToken = jest
42
+ .fn()
43
+ .mockImplementation(() => Promise.resolve("1234"));
44
+
45
+ liteCheckout.getFieldsPromise = jest
46
+ .fn()
47
+ .mockImplementation(() =>
48
+ Promise.resolve(new Array(5).fill(Promise.resolve(true)))
49
+ );
50
+
51
+ liteCheckoutSpy = jest.spyOn(liteCheckout, "getSkyflowTokens");
52
+
53
+ const response = await liteCheckout.getSkyflowTokens({
54
+ ...new TokensRequestClass(),
55
+ });
56
+ expect(response).toStrictEqual("1234");
57
+ expect(liteCheckoutSpy).toHaveBeenCalled();
58
+ });
59
+
60
+ it("getSkyflowTokens empty", async () => {
61
+ liteCheckout.getVaultToken = jest
62
+ .fn()
63
+ .mockImplementation(() => Promise.resolve(""));
64
+
65
+ jest.spyOn(Skyflow, "init").mockImplementation(jest.fn().mockImplementation(() => ({
66
+ container: () => ({
67
+ collect: jest.fn().mockResolvedValue(""),
68
+ }),
69
+ })));
70
+
71
+ liteCheckout.getFieldsPromise = jest
72
+ .fn()
73
+ .mockImplementation(() =>
74
+ Promise.resolve(new Array(5).fill(Promise.resolve(true)))
75
+ );
76
+
77
+ liteCheckoutSpy = jest.spyOn(liteCheckout, "getSkyflowTokens");
78
+
79
+ const response = await liteCheckout.getSkyflowTokens({
80
+ ...new TokensRequestClass(),
81
+ }) as IErrorResponse;
82
+ expect(response).toBeInstanceOf(ErrorResponse);
83
+ expect(response.message).toStrictEqual("Por favor, verifica todos los campos de tu tarjeta");
84
+ });
85
+
86
+ it("getSkyflowTokens error mount fields", async () => {
87
+ liteCheckout.getVaultToken = jest
88
+ .fn()
89
+ .mockImplementation(() => Promise.resolve(""));
90
+
91
+ jest.spyOn(Skyflow, "init").mockImplementation(jest.fn().mockImplementation(() => ({
92
+ container: () => ({
93
+ collect: jest.fn().mockResolvedValue(""),
94
+ }),
95
+ })));
96
+
97
+ liteCheckout.getFieldsPromise = jest
98
+ .fn()
99
+ .mockImplementation(() =>
100
+ new Array(5).fill(false)
101
+ );
102
+
103
+ liteCheckoutSpy = jest.spyOn(liteCheckout, "getSkyflowTokens");
104
+
105
+ const response = await liteCheckout.getSkyflowTokens({
106
+ ...new TokensRequestClass(),
107
+ }) as IErrorResponse;
108
+ expect(response).toBeInstanceOf(ErrorResponse);
109
+ expect(response.message).toStrictEqual("Ocurrió un error al montar los campos de la tarjeta");
110
+ });
111
+
112
+ it("getSkyflowTokens error collect catch", async () => {
113
+ liteCheckout.getVaultToken = jest
114
+ .fn()
115
+ .mockImplementation(() => Promise.resolve("1234"));
116
+
117
+ jest.spyOn(Skyflow, "init").mockImplementation(jest.fn().mockImplementation(() => ({
118
+ container: () => ({
119
+ collect: jest.fn().mockRejectedValue("error"),
120
+ }),
121
+ })));
122
+
123
+ liteCheckout.getFieldsPromise = jest
124
+ .fn()
125
+ .mockImplementation(() =>
126
+ Promise.resolve(new Array(5).fill(Promise.resolve(true)))
127
+ );
128
+
129
+ liteCheckoutSpy = jest.spyOn(liteCheckout, "getSkyflowTokens");
130
+
131
+ const response = (await liteCheckout.getSkyflowTokens({
132
+ ...new TokensRequestClass(),
133
+ })) as IErrorResponse;
134
+ expect(response.message).toStrictEqual("error");
135
+ expect(response).toBeInstanceOf(ErrorResponse);
136
+ });
137
+ });
@@ -0,0 +1,107 @@
1
+ import "../utils/defaultMock";
2
+ import { LiteCheckout } from "../../src";
3
+ import { LiteCheckoutConstructor } from "../../src/classes/liteCheckout";
4
+ import { constructorFields } from "../utils/defaultMock";
5
+
6
+ declare global {
7
+ interface Window {
8
+ OpenPay: any;
9
+ Skyflow: any;
10
+ }
11
+ }
12
+
13
+ describe("getVaultToken", () => {
14
+ let checkoutConstructor: LiteCheckoutConstructor,
15
+ liteCheckout: LiteCheckout,
16
+ fetchSpy: jest.SpyInstance,
17
+ liteCheckoutSpy: jest.SpyInstance;
18
+
19
+ beforeEach(async () => {
20
+ window.fetch = jest.fn();
21
+
22
+ checkoutConstructor = {
23
+ ...constructorFields,
24
+ };
25
+
26
+ liteCheckout = new LiteCheckout(constructorFields);
27
+
28
+ fetchSpy = jest.spyOn(global, "fetch");
29
+ });
30
+
31
+ afterEach(() => {
32
+ jest.restoreAllMocks();
33
+ });
34
+
35
+ it("getVaultToken success", async () => {
36
+ liteCheckoutSpy = jest.spyOn(liteCheckout, "getVaultToken");
37
+
38
+ fetchSpy.mockImplementation(() =>
39
+ Promise.resolve({
40
+ json: () => Promise.resolve({ token: "1234" }),
41
+ ok: true,
42
+ })
43
+ );
44
+
45
+ const response = await liteCheckout.getVaultToken();
46
+ expect(response).toStrictEqual("1234");
47
+ expect(liteCheckoutSpy).toHaveBeenCalled();
48
+ });
49
+
50
+ it("getVaultToken empty", async () => {
51
+ liteCheckoutSpy = jest.spyOn(liteCheckout, "getVaultToken");
52
+
53
+ fetchSpy.mockImplementation(() =>
54
+ Promise.resolve({
55
+ json: () => Promise.resolve(),
56
+ ok: true,
57
+ })
58
+ );
59
+
60
+ const response = await liteCheckout.getVaultToken();
61
+ expect(liteCheckoutSpy).toHaveBeenCalled();
62
+ expect(liteCheckoutSpy).toHaveReturned();
63
+ expect(response).toBeUndefined();
64
+ });
65
+
66
+ it("getVaultToken errorResponse", async () => {
67
+ liteCheckoutSpy = jest.spyOn(liteCheckout, "getVaultToken");
68
+
69
+ fetchSpy.mockImplementation(() =>
70
+ Promise.resolve({
71
+ json: () => Promise.resolve(),
72
+ ok: false,
73
+ status: 400,
74
+ })
75
+ );
76
+
77
+ try {
78
+ await liteCheckout.getVaultToken();
79
+ } catch (e) {
80
+ const error = e as Error;
81
+ expect(liteCheckoutSpy).toHaveBeenCalled();
82
+ expect(liteCheckoutSpy).rejects.toThrow();
83
+ expect(error.message).toStrictEqual(
84
+ "Failed to retrieve bearer token; HTTPCODE: 400"
85
+ );
86
+ expect(error).toBeInstanceOf(Error);
87
+ }
88
+ });
89
+
90
+ it("getVaultToken errorCatch", async () => {
91
+ liteCheckoutSpy = jest.spyOn(liteCheckout, "getVaultToken");
92
+
93
+ fetchSpy.mockRejectedValue("error");
94
+
95
+ try {
96
+ await liteCheckout.getVaultToken();
97
+ } catch (e) {
98
+ const error = e as Error;
99
+ expect(liteCheckoutSpy).toHaveBeenCalled();
100
+ expect(liteCheckoutSpy).rejects.toThrow();
101
+ expect(error.message).toStrictEqual(
102
+ "Failed to retrieve bearer token; error"
103
+ );
104
+ expect(e).toBeInstanceOf(Error);
105
+ }
106
+ });
107
+ });
@@ -0,0 +1,105 @@
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
+ const response = (await liteCheckout.registerCustomerCard(
86
+ "1234", { ...new RegisterCustomerCardRequestClass() }
87
+ )) as IErrorResponse;
88
+ expect(response.code).toStrictEqual("400");
89
+ expect(response).toBeInstanceOf(ErrorResponse);
90
+ });
91
+
92
+ it("registerCustomerCard errorCatch", async () => {
93
+ liteCheckoutSpy = jest.spyOn(liteCheckout, "registerCustomerCard");
94
+
95
+ fetchSpy.mockRejectedValue("error");
96
+
97
+ const response = (await liteCheckout.registerCustomerCard(
98
+ "1234", { ...new RegisterCustomerCardRequestClass() }
99
+ )) as IErrorResponse;
100
+ expect(liteCheckoutSpy).toHaveBeenCalled();
101
+ expect(response.message).toStrictEqual("error");
102
+ expect(response.name).toStrictEqual("catch");
103
+ expect(liteCheckoutSpy).rejects.toThrow();
104
+ });
105
+ });