@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.
- package/.gitlab-ci.yml +29 -0
- package/README.md +496 -0
- package/dist/classes/errorResponse.d.ts +9 -0
- package/dist/classes/liteCheckout.d.ts +34 -0
- package/dist/helpers/utils.d.ts +3 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.js +1 -0
- package/dist/types/commons.d.ts +58 -0
- package/dist/types/requests.d.ts +55 -0
- package/dist/types/responses.d.ts +177 -0
- package/dist/types/skyflow.d.ts +17 -0
- package/jest.config.ts +15 -0
- package/package.json +34 -0
- package/rollup.config.js +17 -0
- package/src/classes/errorResponse.ts +17 -0
- package/src/classes/liteCheckout.ts +301 -0
- package/src/helpers/utils.ts +37 -0
- package/src/index.ts +5 -0
- package/src/types/commons.ts +61 -0
- package/src/types/requests.ts +61 -0
- package/src/types/responses.ts +186 -0
- package/src/types/skyflow.ts +17 -0
- package/tests/classes/liteCheckout.test.ts +57 -0
- package/tests/methods/createOrder.test.ts +106 -0
- package/tests/methods/createPayment.test.ts +109 -0
- package/tests/methods/customerRegister.test.ts +106 -0
- package/tests/methods/getBusiness.test.ts +102 -0
- package/tests/methods/getCustomerCards.test.ts +105 -0
- package/tests/methods/getOpenpayDeviceSessionID.test.ts +95 -0
- package/tests/methods/getSkyflowToken.test.ts +137 -0
- package/tests/methods/getVaultToken.test.ts +107 -0
- package/tests/methods/registerCustomerCard.test.ts +105 -0
- package/tests/methods/startCheckoutRouter.test.ts +107 -0
- package/tests/utils/defaultMock.ts +21 -0
- package/tests/utils/mockClasses.ts +540 -0
- package/tsconfig.json +19 -0
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
import { OrderItem } from "./commons";
|
|
2
|
+
import { SkyflowRecord } from "./skyflow";
|
|
3
|
+
|
|
4
|
+
export interface CreateOrderRequest {
|
|
5
|
+
business: string,
|
|
6
|
+
client: string,
|
|
7
|
+
billing_address_id?: string | null,
|
|
8
|
+
shipping_address_id?: string | null,
|
|
9
|
+
amount: number,
|
|
10
|
+
status: string,
|
|
11
|
+
reference: string | number,
|
|
12
|
+
is_oneclick: boolean,
|
|
13
|
+
items: OrderItem[]
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
export type CreatePaymentRequest = {
|
|
17
|
+
business_pk: string | number,
|
|
18
|
+
amount: number,
|
|
19
|
+
date: string,
|
|
20
|
+
order: string | number
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
export type StartCheckoutRequest = {
|
|
24
|
+
card: any,
|
|
25
|
+
name: any,
|
|
26
|
+
last_name: string,
|
|
27
|
+
email_client: any,
|
|
28
|
+
phone_number: any,
|
|
29
|
+
return_url?: string,
|
|
30
|
+
id_product: string,
|
|
31
|
+
quantity_product: number,
|
|
32
|
+
id_ship: string,
|
|
33
|
+
instance_id_ship: string,
|
|
34
|
+
amount: any,
|
|
35
|
+
title_ship: string,
|
|
36
|
+
description: string,
|
|
37
|
+
device_session_id: any,
|
|
38
|
+
token_id: string,
|
|
39
|
+
order_id: any,
|
|
40
|
+
business_id: any,
|
|
41
|
+
payment_id: any,
|
|
42
|
+
source: string,
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
export interface VaultRequest extends SkyflowRecord {
|
|
46
|
+
records: SkyflowRecord[],
|
|
47
|
+
continueOnError?: boolean,
|
|
48
|
+
byot?: "DISABLE" | "ENABLE" | "ENABLE_STRICT"
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
export type RegisterCustomerCardRequest = {
|
|
52
|
+
skyflow_id: string;
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
export type TokensRequest = {
|
|
56
|
+
vault_id: string,
|
|
57
|
+
vault_url: string,
|
|
58
|
+
data: {
|
|
59
|
+
[key: string]: any;
|
|
60
|
+
}
|
|
61
|
+
}
|
|
@@ -0,0 +1,186 @@
|
|
|
1
|
+
import { Business } from "./commons";
|
|
2
|
+
|
|
3
|
+
export interface IErrorResponse extends Error {
|
|
4
|
+
code?: string;
|
|
5
|
+
body?: string;
|
|
6
|
+
}
|
|
7
|
+
|
|
8
|
+
export interface GetBusinessResponse extends Business { }
|
|
9
|
+
|
|
10
|
+
export type GetVaultTokenResponse = {
|
|
11
|
+
token: string;
|
|
12
|
+
};
|
|
13
|
+
|
|
14
|
+
export type CustomerRegisterResponse = {
|
|
15
|
+
id: number | string;
|
|
16
|
+
email: string;
|
|
17
|
+
auth_token: string;
|
|
18
|
+
};
|
|
19
|
+
|
|
20
|
+
export type CreateOrderResponse = {
|
|
21
|
+
id: number | string;
|
|
22
|
+
created: string;
|
|
23
|
+
amount: string;
|
|
24
|
+
status: string;
|
|
25
|
+
payment_method?: string;
|
|
26
|
+
reference?: string;
|
|
27
|
+
is_oneclick: boolean;
|
|
28
|
+
items: {
|
|
29
|
+
description: string;
|
|
30
|
+
product_reference: string;
|
|
31
|
+
quantity: string;
|
|
32
|
+
price_unit: string;
|
|
33
|
+
discount: string;
|
|
34
|
+
taxes: string;
|
|
35
|
+
amount_total: string;
|
|
36
|
+
}[];
|
|
37
|
+
billing_address?: string;
|
|
38
|
+
shipping_address?: string;
|
|
39
|
+
client: {
|
|
40
|
+
email: string;
|
|
41
|
+
name: string;
|
|
42
|
+
first_name: string;
|
|
43
|
+
last_name: string;
|
|
44
|
+
client_profile: {
|
|
45
|
+
gender: string;
|
|
46
|
+
date_birth?: string;
|
|
47
|
+
terms: boolean;
|
|
48
|
+
phone: string;
|
|
49
|
+
};
|
|
50
|
+
};
|
|
51
|
+
};
|
|
52
|
+
|
|
53
|
+
export type CreatePaymentResponse = {
|
|
54
|
+
pk: number | string;
|
|
55
|
+
order?: string;
|
|
56
|
+
amount: string;
|
|
57
|
+
status: string;
|
|
58
|
+
date: string;
|
|
59
|
+
paid_date?: string;
|
|
60
|
+
shipping_address: {
|
|
61
|
+
street: string;
|
|
62
|
+
number: string;
|
|
63
|
+
suburb: string;
|
|
64
|
+
city: {
|
|
65
|
+
name: string;
|
|
66
|
+
};
|
|
67
|
+
state: {
|
|
68
|
+
name: string;
|
|
69
|
+
country: {
|
|
70
|
+
name: string;
|
|
71
|
+
};
|
|
72
|
+
};
|
|
73
|
+
zip_code: string;
|
|
74
|
+
};
|
|
75
|
+
shipping_address_id?: string;
|
|
76
|
+
billing_address: {
|
|
77
|
+
street: string;
|
|
78
|
+
number: string;
|
|
79
|
+
suburb: string;
|
|
80
|
+
city: {
|
|
81
|
+
name: string;
|
|
82
|
+
};
|
|
83
|
+
state: {
|
|
84
|
+
name: string;
|
|
85
|
+
country: {
|
|
86
|
+
name: string;
|
|
87
|
+
};
|
|
88
|
+
};
|
|
89
|
+
zip_code: string;
|
|
90
|
+
};
|
|
91
|
+
billing_address_id?: string;
|
|
92
|
+
client?: string;
|
|
93
|
+
customer_order_reference?: string;
|
|
94
|
+
};
|
|
95
|
+
|
|
96
|
+
export type StartCheckoutResponse = {
|
|
97
|
+
status: number;
|
|
98
|
+
message: string;
|
|
99
|
+
psp_response: {
|
|
100
|
+
id: string;
|
|
101
|
+
authorization: number;
|
|
102
|
+
operation_type: string;
|
|
103
|
+
transaction_type: string;
|
|
104
|
+
status: string;
|
|
105
|
+
conciliated: boolean;
|
|
106
|
+
creation_date: string;
|
|
107
|
+
operation_date: string;
|
|
108
|
+
description: string;
|
|
109
|
+
error_message?: string;
|
|
110
|
+
order_id?: string;
|
|
111
|
+
card: {
|
|
112
|
+
type: string;
|
|
113
|
+
brand: string;
|
|
114
|
+
address?: string;
|
|
115
|
+
card_number: string;
|
|
116
|
+
holder_name: string;
|
|
117
|
+
expiration_year: string;
|
|
118
|
+
expiration_month: string;
|
|
119
|
+
allows_charges: boolean;
|
|
120
|
+
allows_payouts: boolean;
|
|
121
|
+
bank_name: string;
|
|
122
|
+
points_type: string;
|
|
123
|
+
points_card: boolean;
|
|
124
|
+
bank_code: number;
|
|
125
|
+
};
|
|
126
|
+
customer_id: string;
|
|
127
|
+
gateway_card_present: string;
|
|
128
|
+
amount: number;
|
|
129
|
+
fee: {
|
|
130
|
+
amount: number;
|
|
131
|
+
tax: number;
|
|
132
|
+
currency: string;
|
|
133
|
+
};
|
|
134
|
+
payment_method: {
|
|
135
|
+
type: string;
|
|
136
|
+
url: string;
|
|
137
|
+
};
|
|
138
|
+
currency: string;
|
|
139
|
+
method: string;
|
|
140
|
+
object: string;
|
|
141
|
+
};
|
|
142
|
+
transaction_status: string;
|
|
143
|
+
transaction_id: number;
|
|
144
|
+
payment_id: number;
|
|
145
|
+
provider: string;
|
|
146
|
+
next_action: {
|
|
147
|
+
redirect_to_url: {
|
|
148
|
+
url: string;
|
|
149
|
+
return_url: string;
|
|
150
|
+
verify_transaction_status_url: string;
|
|
151
|
+
};
|
|
152
|
+
};
|
|
153
|
+
actions: {
|
|
154
|
+
name: string;
|
|
155
|
+
url: string;
|
|
156
|
+
method: string;
|
|
157
|
+
}[];
|
|
158
|
+
};
|
|
159
|
+
|
|
160
|
+
export type TokensResponse = {
|
|
161
|
+
vaultID: string;
|
|
162
|
+
responses: {
|
|
163
|
+
[key: string]: string;
|
|
164
|
+
}[];
|
|
165
|
+
};
|
|
166
|
+
|
|
167
|
+
export type GetCustomerCardsResponse = {
|
|
168
|
+
user_id: number;
|
|
169
|
+
cards: {
|
|
170
|
+
records: {
|
|
171
|
+
fields: {
|
|
172
|
+
card_number: string;
|
|
173
|
+
cardholder_name: string;
|
|
174
|
+
cvv: string;
|
|
175
|
+
expiration_month: string;
|
|
176
|
+
expiration_year: string;
|
|
177
|
+
skyflow_id: string;
|
|
178
|
+
};
|
|
179
|
+
}[];
|
|
180
|
+
};
|
|
181
|
+
};
|
|
182
|
+
|
|
183
|
+
export type RegisterCustomerCardResponse = {
|
|
184
|
+
skyflow_id: string;
|
|
185
|
+
user_id: number;
|
|
186
|
+
};
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
export type SkyflowRecord = {
|
|
2
|
+
method: string;
|
|
3
|
+
quorum?: boolean;
|
|
4
|
+
tableName: string;
|
|
5
|
+
fields?: {
|
|
6
|
+
[key: string]: string;
|
|
7
|
+
},
|
|
8
|
+
ID?: string,
|
|
9
|
+
tokenization?: boolean,
|
|
10
|
+
batchID?: string,
|
|
11
|
+
redaction?: "DEFAULT" | "REDACTED" | "MASKED" | "PLAIN_TEXT",
|
|
12
|
+
downloadURL?: boolean,
|
|
13
|
+
upsert?: string,
|
|
14
|
+
tokens?: {
|
|
15
|
+
[key: string]: string;
|
|
16
|
+
}
|
|
17
|
+
}
|
|
@@ -0,0 +1,57 @@
|
|
|
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("LiteCheckout", () => {
|
|
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("Has required properties", () => {
|
|
36
|
+
expect(checkoutConstructor).toEqual(constructorFields);
|
|
37
|
+
});
|
|
38
|
+
|
|
39
|
+
it("Can instance LiteCheckout", () => {
|
|
40
|
+
expect(liteCheckout).toBeInstanceOf(LiteCheckout);
|
|
41
|
+
expect(liteCheckout.apiKeyTonder).toEqual(constructorFields.apiKeyTonder);
|
|
42
|
+
expect(liteCheckout.baseUrlTonder).toEqual(constructorFields.baseUrlTonder);
|
|
43
|
+
expect(liteCheckout.signal).toEqual(constructorFields.signal);
|
|
44
|
+
});
|
|
45
|
+
|
|
46
|
+
|
|
47
|
+
|
|
48
|
+
|
|
49
|
+
|
|
50
|
+
|
|
51
|
+
|
|
52
|
+
|
|
53
|
+
|
|
54
|
+
|
|
55
|
+
|
|
56
|
+
|
|
57
|
+
});
|
|
@@ -0,0 +1,106 @@
|
|
|
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 { OrderResponseClass, OrderClass } from "../utils/mockClasses";
|
|
8
|
+
|
|
9
|
+
declare global {
|
|
10
|
+
interface Window {
|
|
11
|
+
OpenPay: any;
|
|
12
|
+
Skyflow: any;
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
describe("createOrder", () => {
|
|
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("createOrder success", async () => {
|
|
39
|
+
liteCheckoutSpy = jest.spyOn(liteCheckout, "createOrder");
|
|
40
|
+
|
|
41
|
+
fetchSpy.mockImplementation(() =>
|
|
42
|
+
Promise.resolve({
|
|
43
|
+
json: () => Promise.resolve([{ ...new OrderResponseClass() }]),
|
|
44
|
+
ok: true,
|
|
45
|
+
})
|
|
46
|
+
);
|
|
47
|
+
|
|
48
|
+
const response = await liteCheckout.createOrder({
|
|
49
|
+
...new OrderClass(),
|
|
50
|
+
});
|
|
51
|
+
|
|
52
|
+
expect(response).toStrictEqual([{ ...new OrderResponseClass() }]);
|
|
53
|
+
expect(liteCheckoutSpy).toHaveBeenCalled();
|
|
54
|
+
expect(liteCheckoutSpy).toHaveBeenCalledWith({ ...new OrderClass() });
|
|
55
|
+
});
|
|
56
|
+
|
|
57
|
+
it("createOrder empty", async () => {
|
|
58
|
+
liteCheckoutSpy = jest.spyOn(liteCheckout, "createOrder");
|
|
59
|
+
|
|
60
|
+
fetchSpy.mockImplementation(() =>
|
|
61
|
+
Promise.resolve({
|
|
62
|
+
json: () => Promise.resolve(),
|
|
63
|
+
ok: true,
|
|
64
|
+
})
|
|
65
|
+
);
|
|
66
|
+
|
|
67
|
+
const response = await liteCheckout.createOrder({
|
|
68
|
+
...new OrderClass(),
|
|
69
|
+
});
|
|
70
|
+
expect(liteCheckoutSpy).toHaveBeenCalled();
|
|
71
|
+
expect(liteCheckoutSpy).toHaveReturned();
|
|
72
|
+
expect(response).toBeUndefined();
|
|
73
|
+
});
|
|
74
|
+
|
|
75
|
+
it("createOrder errorResponse", async () => {
|
|
76
|
+
liteCheckoutSpy = jest.spyOn(liteCheckout, "createOrder");
|
|
77
|
+
|
|
78
|
+
fetchSpy.mockImplementation(() =>
|
|
79
|
+
Promise.resolve({
|
|
80
|
+
json: () => Promise.resolve(),
|
|
81
|
+
ok: false,
|
|
82
|
+
status: 400,
|
|
83
|
+
})
|
|
84
|
+
);
|
|
85
|
+
|
|
86
|
+
const response = (await liteCheckout.createOrder({
|
|
87
|
+
...new OrderClass(),
|
|
88
|
+
})) as IErrorResponse;
|
|
89
|
+
expect(response.code).toStrictEqual("400");
|
|
90
|
+
expect(response).toBeInstanceOf(ErrorResponse);
|
|
91
|
+
});
|
|
92
|
+
|
|
93
|
+
it("createOrder errorCatch", async () => {
|
|
94
|
+
liteCheckoutSpy = jest.spyOn(liteCheckout, "createOrder");
|
|
95
|
+
|
|
96
|
+
fetchSpy.mockRejectedValue("error");
|
|
97
|
+
|
|
98
|
+
const response = (await liteCheckout.createOrder({
|
|
99
|
+
...new OrderClass(),
|
|
100
|
+
})) as IErrorResponse;
|
|
101
|
+
expect(liteCheckoutSpy).toHaveBeenCalled();
|
|
102
|
+
expect(response.message).toStrictEqual("error");
|
|
103
|
+
expect(response.name).toStrictEqual("catch");
|
|
104
|
+
expect(liteCheckoutSpy).rejects.toThrow();
|
|
105
|
+
});
|
|
106
|
+
});
|
|
@@ -0,0 +1,109 @@
|
|
|
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 { CreatePaymentResponseClass, CreatePaymentRequestClass } from "../utils/mockClasses";
|
|
8
|
+
|
|
9
|
+
|
|
10
|
+
declare global {
|
|
11
|
+
interface Window {
|
|
12
|
+
OpenPay: any;
|
|
13
|
+
Skyflow: any;
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
describe("createPayment", () => {
|
|
18
|
+
let checkoutConstructor: LiteCheckoutConstructor,
|
|
19
|
+
liteCheckout: LiteCheckout,
|
|
20
|
+
fetchSpy: jest.SpyInstance,
|
|
21
|
+
liteCheckoutSpy: jest.SpyInstance;
|
|
22
|
+
|
|
23
|
+
beforeEach(async () => {
|
|
24
|
+
window.fetch = jest.fn();
|
|
25
|
+
|
|
26
|
+
checkoutConstructor = {
|
|
27
|
+
...constructorFields,
|
|
28
|
+
};
|
|
29
|
+
|
|
30
|
+
liteCheckout = new LiteCheckout(constructorFields);
|
|
31
|
+
|
|
32
|
+
fetchSpy = jest.spyOn(global, "fetch");
|
|
33
|
+
});
|
|
34
|
+
|
|
35
|
+
afterEach(() => {
|
|
36
|
+
jest.restoreAllMocks();
|
|
37
|
+
});
|
|
38
|
+
|
|
39
|
+
it("createPayment success", async () => {
|
|
40
|
+
liteCheckoutSpy = jest.spyOn(liteCheckout, "createPayment");
|
|
41
|
+
|
|
42
|
+
fetchSpy.mockImplementation(() =>
|
|
43
|
+
Promise.resolve({
|
|
44
|
+
json: () => Promise.resolve([{ ...new CreatePaymentResponseClass() }]),
|
|
45
|
+
ok: true,
|
|
46
|
+
})
|
|
47
|
+
);
|
|
48
|
+
|
|
49
|
+
const response = await liteCheckout.createPayment({
|
|
50
|
+
...new CreatePaymentRequestClass(),
|
|
51
|
+
});
|
|
52
|
+
|
|
53
|
+
expect(response).toStrictEqual([{ ...new CreatePaymentResponseClass() }]);
|
|
54
|
+
expect(liteCheckoutSpy).toHaveBeenCalled();
|
|
55
|
+
expect(liteCheckoutSpy).toHaveBeenCalledWith({
|
|
56
|
+
...new CreatePaymentRequestClass(),
|
|
57
|
+
});
|
|
58
|
+
});
|
|
59
|
+
|
|
60
|
+
it("createPayment empty", async () => {
|
|
61
|
+
liteCheckoutSpy = jest.spyOn(liteCheckout, "createPayment");
|
|
62
|
+
|
|
63
|
+
fetchSpy.mockImplementation(() =>
|
|
64
|
+
Promise.resolve({
|
|
65
|
+
json: () => Promise.resolve(),
|
|
66
|
+
ok: true,
|
|
67
|
+
})
|
|
68
|
+
);
|
|
69
|
+
|
|
70
|
+
const response = await liteCheckout.createPayment({
|
|
71
|
+
...new CreatePaymentRequestClass(),
|
|
72
|
+
});
|
|
73
|
+
expect(liteCheckoutSpy).toHaveBeenCalled();
|
|
74
|
+
expect(liteCheckoutSpy).toHaveReturned();
|
|
75
|
+
expect(response).toBeUndefined();
|
|
76
|
+
});
|
|
77
|
+
|
|
78
|
+
it("createPayment errorResponse", async () => {
|
|
79
|
+
liteCheckoutSpy = jest.spyOn(liteCheckout, "createPayment");
|
|
80
|
+
|
|
81
|
+
fetchSpy.mockImplementation(() =>
|
|
82
|
+
Promise.resolve({
|
|
83
|
+
json: () => Promise.resolve(),
|
|
84
|
+
ok: false,
|
|
85
|
+
status: 400,
|
|
86
|
+
})
|
|
87
|
+
);
|
|
88
|
+
|
|
89
|
+
const response = (await liteCheckout.createPayment({
|
|
90
|
+
...new CreatePaymentRequestClass(),
|
|
91
|
+
})) as IErrorResponse;
|
|
92
|
+
expect(response.code).toStrictEqual("400");
|
|
93
|
+
expect(response).toBeInstanceOf(ErrorResponse);
|
|
94
|
+
});
|
|
95
|
+
|
|
96
|
+
it("createPayment errorCatch", async () => {
|
|
97
|
+
liteCheckoutSpy = jest.spyOn(liteCheckout, "createPayment");
|
|
98
|
+
|
|
99
|
+
fetchSpy.mockRejectedValue("error");
|
|
100
|
+
|
|
101
|
+
const response = (await liteCheckout.createPayment({
|
|
102
|
+
...new CreatePaymentRequestClass(),
|
|
103
|
+
})) as IErrorResponse;
|
|
104
|
+
expect(liteCheckoutSpy).toHaveBeenCalled();
|
|
105
|
+
expect(response.message).toStrictEqual("error");
|
|
106
|
+
expect(response.name).toStrictEqual("catch");
|
|
107
|
+
expect(liteCheckoutSpy).rejects.toThrow();
|
|
108
|
+
});
|
|
109
|
+
});
|
|
@@ -0,0 +1,106 @@
|
|
|
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
|
+
|
|
10
|
+
declare global {
|
|
11
|
+
interface Window {
|
|
12
|
+
OpenPay: any;
|
|
13
|
+
Skyflow: any;
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
describe("customerRegister", () => {
|
|
18
|
+
let checkoutConstructor: LiteCheckoutConstructor,
|
|
19
|
+
liteCheckout: LiteCheckout,
|
|
20
|
+
fetchSpy: jest.SpyInstance,
|
|
21
|
+
liteCheckoutSpy: jest.SpyInstance;
|
|
22
|
+
|
|
23
|
+
beforeEach(async () => {
|
|
24
|
+
window.fetch = jest.fn();
|
|
25
|
+
|
|
26
|
+
checkoutConstructor = {
|
|
27
|
+
...constructorFields,
|
|
28
|
+
};
|
|
29
|
+
|
|
30
|
+
liteCheckout = new LiteCheckout(constructorFields);
|
|
31
|
+
|
|
32
|
+
fetchSpy = jest.spyOn(global, "fetch");
|
|
33
|
+
});
|
|
34
|
+
|
|
35
|
+
afterEach(() => {
|
|
36
|
+
jest.restoreAllMocks();
|
|
37
|
+
});
|
|
38
|
+
|
|
39
|
+
it("customerRegister success", async () => {
|
|
40
|
+
liteCheckoutSpy = jest.spyOn(liteCheckout, "customerRegister");
|
|
41
|
+
|
|
42
|
+
fetchSpy.mockImplementation(() =>
|
|
43
|
+
Promise.resolve({
|
|
44
|
+
json: () =>
|
|
45
|
+
Promise.resolve({
|
|
46
|
+
...new BusinessClass(),
|
|
47
|
+
}),
|
|
48
|
+
ok: true,
|
|
49
|
+
})
|
|
50
|
+
);
|
|
51
|
+
|
|
52
|
+
const response = await liteCheckout.customerRegister("email@gmail.com");
|
|
53
|
+
|
|
54
|
+
expect(response).toStrictEqual({ ...new BusinessClass() });
|
|
55
|
+
expect(liteCheckoutSpy).toHaveBeenCalled();
|
|
56
|
+
expect(liteCheckoutSpy).toHaveBeenCalledWith("email@gmail.com");
|
|
57
|
+
});
|
|
58
|
+
|
|
59
|
+
it("customerRegister empty", async () => {
|
|
60
|
+
liteCheckoutSpy = jest.spyOn(liteCheckout, "customerRegister");
|
|
61
|
+
|
|
62
|
+
fetchSpy.mockImplementation(() =>
|
|
63
|
+
Promise.resolve({
|
|
64
|
+
json: () => Promise.resolve(),
|
|
65
|
+
ok: true,
|
|
66
|
+
})
|
|
67
|
+
);
|
|
68
|
+
|
|
69
|
+
const response = await liteCheckout.customerRegister("email@gmail.com");
|
|
70
|
+
expect(liteCheckoutSpy).toHaveBeenCalled();
|
|
71
|
+
expect(liteCheckoutSpy).toHaveReturned();
|
|
72
|
+
expect(response).toBeUndefined();
|
|
73
|
+
});
|
|
74
|
+
|
|
75
|
+
it("customerRegister errorResponse", async () => {
|
|
76
|
+
liteCheckoutSpy = jest.spyOn(liteCheckout, "customerRegister");
|
|
77
|
+
|
|
78
|
+
fetchSpy.mockImplementation(() =>
|
|
79
|
+
Promise.resolve({
|
|
80
|
+
json: () => Promise.resolve(),
|
|
81
|
+
ok: false,
|
|
82
|
+
status: 400,
|
|
83
|
+
})
|
|
84
|
+
);
|
|
85
|
+
|
|
86
|
+
const response = (await liteCheckout.customerRegister(
|
|
87
|
+
"email@gmail.com"
|
|
88
|
+
)) as IErrorResponse;
|
|
89
|
+
expect(response.code).toStrictEqual("400");
|
|
90
|
+
expect(response).toBeInstanceOf(ErrorResponse);
|
|
91
|
+
});
|
|
92
|
+
|
|
93
|
+
it("customerRegister errorCatch", async () => {
|
|
94
|
+
liteCheckoutSpy = jest.spyOn(liteCheckout, "customerRegister");
|
|
95
|
+
|
|
96
|
+
fetchSpy.mockRejectedValue("error");
|
|
97
|
+
|
|
98
|
+
const response = (await liteCheckout.customerRegister(
|
|
99
|
+
"email@gmail.com"
|
|
100
|
+
)) as IErrorResponse;
|
|
101
|
+
expect(liteCheckoutSpy).toHaveBeenCalled();
|
|
102
|
+
expect(response.message).toStrictEqual("error");
|
|
103
|
+
expect(response.name).toStrictEqual("catch");
|
|
104
|
+
expect(liteCheckoutSpy).rejects.toThrow();
|
|
105
|
+
});
|
|
106
|
+
});
|