@rudderstack/integrations-lib 0.2.30 → 0.2.31

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 (70) hide show
  1. package/build/constants.d.ts +5 -64
  2. package/build/constants.d.ts.map +1 -1
  3. package/build/constants.js +1 -1
  4. package/build/logger.d.ts +1 -1
  5. package/build/logger.d.ts.map +1 -1
  6. package/build/logger.js +1 -1
  7. package/build/sdks/googleAdsRestAPI/googleAds.d.ts +2 -2
  8. package/build/sdks/googleAdsRestAPI/googleAds.d.ts.map +1 -1
  9. package/build/sdks/googleAdsRestAPI/googleAds.js +2 -2
  10. package/build/sdks/sfmc/index.d.ts +1 -1
  11. package/build/sdks/sfmc/index.d.ts.map +1 -1
  12. package/build/sdks/sfmc/index.js +11 -3
  13. package/build/sdks/sfmc/type.d.ts +5 -0
  14. package/build/sdks/sfmc/type.d.ts.map +1 -1
  15. package/build/sdks/sfmc/type.js +1 -1
  16. package/build/sdks/sfmc/utils.d.ts +6 -5
  17. package/build/sdks/sfmc/utils.d.ts.map +1 -1
  18. package/build/sdks/sfmc/utils.js +6 -6
  19. package/build/sdks/zoho/types.d.ts +2 -20
  20. package/build/sdks/zoho/types.d.ts.map +1 -1
  21. package/build/sdks/zoho/types.js +1 -1
  22. package/build/utils/misc.d.ts +7 -7
  23. package/build/utils/misc.d.ts.map +1 -1
  24. package/build/utils/misc.js +1 -1
  25. package/build/utils/request.d.ts +8 -1
  26. package/build/utils/request.d.ts.map +1 -1
  27. package/build/utils/request.js +1 -1
  28. package/package.json +2 -1
  29. package/build/lib/set-value/set-value.test.d.ts +0 -2
  30. package/build/lib/set-value/set-value.test.d.ts.map +0 -1
  31. package/build/lib/set-value/set-value.test.js +0 -105
  32. package/build/network/clients/axios_client.test.d.ts +0 -2
  33. package/build/network/clients/axios_client.test.d.ts.map +0 -1
  34. package/build/network/clients/axios_client.test.js +0 -276
  35. package/build/network/factory.test.d.ts +0 -2
  36. package/build/network/factory.test.d.ts.map +0 -1
  37. package/build/network/factory.test.js +0 -51
  38. package/build/sdks/customerio_audience/index.test.d.ts +0 -2
  39. package/build/sdks/customerio_audience/index.test.d.ts.map +0 -1
  40. package/build/sdks/customerio_audience/index.test.js +0 -121
  41. package/build/sdks/googleAdsRestAPI/googleAds.test.d.ts +0 -2
  42. package/build/sdks/googleAdsRestAPI/googleAds.test.d.ts.map +0 -1
  43. package/build/sdks/googleAdsRestAPI/googleAds.test.js +0 -771
  44. package/build/sdks/sfmc/index.test.d.ts +0 -2
  45. package/build/sdks/sfmc/index.test.d.ts.map +0 -1
  46. package/build/sdks/sfmc/index.test.js +0 -751
  47. package/build/sdks/sfmc/utils.test.d.ts +0 -2
  48. package/build/sdks/sfmc/utils.test.d.ts.map +0 -1
  49. package/build/sdks/sfmc/utils.test.js +0 -32
  50. package/build/sdks/zoho/zoho.test.d.ts +0 -2
  51. package/build/sdks/zoho/zoho.test.d.ts.map +0 -1
  52. package/build/sdks/zoho/zoho.test.js +0 -472
  53. package/build/structured-logger.test.d.ts +0 -2
  54. package/build/structured-logger.test.d.ts.map +0 -1
  55. package/build/structured-logger.test.js +0 -93
  56. package/build/utils/json-schema-generator.test.d.ts +0 -2
  57. package/build/utils/json-schema-generator.test.d.ts.map +0 -1
  58. package/build/utils/json-schema-generator.test.js +0 -368
  59. package/build/utils/misc.test.d.ts +0 -2
  60. package/build/utils/misc.test.d.ts.map +0 -1
  61. package/build/utils/misc.test.js +0 -2260
  62. package/build/utils/request.test.d.ts +0 -2
  63. package/build/utils/request.test.d.ts.map +0 -1
  64. package/build/utils/request.test.js +0 -72
  65. package/build/utils/tests.test.d.ts +0 -2
  66. package/build/utils/tests.test.d.ts.map +0 -1
  67. package/build/utils/tests.test.js +0 -89
  68. package/build/utils/zod.test.d.ts +0 -2
  69. package/build/utils/zod.test.d.ts.map +0 -1
  70. package/build/utils/zod.test.js +0 -48
@@ -1,276 +0,0 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
- Object.defineProperty(o, "default", { enumerable: true, value: v });
15
- }) : function(o, v) {
16
- o["default"] = v;
17
- });
18
- var __importStar = (this && this.__importStar) || (function () {
19
- var ownKeys = function(o) {
20
- ownKeys = Object.getOwnPropertyNames || function (o) {
21
- var ar = [];
22
- for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
- return ar;
24
- };
25
- return ownKeys(o);
26
- };
27
- return function (mod) {
28
- if (mod && mod.__esModule) return mod;
29
- var result = {};
30
- if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
- __setModuleDefault(result, mod);
32
- return result;
33
- };
34
- })();
35
- var __importDefault = (this && this.__importDefault) || function (mod) {
36
- return (mod && mod.__esModule) ? mod : { "default": mod };
37
- };
38
- Object.defineProperty(exports, "__esModule", { value: true });
39
- const axios_1 = __importStar(require("axios"));
40
- const axios_mock_adapter_1 = __importDefault(require("axios-mock-adapter"));
41
- const axios_client_1 = require("./axios_client"); // Import the AxiosClient class
42
- // Mock Axios for testing
43
- jest.mock('axios', () => ({
44
- ...jest.requireActual('axios'),
45
- create: jest.fn().mockReturnValue(jest.requireActual('axios')),
46
- }));
47
- // Test cases
48
- describe('AxiosClient', () => {
49
- let axiosClient;
50
- let mockAxios;
51
- beforeEach(() => {
52
- mockAxios = new axios_mock_adapter_1.default(axios_1.default); // Create a MockAdapter for Axios
53
- axiosClient = new axios_client_1.AxiosClient(); // Create a new AxiosClient instance for each test
54
- });
55
- afterEach(() => {
56
- mockAxios.restore();
57
- });
58
- describe('happy flow tests', () => {
59
- // Scenario 1: GET request and receive a response
60
- it('should make a GET request and receive a response', async () => {
61
- // Mock the GET request using axios-mock-adapter
62
- mockAxios.onGet('https://example.com').reply(200, 'GET response');
63
- const response = (await axiosClient.get('https://example.com'));
64
- expect(response.type).toBe('success');
65
- expect(response.statusCode).toBe(200);
66
- expect(response.responseBody).toBe('GET response');
67
- });
68
- // Scenario 2: POST request and receive a response
69
- it('should make a POST request and receive a response', async () => {
70
- // Mock the axios.post method to return a response
71
- mockAxios.onPost('https://example.com').reply(201, 'POST response');
72
- const response = (await axiosClient.post('https://example.com', {
73
- foo: 'bar',
74
- }, { timeout: 1000 }));
75
- expect(response.type).toBe('success');
76
- expect(response.statusCode).toBe(201);
77
- expect(response.responseBody).toBe('POST response');
78
- });
79
- // Scenario 3: PUT request and receive a response
80
- it('should make a PUT request and receive a response', async () => {
81
- // Mock the axios.put method to return a response
82
- mockAxios.onPut('https://example.com').reply(204);
83
- const response = (await axiosClient.put('https://example.com', {
84
- foo: 'bar',
85
- }, { timeout: 100 }));
86
- expect(response.type).toBe('success');
87
- expect(response.statusCode).toBe(204);
88
- expect(response.responseBody).toBeUndefined(); // No response body for PUT
89
- });
90
- // Scenario 4: PATCH request and receive a response
91
- it('should make a PATCH request and receive a response', async () => {
92
- // Mock the axios.patch method to return a response
93
- mockAxios.onPatch('https://example.com').reply(200, 'PATCH response');
94
- const response = (await axiosClient.patch('https://example.com', {
95
- foo: 'bar',
96
- }, { timeout: 500 }));
97
- expect(response.type).toBe('success');
98
- expect(response.statusCode).toBe(200);
99
- expect(response.responseBody).toBe('PATCH response');
100
- });
101
- // Scenario 5: DELETE request and receive a response
102
- it('should make a DELETE request and receive a response', async () => {
103
- // Mock the axios.delete method to return a response
104
- mockAxios.onDelete('https://example.com').reply(204);
105
- const response = (await axiosClient.delete('https://example.com', {
106
- timeout: 420,
107
- }));
108
- expect(response.type).toBe('success');
109
- expect(response.statusCode).toBe(204);
110
- expect(response.responseBody).toBeUndefined(); // No response body for DELETE
111
- });
112
- // Scenario 6: GET request with a response parser
113
- it('should make a GET request with a response parser', async () => {
114
- // Mock the GET request using axios-mock-adapter
115
- mockAxios.onGet('https://example.com').reply(200, 'GET response');
116
- const response = (await axiosClient.get('https://example.com', {}, (data) => `Parsed ${data}`));
117
- expect(response.type).toBe('success');
118
- expect(response.statusCode).toBe(200);
119
- expect(response.responseBody).toBe('Parsed GET response');
120
- });
121
- // Scenario 7: POST request with a response parser
122
- it('should make a POST request with a response parser', async () => {
123
- // Mock the axios.post method to return a response
124
- mockAxios.onPost('https://example.com').reply(201, 'POST response');
125
- const response = (await axiosClient.post('https://example.com', {
126
- foo: 'bar',
127
- }, {}, (data) => `Parsed ${data}`));
128
- expect(response.type).toBe('success');
129
- expect(response.statusCode).toBe(201);
130
- expect(response.responseBody).toBe('Parsed POST response');
131
- });
132
- // Scenario 8: PUT request with a response parser
133
- it('should make a PUT request with a response parser', async () => {
134
- // Mock the axios.put method to return a response
135
- mockAxios.onPut('https://example.com').reply(204);
136
- const response = (await axiosClient.put('https://example.com', {
137
- foo: 'bar',
138
- }, {}, (data) => `Parsed ${data}`));
139
- expect(response.type).toBe('success');
140
- expect(response.statusCode).toBe(204);
141
- expect(response.responseBody).toBe('Parsed undefined'); // No response body for PUT
142
- });
143
- // Scenario 9: PATCH request with a response parser
144
- it('should make a PATCH request with a response parser', async () => {
145
- // Mock the axios.patch method to return a response
146
- mockAxios.onPatch('https://example.com').reply(200, 'PATCH response');
147
- const response = (await axiosClient.patch('https://example.com', {
148
- foo: 'bar',
149
- }, {}, (data) => `Parsed ${data}`));
150
- expect(response.type).toBe('success');
151
- expect(response.statusCode).toBe(200);
152
- expect(response.responseBody).toBe('Parsed PATCH response');
153
- });
154
- // Scenario 10: DELETE request with a response parser
155
- it('should make a DELETE request with a response parser', async () => {
156
- // Mock the axios.delete method to return a response
157
- mockAxios.onDelete('https://example.com').reply(204);
158
- const response = (await axiosClient.delete('https://example.com', {}, (data) => `Parsed ${data}`));
159
- expect(response.type).toBe('success');
160
- expect(response.statusCode).toBe(204);
161
- expect(response.responseBody).toBe('Parsed undefined'); // No response body for DELETE
162
- });
163
- // Scenario 11: GET request with headers
164
- it('should make a GET request with headers', async () => {
165
- // Mock the GET request using axios-mock-adapter
166
- mockAxios.onGet('https://example.com').reply((config) => {
167
- expect(config.headers.foo).toEqual('bar');
168
- return [
169
- 200,
170
- 'GET response',
171
- {
172
- Authorization: `Bearer Token`,
173
- 'Content-type': 'application/x-www-form-urlencoded',
174
- },
175
- ];
176
- });
177
- const response = (await axiosClient.get('https://example.com', {
178
- headers: { foo: 'bar' },
179
- }));
180
- expect(response.type).toBe('success');
181
- expect(response.statusCode).toBe(200);
182
- expect(response.responseBody).toBe('GET response');
183
- });
184
- // other happy flow tests
185
- // Scenario 12:
186
- });
187
- describe('error flow tests', () => {
188
- // Scenario 1: GET request and receive a network error
189
- it('should make a GET request and receive a network error', async () => {
190
- // Mock the GET request using axios-mock-adapter
191
- mockAxios.onGet('https://example.com').abortRequest();
192
- const response = (await axiosClient.get('https://example.com'));
193
- expect(response.type).toBe('client-error');
194
- expect(response.statusCode).toBe(500);
195
- expect(response.message).toBe('Unknown Error:Request aborted');
196
- });
197
- // should handle timeout errors
198
- it('should make a GET request and receive a timeout error', async () => {
199
- // Mock the GET request using axios-mock-adapter
200
- mockAxios.onGet('https://example.com').timeout();
201
- const response = (await axiosClient.get('https://example.com'));
202
- expect(response.type).toBe('client-error');
203
- expect(response.statusCode).toBe(500);
204
- expect(response.message).toBe('Unknown Error:timeout of 0ms exceeded');
205
- });
206
- it('should make a GET request and receive a network error', async () => {
207
- // Mock the GET request using axios-mock-adapter
208
- mockAxios.onGet('https://example.com').networkError();
209
- const response = (await axiosClient.get('https://example.com'));
210
- expect(response.type).toBe('client-error');
211
- expect(response.statusCode).toBe(500);
212
- expect(response.message).toBe('Network Error');
213
- });
214
- // should handle application errors (4xx)
215
- it('should make a GET request and receive a 400 error', async () => {
216
- // Mock the GET request using axios-mock-adapter
217
- mockAxios.onGet('https://example.com').reply(400, 'Bad Request Received');
218
- const response = (await axiosClient.get('https://example.com'));
219
- expect(response.type).toBe('application-error');
220
- expect(response.statusCode).toBe(400);
221
- expect(response.responseBody).toBe('Bad Request Received');
222
- });
223
- it('should make a GET request and receive a 500 error when errored with unknown code', async () => {
224
- // Mock the GET request using axios-mock-adapter
225
- mockAxios.onGet('https://example.com').reply((config) => {
226
- const err = axios_1.AxiosError.from('my error message', 'MY_CODE', config);
227
- return Promise.reject(err);
228
- });
229
- const response = (await axiosClient.get('https://example.com'));
230
- expect(response.type).toBe('client-error');
231
- expect(response.statusCode).toBe(500);
232
- expect(response.message).toBe(`Unknown Error:undefined`);
233
- });
234
- it('should make a GET request and receive a 500 error when errored with EACCES code', async () => {
235
- // Mock the GET request using axios-mock-adapter
236
- mockAxios.onGet('https://example.com').reply((config) => {
237
- const err = axios_1.AxiosError.from('my error message', 'EACCES', config);
238
- return Promise.reject(err);
239
- });
240
- const response = (await axiosClient.get('https://example.com'));
241
- expect(response.type).toBe('client-error');
242
- expect(response.statusCode).toBe(400);
243
- expect(response.message).toBe('[EACCES] :: Permission denied');
244
- });
245
- // should handle application errors (5xx)
246
- it('should make a GET request and receive a 500 error', async () => {
247
- // Mock the GET request using axios-mock-adapter
248
- mockAxios.onGet('https://example.com').reply(500, 'Internal Server Error');
249
- const response = (await axiosClient.get('https://example.com'));
250
- expect(response.type).toBe('application-error');
251
- expect(response.statusCode).toBe(500);
252
- expect(response.responseBody).toBe('Internal Server Error');
253
- });
254
- // should handle unexpected errors
255
- it('should make a GET request and receive an unexpected error', async () => {
256
- // Mock the GET request using axios-mock-adapter
257
- mockAxios.onGet('https://example.com').reply(200, 'GET response');
258
- const response = (await axiosClient.get('https://example.com', {}, (_data) => {
259
- throw new Error('Unexpected Error');
260
- }));
261
- expect(response.type).toBe('client-error');
262
- expect(response.statusCode).toBe(500);
263
- expect(response.message).toBe('Failed to parse response data: Unexpected Error');
264
- });
265
- // should handle empty response body
266
- it('should make a GET request and receive an empty response body', async () => {
267
- // Mock the GET request using axios-mock-adapter
268
- mockAxios.onGet('https://example.com').reply(200);
269
- const response = (await axiosClient.get('https://example.com'));
270
- expect(response.type).toBe('success');
271
- expect(response.statusCode).toBe(200);
272
- expect(response.responseBody).toBeUndefined();
273
- });
274
- });
275
- });
276
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXhpb3NfY2xpZW50LnRlc3QuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbmV0d29yay9jbGllbnRzL2F4aW9zX2NsaWVudC50ZXN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsK0NBQTBDO0FBQzFDLDRFQUE2QztBQUM3QyxpREFBNkMsQ0FBQywrQkFBK0I7QUFPN0UseUJBQXlCO0FBQ3pCLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFLEdBQUcsRUFBRSxDQUFDLENBQUM7SUFDeEIsR0FBSSxJQUFJLENBQUMsYUFBYSxDQUFDLE9BQU8sQ0FBWTtJQUMxQyxNQUFNLEVBQUUsSUFBSSxDQUFDLEVBQUUsRUFBRSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLE9BQU8sQ0FBQyxDQUFDO0NBQy9ELENBQUMsQ0FBQyxDQUFDO0FBRUosYUFBYTtBQUNiLFFBQVEsQ0FBQyxhQUFhLEVBQUUsR0FBRyxFQUFFO0lBQzNCLElBQUksV0FBd0IsQ0FBQztJQUM3QixJQUFJLFNBQVMsQ0FBQztJQUVkLFVBQVUsQ0FBQyxHQUFHLEVBQUU7UUFDZCxTQUFTLEdBQUcsSUFBSSw0QkFBVyxDQUFDLGVBQUssQ0FBQyxDQUFDLENBQUMsaUNBQWlDO1FBQ3JFLFdBQVcsR0FBRyxJQUFJLDBCQUFXLEVBQUUsQ0FBQyxDQUFDLGtEQUFrRDtJQUNyRixDQUFDLENBQUMsQ0FBQztJQUVILFNBQVMsQ0FBQyxHQUFHLEVBQUU7UUFDYixTQUFTLENBQUMsT0FBTyxFQUFFLENBQUM7SUFDdEIsQ0FBQyxDQUFDLENBQUM7SUFFSCxRQUFRLENBQUMsa0JBQWtCLEVBQUUsR0FBRyxFQUFFO1FBQ2hDLGlEQUFpRDtRQUNqRCxFQUFFLENBQUMsa0RBQWtELEVBQUUsS0FBSyxJQUFJLEVBQUU7WUFDaEUsZ0RBQWdEO1lBQ2hELFNBQVMsQ0FBQyxLQUFLLENBQUMs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Q0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDLENBQUMsQ0FBQztBQUNMLENBQUMsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGF4aW9zLCB7IEF4aW9zRXJyb3IgfSBmcm9tICdheGlvcyc7XG5pbXBvcnQgTW9ja0FkYXB0ZXIgZnJvbSAnYXhpb3MtbW9jay1hZGFwdGVyJztcbmltcG9ydCB7IEF4aW9zQ2xpZW50IH0gZnJvbSAnLi9heGlvc19jbGllbnQnOyAvLyBJbXBvcnQgdGhlIEF4aW9zQ2xpZW50IGNsYXNzXG5pbXBvcnQge1xuICBBcHBsaWNhdGlvbkVycm9yQXBpUmVzcG9uc2UsXG4gIENsaWVudEVycm9yQXBpUmVzcG9uc2UsXG4gIFN1Y2Nlc3NmdWxBcGlSZXNwb25zZSxcbn0gZnJvbSAnLi90eXBlcyc7XG5cbi8vIE1vY2sgQXhpb3MgZm9yIHRlc3Rpbmdcbmplc3QubW9jaygnYXhpb3MnLCAoKSA9PiAoe1xuICAuLi4oamVzdC5yZXF1aXJlQWN0dWFsKCdheGlvcycpIGFzIG9iamVjdCksXG4gIGNyZWF0ZTogamVzdC5mbigpLm1vY2tSZXR1cm5WYWx1ZShqZXN0LnJlcXVpcmVBY3R1YWwoJ2F4aW9zJykpLFxufSkpO1xuXG4vLyBUZXN0IGNhc2VzXG5kZXNjcmliZSgnQXhpb3NDbGllbnQnLCAoKSA9PiB7XG4gIGxldCBheGlvc0NsaWVudDogQXhpb3NDbGllbnQ7XG4gIGxldCBtb2NrQXhpb3M7XG5cbiAgYmVmb3JlRWFjaCgoKSA9PiB7XG4gICAgbW9ja0F4aW9zID0gbmV3IE1vY2tBZGFwdGVyKGF4aW9zKTsgLy8gQ3JlYXRlIGEgTW9ja0FkYXB0ZXIgZm9yIEF4aW9zXG4gICAgYXhpb3NDbGllbnQgPSBuZXcgQXhpb3NDbGllbnQoKTsgLy8gQ3JlYXRlIGEgbmV3IEF4aW9zQ2xpZW50IGluc3RhbmNlIGZvciBlYWNoIHRlc3RcbiAgfSk7XG5cbiAgYWZ0ZXJFYWNoKCgpID0+IHtcbiAgICBtb2NrQXhpb3MucmVzdG9yZSgpO1xuICB9KTtcblxuICBkZXNjcmliZSgnaGFwcHkgZmxvdyB0ZXN0cycsICgpID0+IHtcbiAgICAvLyBTY2VuYXJpbyAxOiBHRVQgcmVxdWVzdCBhbmQgcmVjZWl2ZSBhIHJlc3BvbnNlXG4gICAgaXQoJ3Nob3VsZCBtYWtlIGEgR0VUIHJlcXVlc3QgYW5kIHJlY2VpdmUgYSByZXNwb25zZScsIGFzeW5jICgpID0+IHtcbiAgICAgIC8vIE1vY2sgdGhlIEdFVCByZXF1ZXN0IHVzaW5nIGF4aW9zLW1vY2stYWRhcHRlclxuICAgICAgbW9ja0F4aW9zLm9uR2V0KCdodHRwczovL2V4YW1wbGUuY29tJykucmVwbHkoMjAwLCAnR0VUIHJlc3BvbnNlJyk7XG4gICAgICBjb25zdCByZXNwb25zZSA9IChhd2FpdCBheGlvc0NsaWVudC5nZXQoXG4gICAgICAgICdodHRwczovL2V4YW1wbGUuY29tJyxcbiAgICAgICkpIGFzIFN1Y2Nlc3NmdWxBcGlSZXNwb25zZTxzdHJpbmc+O1xuICAgICAgZXhwZWN0KHJlc3BvbnNlLnR5cGUpLnRvQmUoJ3N1Y2Nlc3MnKTtcbiAgICAgIGV4cGVjdChyZXNwb25zZS5zdGF0dXNDb2RlKS50b0JlKDIwMCk7XG4gICAgICBleHBlY3QocmVzcG9uc2UucmVzcG9uc2VCb2R5KS50b0JlKCdHRVQgcmVzcG9uc2UnKTtcbiAgICB9KTtcblxuICAgIC8vIFNjZW5hcmlvIDI6IFBPU1QgcmVxdWVzdCBhbmQgcmVjZWl2ZSBhIHJlc3BvbnNlXG4gICAgaXQoJ3Nob3VsZCBtYWtlIGEgUE9TVCByZXF1ZXN0IGFuZCByZWNlaXZlIGEgcmVzcG9uc2UnLCBhc3luYyAoKSA9PiB7XG4gICAgICAvLyBNb2NrIHRoZSBheGlvcy5wb3N0IG1ldGhvZCB0byByZXR1cm4gYSByZXNwb25zZVxuICAgICAgbW9ja0F4aW9zLm9uUG9zdCgnaHR0cHM6Ly9leGFtcGxlLmNvbScpLnJlcGx5KDIwMSwgJ1BPU1QgcmVzcG9uc2UnKTtcblxuICAgICAgY29uc3QgcmVzcG9uc2UgPSAoYXdhaXQgYXhpb3NDbGllbnQucG9zdChcbiAgICAgICAgJ2h0dHBzOi8vZXhhbXBsZS5jb20nLFxuICAgICAgICB7XG4gICAgICAgICAgZm9vOiAnYmFyJyxcbiAgICAgICAgfSxcbiAgICAgICAgeyB0aW1lb3V0OiAxMDAwIH0sXG4gICAgICApKSBhcyBTdWNjZXNzZnVsQXBpUmVzcG9uc2U8c3RyaW5nPjtcbiAgICAgIGV4cGVjdChyZXNwb25zZS50eXBlKS50b0JlKCdzdWNjZXNzJyk7XG4gICAgICBleHBlY3QocmVzcG9uc2Uuc3RhdHVzQ29kZSkudG9CZSgyMDEpO1xuICAgICAgZXhwZWN0KHJlc3BvbnNlLnJlc3BvbnNlQm9keSkudG9CZSgnUE9TVCByZXNwb25zZScpO1xuICAgIH0pO1xuXG4gICAgLy8gU2NlbmFyaW8gMzogUFVUIHJlcXVlc3QgYW5kIHJlY2VpdmUgYSByZXNwb25zZVxuICAgIGl0KCdzaG91bGQgbWFrZSBhIFBVVCByZXF1ZXN0IGFuZCByZWNlaXZlIGEgcmVzcG9uc2UnLCBhc3luYyAoKSA9PiB7XG4gICAgICAvLyBNb2NrIHRoZSBheGlvcy5wdXQgbWV0aG9kIHRvIHJldHVybiBhIHJlc3BvbnNlXG4gICAgICBtb2NrQXhpb3Mub25QdXQoJ2h0dHBzOi8vZXhhbXBsZS5jb20nKS5yZXBseSgyMDQpO1xuXG4gICAgICBjb25zdCByZXNwb25zZSA9IChhd2FpdCBheGlvc0NsaWVudC5wdXQoXG4gICAgICAgICdodHRwczovL2V4YW1wbGUuY29tJyxcbiAgICAgICAge1xuICAgICAgICAgIGZvbzogJ2JhcicsXG4gICAgICAgIH0sXG4gICAgICAgIHsgdGltZW91dDogMTAwIH0sXG4gICAgICApKSBhcyBTdWNjZXNzZnVsQXBpUmVzcG9uc2U8c3RyaW5nPjtcbiAgICAgIGV4cGVjdChyZXNwb25zZS50eXBlKS50b0JlKCdzdWNjZXNzJyk7XG4gICAgICBleHBlY3QocmVzcG9uc2Uuc3RhdHVzQ29kZSkudG9CZSgyMDQpO1xuICAgICAgZXhwZWN0KHJlc3BvbnNlLnJlc3BvbnNlQm9keSkudG9CZVVuZGVmaW5lZCgpOyAvLyBObyByZXNwb25zZSBib2R5IGZvciBQVVRcbiAgICB9KTtcblxuICAgIC8vIFNjZW5hcmlvIDQ6IFBBVENIIHJlcXVlc3QgYW5kIHJlY2VpdmUgYSByZXNwb25zZVxuICAgIGl0KCdzaG91bGQgbWFrZSBhIFBBVENIIHJlcXVlc3QgYW5kIHJlY2VpdmUgYSByZXNwb25zZScsIGFzeW5jICgpID0+IHtcbiAgICAgIC8vIE1vY2sgdGhlIGF4aW9zLnBhdGNoIG1ldGhvZCB0byByZXR1cm4gYSByZXNwb25zZVxuICAgICAgbW9ja0F4aW9zLm9uUGF0Y2goJ2h0dHBzOi8vZXhhbXBsZS5jb20nKS5yZXBseSgyMDAsICdQQVRDSCByZXNwb25zZScpO1xuXG4gICAgICBjb25zdCByZXNwb25zZSA9IChhd2FpdCBheGlvc0NsaWVudC5wYXRjaChcbiAgICAgICAgJ2h0dHBzOi8vZXhhbXBsZS5jb20nLFxuICAgICAgICB7XG4gICAgICAgICAgZm9vOiAnYmFyJyxcbiAgICAgICAgfSxcbiAgICAgICAgeyB0aW1lb3V0OiA1MDAgfSxcbiAgICAgICkpIGFzIFN1Y2Nlc3NmdWxBcGlSZXNwb25zZTxzdHJpbmc+O1xuICAgICAgZXhwZWN0KHJlc3BvbnNlLnR5cGUpLnRvQmUoJ3N1Y2Nlc3MnKTtcbiAgICAgIGV4cGVjdChyZXNwb25zZS5zdGF0dXNDb2RlKS50b0JlKDIwMCk7XG4gICAgICBleHBlY3QocmVzcG9uc2UucmVzcG9uc2VCb2R5KS50b0JlKCdQQVRDSCByZXNwb25zZScpO1xuICAgIH0pO1xuXG4gICAgLy8gU2NlbmFyaW8gNTogREVMRVRFIHJlcXVlc3QgYW5kIHJlY2VpdmUgYSByZXNwb25zZVxuICAgIGl0KCdzaG91bGQgbWFrZSBhIERFTEVURSByZXF1ZXN0IGFuZCByZWNlaXZlIGEgcmVzcG9uc2UnLCBhc3luYyAoKSA9PiB7XG4gICAgICAvLyBNb2NrIHRoZSBheGlvcy5kZWxldGUgbWV0aG9kIHRvIHJldHVybiBhIHJlc3BvbnNlXG4gICAgICBtb2NrQXhpb3Mub25EZWxldGUoJ2h0dHBzOi8vZXhhbXBsZS5jb20nKS5yZXBseSgyMDQpO1xuXG4gICAgICBjb25zdCByZXNwb25zZSA9IChhd2FpdCBheGlvc0NsaWVudC5kZWxldGUoJ2h0dHBzOi8vZXhhbXBsZS5jb20nLCB7XG4gICAgICAgIHRpbWVvdXQ6IDQyMCxcbiAgICAgIH0pKSBhcyBTdWNjZXNzZnVsQXBpUmVzcG9uc2U8c3RyaW5nPjtcbiAgICAgIGV4cGVjdChyZXNwb25zZS50eXBlKS50b0JlKCdzdWNjZXNzJyk7XG4gICAgICBleHBlY3QocmVzcG9uc2Uuc3RhdHVzQ29kZSkudG9CZSgyMDQpO1xuICAgICAgZXhwZWN0KHJlc3BvbnNlLnJlc3BvbnNlQm9keSkudG9CZVVuZGVmaW5lZCgpOyAvLyBObyByZXNwb25zZSBib2R5IGZvciBERUxFVEVcbiAgICB9KTtcblxuICAgIC8vIFNjZW5hcmlvIDY6IEdFVCByZXF1ZXN0IHdpdGggYSByZXNwb25zZSBwYXJzZXJcbiAgICBpdCgnc2hvdWxkIG1ha2UgYSBHRVQgcmVxdWVzdCB3aXRoIGEgcmVzcG9uc2UgcGFyc2VyJywgYXN5bmMgKCkgPT4ge1xuICAgICAgLy8gTW9jayB0aGUgR0VUIHJlcXVlc3QgdXNpbmcgYXhpb3MtbW9jay1hZGFwdGVyXG4gICAgICBtb2NrQXhpb3Mub25HZXQoJ2h0dHBzOi8vZXhhbXBsZS5jb20nKS5yZXBseSgyMDAsICdHRVQgcmVzcG9uc2UnKTtcblxuICAgICAgY29uc3QgcmVzcG9uc2UgPSAoYXdhaXQgYXhpb3NDbGllbnQuZ2V0KFxuICAgICAgICAnaHR0cHM6Ly9leGFtcGxlLmNvbScsXG4gICAgICAgIHt9LFxuICAgICAgICAoZGF0YSkgPT4gYFBhcnNlZCAke2RhdGF9YCxcbiAgICAgICkpIGFzIFN1Y2Nlc3NmdWxBcGlSZXNwb25zZTxzdHJpbmc+O1xuICAgICAgZXhwZWN0KHJlc3BvbnNlLnR5cGUpLnRvQmUoJ3N1Y2Nlc3MnKTtcbiAgICAgIGV4cGVjdChyZXNwb25zZS5zdGF0dXNDb2RlKS50b0JlKDIwMCk7XG4gICAgICBleHBlY3QocmVzcG9uc2UucmVzcG9uc2VCb2R5KS50b0JlKCdQYXJzZWQgR0VUIHJlc3BvbnNlJyk7XG4gICAgfSk7XG5cbiAgICAvLyBTY2VuYXJpbyA3OiBQT1NUIHJlcXVlc3Qgd2l0aCBhIHJlc3BvbnNlIHBhcnNlclxuICAgIGl0KCdzaG91bGQgbWFrZSBhIFBPU1QgcmVxdWVzdCB3aXRoIGEgcmVzcG9uc2UgcGFyc2VyJywgYXN5bmMgKCkgPT4ge1xuICAgICAgLy8gTW9jayB0aGUgYXhpb3MucG9zdCBtZXRob2QgdG8gcmV0dXJuIGEgcmVzcG9uc2VcbiAgICAgIG1vY2tBeGlvcy5vblBvc3QoJ2h0dHBzOi8vZXhhbXBsZS5jb20nKS5yZXBseSgyMDEsICdQT1NUIHJlc3BvbnNlJyk7XG5cbiAgICAgIGNvbnN0IHJlc3BvbnNlID0gKGF3YWl0IGF4aW9zQ2xpZW50LnBvc3QoXG4gICAgICAgICdodHRwczovL2V4YW1wbGUuY29tJyxcbiAgICAgICAge1xuICAgICAgICAgIGZvbzogJ2JhcicsXG4gICAgICAgIH0sXG4gICAgICAgIHt9LFxuICAgICAgICAoZGF0YSkgPT4gYFBhcnNlZCAke2RhdGF9YCxcbiAgICAgICkpIGFzIFN1Y2Nlc3NmdWxBcGlSZXNwb25zZTxzdHJpbmc+O1xuICAgICAgZXhwZWN0KHJlc3BvbnNlLnR5cGUpLnRvQmUoJ3N1Y2Nlc3MnKTtcbiAgICAgIGV4cGVjdChyZXNwb25zZS5zdGF0dXNDb2RlKS50b0JlKDIwMSk7XG4gICAgICBleHBlY3QocmVzcG9uc2UucmVzcG9uc2VCb2R5KS50b0JlKCdQYXJzZWQgUE9TVCByZXNwb25zZScpO1xuICAgIH0pO1xuXG4gICAgLy8gU2NlbmFyaW8gODogUFVUIHJlcXVlc3Qgd2l0aCBhIHJlc3BvbnNlIHBhcnNlclxuICAgIGl0KCdzaG91bGQgbWFrZSBhIFBVVCByZXF1ZXN0IHdpdGggYSByZXNwb25zZSBwYXJzZXInLCBhc3luYyAoKSA9PiB7XG4gICAgICAvLyBNb2NrIHRoZSBheGlvcy5wdXQgbWV0aG9kIHRvIHJldHVybiBhIHJlc3BvbnNlXG4gICAgICBtb2NrQXhpb3Mub25QdXQoJ2h0dHBzOi8vZXhhbXBsZS5jb20nKS5yZXBseSgyMDQpO1xuXG4gICAgICBjb25zdCByZXNwb25zZSA9IChhd2FpdCBheGlvc0NsaWVudC5wdXQoXG4gICAgICAgICdodHRwczovL2V4YW1wbGUuY29tJyxcbiAgICAgICAge1xuICAgICAgICAgIGZvbzogJ2JhcicsXG4gICAgICAgIH0sXG4gICAgICAgIHt9LFxuICAgICAgICAoZGF0YSkgPT4gYFBhcnNlZCAke2RhdGF9YCxcbiAgICAgICkpIGFzIFN1Y2Nlc3NmdWxBcGlSZXNwb25zZTxzdHJpbmc+O1xuICAgICAgZXhwZWN0KHJlc3BvbnNlLnR5cGUpLnRvQmUoJ3N1Y2Nlc3MnKTtcbiAgICAgIGV4cGVjdChyZXNwb25zZS5zdGF0dXNDb2RlKS50b0JlKDIwNCk7XG4gICAgICBleHBlY3QocmVzcG9uc2UucmVzcG9uc2VCb2R5KS50b0JlKCdQYXJzZWQgdW5kZWZpbmVkJyk7IC8vIE5vIHJlc3BvbnNlIGJvZHkgZm9yIFBVVFxuICAgIH0pO1xuXG4gICAgLy8gU2NlbmFyaW8gOTogUEFUQ0ggcmVxdWVzdCB3aXRoIGEgcmVzcG9uc2UgcGFyc2VyXG4gICAgaXQoJ3Nob3VsZCBtYWtlIGEgUEFUQ0ggcmVxdWVzdCB3aXRoIGEgcmVzcG9uc2UgcGFyc2VyJywgYXN5bmMgKCkgPT4ge1xuICAgICAgLy8gTW9jayB0aGUgYXhpb3MucGF0Y2ggbWV0aG9kIHRvIHJldHVybiBhIHJlc3BvbnNlXG4gICAgICBtb2NrQXhpb3Mub25QYXRjaCgnaHR0cHM6Ly9leGFtcGxlLmNvbScpLnJlcGx5KDIwMCwgJ1BBVENIIHJlc3BvbnNlJyk7XG5cbiAgICAgIGNvbnN0IHJlc3BvbnNlID0gKGF3YWl0IGF4aW9zQ2xpZW50LnBhdGNoKFxuICAgICAgICAnaHR0cHM6Ly9leGFtcGxlLmNvbScsXG4gICAgICAgIHtcbiAgICAgICAgICBmb286ICdiYXInLFxuICAgICAgICB9LFxuICAgICAgICB7fSxcbiAgICAgICAgKGRhdGEpID0+IGBQYXJzZWQgJHtkYXRhfWAsXG4gICAgICApKSBhcyBTdWNjZXNzZnVsQXBpUmVzcG9uc2U8c3RyaW5nPjtcbiAgICAgIGV4cGVjdChyZXNwb25zZS50eXBlKS50b0JlKCdzdWNjZXNzJyk7XG4gICAgICBleHBlY3QocmVzcG9uc2Uuc3RhdHVzQ29kZSkudG9CZSgyMDApO1xuICAgICAgZXhwZWN0KHJlc3BvbnNlLnJlc3BvbnNlQm9keSkudG9CZSgnUGFyc2VkIFBBVENIIHJlc3BvbnNlJyk7XG4gICAgfSk7XG5cbiAgICAvLyBTY2VuYXJpbyAxMDogREVMRVRFIHJlcXVlc3Qgd2l0aCBhIHJlc3BvbnNlIHBhcnNlclxuICAgIGl0KCdzaG91bGQgbWFrZSBhIERFTEVURSByZXF1ZXN0IHdpdGggYSByZXNwb25zZSBwYXJzZXInLCBhc3luYyAoKSA9PiB7XG4gICAgICAvLyBNb2NrIHRoZSBheGlvcy5kZWxldGUgbWV0aG9kIHRvIHJldHVybiBhIHJlc3BvbnNlXG4gICAgICBtb2NrQXhpb3Mub25EZWxldGUoJ2h0dHBzOi8vZXhhbXBsZS5jb20nKS5yZXBseSgyMDQpO1xuXG4gICAgICBjb25zdCByZXNwb25zZSA9IChhd2FpdCBheGlvc0NsaWVudC5kZWxldGUoXG4gICAgICAgICdodHRwczovL2V4YW1wbGUuY29tJyxcbiAgICAgICAge30sXG4gICAgICAgIChkYXRhKSA9PiBgUGFyc2VkICR7ZGF0YX1gLFxuICAgICAgKSkgYXMgU3VjY2Vzc2Z1bEFwaVJlc3BvbnNlPHN0cmluZz47XG4gICAgICBleHBlY3QocmVzcG9uc2UudHlwZSkudG9CZSgnc3VjY2VzcycpO1xuICAgICAgZXhwZWN0KHJlc3BvbnNlLnN0YXR1c0NvZGUpLnRvQmUoMjA0KTtcbiAgICAgIGV4cGVjdChyZXNwb25zZS5yZXNwb25zZUJvZHkpLnRvQmUoJ1BhcnNlZCB1bmRlZmluZWQnKTsgLy8gTm8gcmVzcG9uc2UgYm9keSBmb3IgREVMRVRFXG4gICAgfSk7XG5cbiAgICAvLyBTY2VuYXJpbyAxMTogR0VUIHJlcXVlc3Qgd2l0aCBoZWFkZXJzXG4gICAgaXQoJ3Nob3VsZCBtYWtlIGEgR0VUIHJlcXVlc3Qgd2l0aCBoZWFkZXJzJywgYXN5bmMgKCkgPT4ge1xuICAgICAgLy8gTW9jayB0aGUgR0VUIHJlcXVlc3QgdXNpbmcgYXhpb3MtbW9jay1hZGFwdGVyXG4gICAgICBtb2NrQXhpb3Mub25HZXQoJ2h0dHBzOi8vZXhhbXBsZS5jb20nKS5yZXBseSgoY29uZmlnKSA9PiB7XG4gICAgICAgIGV4cGVjdChjb25maWcuaGVhZGVycy5mb28pLnRvRXF1YWwoJ2JhcicpO1xuICAgICAgICByZXR1cm4gW1xuICAgICAgICAgIDIwMCxcbiAgICAgICAgICAnR0VUIHJlc3BvbnNlJyxcbiAgICAgICAgICB7XG4gICAgICAgICAgICBBdXRob3JpemF0aW9uOiBgQmVhcmVyIFRva2VuYCxcbiAgICAgICAgICAgICdDb250ZW50LXR5cGUnOiAnYXBwbGljYXRpb24veC13d3ctZm9ybS11cmxlbmNvZGVkJyxcbiAgICAgICAgICB9LFxuICAgICAgICBdO1xuICAgICAgfSk7XG5cbiAgICAgIGNvbnN0IHJlc3BvbnNlID0gKGF3YWl0IGF4aW9zQ2xpZW50LmdldCgnaHR0cHM6Ly9leGFtcGxlLmNvbScsIHtcbiAgICAgICAgaGVhZGVyczogeyBmb286ICdiYXInIH0sXG4gICAgICB9KSkgYXMgU3VjY2Vzc2Z1bEFwaVJlc3BvbnNlPHN0cmluZz47XG4gICAgICBleHBlY3QocmVzcG9uc2UudHlwZSkudG9CZSgnc3VjY2VzcycpO1xuICAgICAgZXhwZWN0KHJlc3BvbnNlLnN0YXR1c0NvZGUpLnRvQmUoMjAwKTtcbiAgICAgIGV4cGVjdChyZXNwb25zZS5yZXNwb25zZUJvZHkpLnRvQmUoJ0dFVCByZXNwb25zZScpO1xuICAgIH0pO1xuXG4gICAgLy8gb3RoZXIgaGFwcHkgZmxvdyB0ZXN0c1xuICAgIC8vIFNjZW5hcmlvIDEyOlxuICB9KTtcblxuICBkZXNjcmliZSgnZXJyb3IgZmxvdyB0ZXN0cycsICgpID0+IHtcbiAgICAvLyBTY2VuYXJpbyAxOiBHRVQgcmVxdWVzdCBhbmQgcmVjZWl2ZSBhIG5ldHdvcmsgZXJyb3JcbiAgICBpdCgnc2hvdWxkIG1ha2UgYSBHRVQgcmVxdWVzdCBhbmQgcmVjZWl2ZSBhIG5ldHdvcmsgZXJyb3InLCBhc3luYyAoKSA9PiB7XG4gICAgICAvLyBNb2NrIHRoZSBHRVQgcmVxdWVzdCB1c2luZyBheGlvcy1tb2NrLWFkYXB0ZXJcbiAgICAgIG1vY2tBeGlvcy5vbkdldCgnaHR0cHM6Ly9leGFtcGxlLmNvbScpLmFib3J0UmVxdWVzdCgpO1xuXG4gICAgICBjb25zdCByZXNwb25zZSA9IChhd2FpdCBheGlvc0NsaWVudC5nZXQoJ2h0dHBzOi8vZXhhbXBsZS5jb20nKSkgYXMgQ2xpZW50RXJyb3JBcGlSZXNwb25zZTtcbiAgICAgIGV4cGVjdChyZXNwb25zZS50eXBlKS50b0JlKCdjbGllbnQtZXJyb3InKTtcbiAgICAgIGV4cGVjdChyZXNwb25zZS5zdGF0dXNDb2RlKS50b0JlKDUwMCk7XG4gICAgICBleHBlY3QocmVzcG9uc2UubWVzc2FnZSkudG9CZSgnVW5rbm93biBFcnJvcjpSZXF1ZXN0IGFib3J0ZWQnKTtcbiAgICB9KTtcblxuICAgIC8vIHNob3VsZCBoYW5kbGUgdGltZW91dCBlcnJvcnNcbiAgICBpdCgnc2hvdWxkIG1ha2UgYSBHRVQgcmVxdWVzdCBhbmQgcmVjZWl2ZSBhIHRpbWVvdXQgZXJyb3InLCBhc3luYyAoKSA9PiB7XG4gICAgICAvLyBNb2NrIHRoZSBHRVQgcmVxdWVzdCB1c2luZyBheGlvcy1tb2NrLWFkYXB0ZXJcbiAgICAgIG1vY2tBeGlvcy5vbkdldCgnaHR0cHM6Ly9leGFtcGxlLmNvbScpLnRpbWVvdXQoKTtcblxuICAgICAgY29uc3QgcmVzcG9uc2UgPSAoYXdhaXQgYXhpb3NDbGllbnQuZ2V0KCdodHRwczovL2V4YW1wbGUuY29tJykpIGFzIENsaWVudEVycm9yQXBpUmVzcG9uc2U7XG4gICAgICBleHBlY3QocmVzcG9uc2UudHlwZSkudG9CZSgnY2xpZW50LWVycm9yJyk7XG4gICAgICBleHBlY3QocmVzcG9uc2Uuc3RhdHVzQ29kZSkudG9CZSg1MDApO1xuICAgICAgZXhwZWN0KHJlc3BvbnNlLm1lc3NhZ2UpLnRvQmUoJ1Vua25vd24gRXJyb3I6dGltZW91dCBvZiAwbXMgZXhjZWVkZWQnKTtcbiAgICB9KTtcblxuICAgIGl0KCdzaG91bGQgbWFrZSBhIEdFVCByZXF1ZXN0IGFuZCByZWNlaXZlIGEgbmV0d29yayBlcnJvcicsIGFzeW5jICgpID0+IHtcbiAgICAgIC8vIE1vY2sgdGhlIEdFVCByZXF1ZXN0IHVzaW5nIGF4aW9zLW1vY2stYWRhcHRlclxuICAgICAgbW9ja0F4aW9zLm9uR2V0KCdodHRwczovL2V4YW1wbGUuY29tJykubmV0d29ya0Vycm9yKCk7XG5cbiAgICAgIGNvbnN0IHJlc3BvbnNlID0gKGF3YWl0IGF4aW9zQ2xpZW50LmdldCgnaHR0cHM6Ly9leGFtcGxlLmNvbScpKSBhcyBDbGllbnRFcnJvckFwaVJlc3BvbnNlO1xuICAgICAgZXhwZWN0KHJlc3BvbnNlLnR5cGUpLnRvQmUoJ2NsaWVudC1lcnJvcicpO1xuICAgICAgZXhwZWN0KHJlc3BvbnNlLnN0YXR1c0NvZGUpLnRvQmUoNTAwKTtcbiAgICAgIGV4cGVjdChyZXNwb25zZS5tZXNzYWdlKS50b0JlKCdOZXR3b3JrIEVycm9yJyk7XG4gICAgfSk7XG5cbiAgICAvLyBzaG91bGQgaGFuZGxlIGFwcGxpY2F0aW9uIGVycm9ycyAoNHh4KVxuICAgIGl0KCdzaG91bGQgbWFrZSBhIEdFVCByZXF1ZXN0IGFuZCByZWNlaXZlIGEgNDAwIGVycm9yJywgYXN5bmMgKCkgPT4ge1xuICAgICAgLy8gTW9jayB0aGUgR0VUIHJlcXVlc3QgdXNpbmcgYXhpb3MtbW9jay1hZGFwdGVyXG4gICAgICBtb2NrQXhpb3Mub25HZXQoJ2h0dHBzOi8vZXhhbXBsZS5jb20nKS5yZXBseSg0MDAsICdCYWQgUmVxdWVzdCBSZWNlaXZlZCcpO1xuXG4gICAgICBjb25zdCByZXNwb25zZSA9IChhd2FpdCBheGlvc0NsaWVudC5nZXQoXG4gICAgICAgICdodHRwczovL2V4YW1wbGUuY29tJyxcbiAgICAgICkpIGFzIEFwcGxpY2F0aW9uRXJyb3JBcGlSZXNwb25zZTtcbiAgICAgIGV4cGVjdChyZXNwb25zZS50eXBlKS50b0JlKCdhcHBsaWNhdGlvbi1lcnJvcicpO1xuICAgICAgZXhwZWN0KHJlc3BvbnNlLnN0YXR1c0NvZGUpLnRvQmUoNDAwKTtcbiAgICAgIGV4cGVjdChyZXNwb25zZS5yZXNwb25zZUJvZHkpLnRvQmUoJ0JhZCBSZXF1ZXN0IFJlY2VpdmVkJyk7XG4gICAgfSk7XG5cbiAgICBpdCgnc2hvdWxkIG1ha2UgYSBHRVQgcmVxdWVzdCBhbmQgcmVjZWl2ZSBhIDUwMCBlcnJvciB3aGVuIGVycm9yZWQgd2l0aCB1bmtub3duIGNvZGUnLCBhc3luYyAoKSA9PiB7XG4gICAgICAvLyBNb2NrIHRoZSBHRVQgcmVxdWVzdCB1c2luZyBheGlvcy1tb2NrLWFkYXB0ZXJcbiAgICAgIG1vY2tBeGlvcy5vbkdldCgnaHR0cHM6Ly9leGFtcGxlLmNvbScpLnJlcGx5KChjb25maWcpID0+IHtcbiAgICAgICAgY29uc3QgZXJyID0gQXhpb3NFcnJvci5mcm9tKCdteSBlcnJvciBtZXNzYWdlJywgJ01ZX0NPREUnLCBjb25maWcpO1xuICAgICAgICByZXR1cm4gUHJvbWlzZS5yZWplY3QoZXJyKTtcbiAgICAgIH0pO1xuXG4gICAgICBjb25zdCByZXNwb25zZSA9IChhd2FpdCBheGlvc0NsaWVudC5nZXQoXG4gICAgICAgICdodHRwczovL2V4YW1wbGUuY29tJyxcbiAgICAgICkpIGFzIEFwcGxpY2F0aW9uRXJyb3JBcGlSZXNwb25zZTtcbiAgICAgIGV4cGVjdChyZXNwb25zZS50eXBlKS50b0JlKCdjbGllbnQtZXJyb3InKTtcbiAgICAgIGV4cGVjdChyZXNwb25zZS5zdGF0dXNDb2RlKS50b0JlKDUwMCk7XG4gICAgICBleHBlY3QocmVzcG9uc2UubWVzc2FnZSkudG9CZShgVW5rbm93biBFcnJvcjp1bmRlZmluZWRgKTtcbiAgICB9KTtcbiAgICBpdCgnc2hvdWxkIG1ha2UgYSBHRVQgcmVxdWVzdCBhbmQgcmVjZWl2ZSBhIDUwMCBlcnJvciB3aGVuIGVycm9yZWQgd2l0aCBFQUNDRVMgY29kZScsIGFzeW5jICgpID0+IHtcbiAgICAgIC8vIE1vY2sgdGhlIEdFVCByZXF1ZXN0IHVzaW5nIGF4aW9zLW1vY2stYWRhcHRlclxuICAgICAgbW9ja0F4aW9zLm9uR2V0KCdodHRwczovL2V4YW1wbGUuY29tJykucmVwbHkoKGNvbmZpZykgPT4ge1xuICAgICAgICBjb25zdCBlcnIgPSBBeGlvc0Vycm9yLmZyb20oJ215IGVycm9yIG1lc3NhZ2UnLCAnRUFDQ0VTJywgY29uZmlnKTtcbiAgICAgICAgcmV0dXJuIFByb21pc2UucmVqZWN0KGVycik7XG4gICAgICB9KTtcblxuICAgICAgY29uc3QgcmVzcG9uc2UgPSAoYXdhaXQgYXhpb3NDbGllbnQuZ2V0KFxuICAgICAgICAnaHR0cHM6Ly9leGFtcGxlLmNvbScsXG4gICAgICApKSBhcyBBcHBsaWNhdGlvbkVycm9yQXBpUmVzcG9uc2U7XG4gICAgICBleHBlY3QocmVzcG9uc2UudHlwZSkudG9CZSgnY2xpZW50LWVycm9yJyk7XG4gICAgICBleHBlY3QocmVzcG9uc2Uuc3RhdHVzQ29kZSkudG9CZSg0MDApO1xuICAgICAgZXhwZWN0KHJlc3BvbnNlLm1lc3NhZ2UpLnRvQmUoJ1tFQUNDRVNdIDo6IFBlcm1pc3Npb24gZGVuaWVkJyk7XG4gICAgfSk7XG5cbiAgICAvLyBzaG91bGQgaGFuZGxlIGFwcGxpY2F0aW9uIGVycm9ycyAoNXh4KVxuICAgIGl0KCdzaG91bGQgbWFrZSBhIEdFVCByZXF1ZXN0IGFuZCByZWNlaXZlIGEgNTAwIGVycm9yJywgYXN5bmMgKCkgPT4ge1xuICAgICAgLy8gTW9jayB0aGUgR0VUIHJlcXVlc3QgdXNpbmcgYXhpb3MtbW9jay1hZGFwdGVyXG4gICAgICBtb2NrQXhpb3Mub25HZXQoJ2h0dHBzOi8vZXhhbXBsZS5jb20nKS5yZXBseSg1MDAsICdJbnRlcm5hbCBTZXJ2ZXIgRXJyb3InKTtcblxuICAgICAgY29uc3QgcmVzcG9uc2UgPSAoYXdhaXQgYXhpb3NDbGllbnQuZ2V0KFxuICAgICAgICAnaHR0cHM6Ly9leGFtcGxlLmNvbScsXG4gICAgICApKSBhcyBBcHBsaWNhdGlvbkVycm9yQXBpUmVzcG9uc2U7XG4gICAgICBleHBlY3QocmVzcG9uc2UudHlwZSkudG9CZSgnYXBwbGljYXRpb24tZXJyb3InKTtcbiAgICAgIGV4cGVjdChyZXNwb25zZS5zdGF0dXNDb2RlKS50b0JlKDUwMCk7XG4gICAgICBleHBlY3QocmVzcG9uc2UucmVzcG9uc2VCb2R5KS50b0JlKCdJbnRlcm5hbCBTZXJ2ZXIgRXJyb3InKTtcbiAgICB9KTtcblxuICAgIC8vIHNob3VsZCBoYW5kbGUgdW5leHBlY3RlZCBlcnJvcnNcbiAgICBpdCgnc2hvdWxkIG1ha2UgYSBHRVQgcmVxdWVzdCBhbmQgcmVjZWl2ZSBhbiB1bmV4cGVjdGVkIGVycm9yJywgYXN5bmMgKCkgPT4ge1xuICAgICAgLy8gTW9jayB0aGUgR0VUIHJlcXVlc3QgdXNpbmcgYXhpb3MtbW9jay1hZGFwdGVyXG4gICAgICBtb2NrQXhpb3Mub25HZXQoJ2h0dHBzOi8vZXhhbXBsZS5jb20nKS5yZXBseSgyMDAsICdHRVQgcmVzcG9uc2UnKTtcblxuICAgICAgY29uc3QgcmVzcG9uc2UgPSAoYXdhaXQgYXhpb3NDbGllbnQuZ2V0KCdodHRwczovL2V4YW1wbGUuY29tJywge30sIChfZGF0YSkgPT4ge1xuICAgICAgICB0aHJvdyBuZXcgRXJyb3IoJ1VuZXhwZWN0ZWQgRXJyb3InKTtcbiAgICAgIH0pKSBhcyBDbGllbnRFcnJvckFwaVJlc3BvbnNlO1xuICAgICAgZXhwZWN0KHJlc3BvbnNlLnR5cGUpLnRvQmUoJ2NsaWVudC1lcnJvcicpO1xuICAgICAgZXhwZWN0KHJlc3BvbnNlLnN0YXR1c0NvZGUpLnRvQmUoNTAwKTtcbiAgICAgIGV4cGVjdChyZXNwb25zZS5tZXNzYWdlKS50b0JlKCdGYWlsZWQgdG8gcGFyc2UgcmVzcG9uc2UgZGF0YTogVW5leHBlY3RlZCBFcnJvcicpO1xuICAgIH0pO1xuXG4gICAgLy8gc2hvdWxkIGhhbmRsZSBlbXB0eSByZXNwb25zZSBib2R5XG4gICAgaXQoJ3Nob3VsZCBtYWtlIGEgR0VUIHJlcXVlc3QgYW5kIHJlY2VpdmUgYW4gZW1wdHkgcmVzcG9uc2UgYm9keScsIGFzeW5jICgpID0+IHtcbiAgICAgIC8vIE1vY2sgdGhlIEdFVCByZXF1ZXN0IHVzaW5nIGF4aW9zLW1vY2stYWRhcHRlclxuICAgICAgbW9ja0F4aW9zLm9uR2V0KCdodHRwczovL2V4YW1wbGUuY29tJykucmVwbHkoMjAwKTtcblxuICAgICAgY29uc3QgcmVzcG9uc2UgPSAoYXdhaXQgYXhpb3NDbGllbnQuZ2V0KFxuICAgICAgICAnaHR0cHM6Ly9leGFtcGxlLmNvbScsXG4gICAgICApKSBhcyBTdWNjZXNzZnVsQXBpUmVzcG9uc2U8c3RyaW5nPjtcbiAgICAgIGV4cGVjdChyZXNwb25zZS50eXBlKS50b0JlKCdzdWNjZXNzJyk7XG4gICAgICBleHBlY3QocmVzcG9uc2Uuc3RhdHVzQ29kZSkudG9CZSgyMDApO1xuICAgICAgZXhwZWN0KHJlc3BvbnNlLnJlc3BvbnNlQm9keSkudG9CZVVuZGVmaW5lZCgpO1xuICAgIH0pO1xuICB9KTtcbn0pO1xuIl19
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=factory.test.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"factory.test.d.ts","sourceRoot":"","sources":["../../src/network/factory.test.ts"],"names":[],"mappings":""}
@@ -1,51 +0,0 @@
1
- "use strict";
2
- // Generated by CodiumAI
3
- Object.defineProperty(exports, "__esModule", { value: true });
4
- const errors_1 = require("../errors");
5
- const axios_client_1 = require("./clients/axios_client");
6
- const factory_1 = require("./factory");
7
- describe('getHttpClient', () => {
8
- // Tests that getHttpClient returns an instance of AxiosClient when name is ClientNames.Axios and options are not provided
9
- it('should return an instance of AxiosClient when name is ClientNames.Axios and options are not provided', () => {
10
- const httpClient = factory_1.HttpClientFactory.getHttpClient(factory_1.ClientNames.Axios);
11
- expect(httpClient).toBeInstanceOf(axios_client_1.AxiosClient);
12
- });
13
- // Tests that getHttpClient returns an instance of AxiosClient with provided options when name is ClientNames.Axios and options are provided
14
- it('should return an instance of AxiosClient with provided options when name is ClientNames.Axios and options are provided', () => {
15
- const options = { timeout: 5000 };
16
- const httpClient = factory_1.HttpClientFactory.getHttpClient(factory_1.ClientNames.Axios, options);
17
- expect(httpClient).toBeInstanceOf(axios_client_1.AxiosClient);
18
- // @ts-expect-error: options is not present but for testing purpose we need this to be ignored
19
- expect(httpClient.options.timeout).toEqual(options.timeout);
20
- });
21
- // Tests that getHttpClient throws a PlatformError with message 'Invalid client name' when name is not a valid ClientNames enum value
22
- it('should throw a PlatformError with message "Invalid client name" when name is not a valid ClientNames enum value', () => {
23
- const invalidName = 'InvalidClient';
24
- expect(() => {
25
- factory_1.HttpClientFactory.getHttpClient(invalidName);
26
- }).toThrowError(errors_1.PlatformError);
27
- expect(() => {
28
- factory_1.HttpClientFactory.getHttpClient(invalidName);
29
- }).toThrowError('Invalid client name');
30
- });
31
- // Uncomment the following tests as we implement the FetchClient and XhrClient classes
32
- // // Tests that getHttpClient returns a FetchClient instance when name is ClientNames.Fetch
33
- // it('should return a FetchClient instance when name is ClientNames.Fetch', () => {
34
- // jest.mock('./clients/fetch', () => ({
35
- // FetchClient: jest.fn(),
36
- // }));
37
- // const { FetchClient } = require('./clients/fetch');
38
- // const httpClient = HttpClientFactory.getHttpClient(ClientNames.Fetch);
39
- // expect(httpClient).toBe(FetchClient);
40
- // });
41
- // // Tests that getHttpClient returns an XhrClient instance when name is ClientNames.Xhr
42
- // it('should return an XhrClient instance when name is ClientNames.Xhr', () => {
43
- // jest.mock('./clients/xhr', () => ({
44
- // XhrClient: jest.fn(),
45
- // }));
46
- // const { XhrClient } = require('./clients/xhr');
47
- // const httpClient = HttpClientFactory.getHttpClient(ClientNames.Xhr);
48
- // expect(httpClient).toBe(XhrClient);
49
- // });
50
- });
51
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmFjdG9yeS50ZXN0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL25ldHdvcmsvZmFjdG9yeS50ZXN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSx3QkFBd0I7O0FBRXhCLHNDQUEwQztBQUMxQyx5REFBcUQ7QUFDckQsdUNBQTJEO0FBRTNELFFBQVEsQ0FBQyxlQUFlLEVBQUUsR0FBRyxFQUFFO0lBQzdCLDBIQUEwSDtJQUMxSCxFQUFFLENBQUMsc0dBQXNHLEVBQUUsR0FBRyxFQUFFO1FBQzlHLE1BQU0sVUFBVSxHQUFHLDJCQUFpQixDQUFDLGFBQWEsQ0FBQyxxQkFBVyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ3RFLE1BQU0sQ0FBQyxVQUFVLENBQUMsQ0FBQyxjQUFjLENBQUMsMEJBQVcsQ0FBQyxDQUFDO0lBQ2pELENBQUMsQ0FBQyxDQUFDO0lBRUgsNElBQTRJO0lBQzVJLEVBQUUsQ0FBQyx3SEFBd0gsRUFBRSxHQUFHLEVBQUU7UUFDaEksTUFBTSxPQUFPLEdBQUcsRUFBRSxPQUFPLEVBQUUsSUFBSSxFQUFFLENBQUM7UUFDbEMsTUFBTSxVQUFVLEdBQUcsMkJBQWlCLENBQUMsYUFBYSxDQUFDLHFCQUFXLENBQUMsS0FBSyxFQUFFLE9BQU8sQ0FBQyxDQUFDO1FBQy9FLE1BQU0sQ0FBQyxVQUFVLENBQUMsQ0FBQyxjQUFjLENBQUMsMEJBQVcsQ0FBQyxDQUFDO1FBQy9DLDhGQUE4RjtRQUM5RixNQUFNLENBQUMsVUFBVSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQzlELENBQUMsQ0FBQyxDQUFDO0lBRUgscUlBQXFJO0lBQ3JJLEVBQUUsQ0FBQyxpSEFBaUgsRUFBRSxHQUFHLEVBQUU7UUFDekgsTUFBTSxXQUFXLEdBQUcsZUFBZSxDQUFDO1FBQ3BDLE1BQU0sQ0FBQyxHQUFHLEVBQUU7WUFDViwyQkFBaUIsQ0FBQyxhQUFhLENBQUMsV0FBMEIsQ0FBQyxDQUFDO1FBQzlELENBQUMsQ0FBQyxDQUFDLFlBQVksQ0FBQyxzQkFBYSxDQUFDLENBQUM7UUFDL0IsTUFBTSxDQUFDLEdBQUcsRUFBRTtZQUNWLDJCQUFpQixDQUFDLGFBQWEsQ0FBQyxXQUEwQixDQUFDLENBQUM7UUFDOUQsQ0FBQyxDQUFDLENBQUMsWUFBWSxDQUFDLHFCQUFxQixDQUFDLENBQUM7SUFDekMsQ0FBQyxDQUFDLENBQUM7SUFFSCxzRkFBc0Y7SUFDdEYsNEZBQTRGO0lBQzVGLG9GQUFvRjtJQUNwRiwwQ0FBMEM7SUFDMUMsOEJBQThCO0lBQzlCLFNBQVM7SUFDVCx3REFBd0Q7SUFDeEQsMkVBQTJFO0lBQzNFLDBDQUEwQztJQUMxQyxNQUFNO0lBRU4seUZBQXlGO0lBQ3pGLGlGQUFpRjtJQUNqRix3Q0FBd0M7SUFDeEMsNEJBQTRCO0lBQzVCLFNBQVM7SUFDVCxvREFBb0Q7SUFDcEQseUVBQXlFO0lBQ3pFLHdDQUF3QztJQUN4QyxNQUFNO0FBQ1IsQ0FBQyxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBHZW5lcmF0ZWQgYnkgQ29kaXVtQUlcblxuaW1wb3J0IHsgUGxhdGZvcm1FcnJvciB9IGZyb20gJy4uL2Vycm9ycyc7XG5pbXBvcnQgeyBBeGlvc0NsaWVudCB9IGZyb20gJy4vY2xpZW50cy9heGlvc19jbGllbnQnO1xuaW1wb3J0IHsgQ2xpZW50TmFtZXMsIEh0dHBDbGllbnRGYWN0b3J5IH0gZnJvbSAnLi9mYWN0b3J5JztcblxuZGVzY3JpYmUoJ2dldEh0dHBDbGllbnQnLCAoKSA9PiB7XG4gIC8vIFRlc3RzIHRoYXQgZ2V0SHR0cENsaWVudCByZXR1cm5zIGFuIGluc3RhbmNlIG9mIEF4aW9zQ2xpZW50IHdoZW4gbmFtZSBpcyBDbGllbnROYW1lcy5BeGlvcyBhbmQgb3B0aW9ucyBhcmUgbm90IHByb3ZpZGVkXG4gIGl0KCdzaG91bGQgcmV0dXJuIGFuIGluc3RhbmNlIG9mIEF4aW9zQ2xpZW50IHdoZW4gbmFtZSBpcyBDbGllbnROYW1lcy5BeGlvcyBhbmQgb3B0aW9ucyBhcmUgbm90IHByb3ZpZGVkJywgKCkgPT4ge1xuICAgIGNvbnN0IGh0dHBDbGllbnQgPSBIdHRwQ2xpZW50RmFjdG9yeS5nZXRIdHRwQ2xpZW50KENsaWVudE5hbWVzLkF4aW9zKTtcbiAgICBleHBlY3QoaHR0cENsaWVudCkudG9CZUluc3RhbmNlT2YoQXhpb3NDbGllbnQpO1xuICB9KTtcblxuICAvLyBUZXN0cyB0aGF0IGdldEh0dHBDbGllbnQgcmV0dXJucyBhbiBpbnN0YW5jZSBvZiBBeGlvc0NsaWVudCB3aXRoIHByb3ZpZGVkIG9wdGlvbnMgd2hlbiBuYW1lIGlzIENsaWVudE5hbWVzLkF4aW9zIGFuZCBvcHRpb25zIGFyZSBwcm92aWRlZFxuICBpdCgnc2hvdWxkIHJldHVybiBhbiBpbnN0YW5jZSBvZiBBeGlvc0NsaWVudCB3aXRoIHByb3ZpZGVkIG9wdGlvbnMgd2hlbiBuYW1lIGlzIENsaWVudE5hbWVzLkF4aW9zIGFuZCBvcHRpb25zIGFyZSBwcm92aWRlZCcsICgpID0+IHtcbiAgICBjb25zdCBvcHRpb25zID0geyB0aW1lb3V0OiA1MDAwIH07XG4gICAgY29uc3QgaHR0cENsaWVudCA9IEh0dHBDbGllbnRGYWN0b3J5LmdldEh0dHBDbGllbnQoQ2xpZW50TmFtZXMuQXhpb3MsIG9wdGlvbnMpO1xuICAgIGV4cGVjdChodHRwQ2xpZW50KS50b0JlSW5zdGFuY2VPZihBeGlvc0NsaWVudCk7XG4gICAgLy8gQHRzLWV4cGVjdC1lcnJvcjogb3B0aW9ucyBpcyBub3QgcHJlc2VudCBidXQgZm9yIHRlc3RpbmcgcHVycG9zZSB3ZSBuZWVkIHRoaXMgdG8gYmUgaWdub3JlZFxuICAgIGV4cGVjdChodHRwQ2xpZW50Lm9wdGlvbnMudGltZW91dCkudG9FcXVhbChvcHRpb25zLnRpbWVvdXQpO1xuICB9KTtcblxuICAvLyBUZXN0cyB0aGF0IGdldEh0dHBDbGllbnQgdGhyb3dzIGEgUGxhdGZvcm1FcnJvciB3aXRoIG1lc3NhZ2UgJ0ludmFsaWQgY2xpZW50IG5hbWUnIHdoZW4gbmFtZSBpcyBub3QgYSB2YWxpZCBDbGllbnROYW1lcyBlbnVtIHZhbHVlXG4gIGl0KCdzaG91bGQgdGhyb3cgYSBQbGF0Zm9ybUVycm9yIHdpdGggbWVzc2FnZSBcIkludmFsaWQgY2xpZW50IG5hbWVcIiB3aGVuIG5hbWUgaXMgbm90IGEgdmFsaWQgQ2xpZW50TmFtZXMgZW51bSB2YWx1ZScsICgpID0+IHtcbiAgICBjb25zdCBpbnZhbGlkTmFtZSA9ICdJbnZhbGlkQ2xpZW50JztcbiAgICBleHBlY3QoKCkgPT4ge1xuICAgICAgSHR0cENsaWVudEZhY3RvcnkuZ2V0SHR0cENsaWVudChpbnZhbGlkTmFtZSBhcyBDbGllbnROYW1lcyk7XG4gICAgfSkudG9UaHJvd0Vycm9yKFBsYXRmb3JtRXJyb3IpO1xuICAgIGV4cGVjdCgoKSA9PiB7XG4gICAgICBIdHRwQ2xpZW50RmFjdG9yeS5nZXRIdHRwQ2xpZW50KGludmFsaWROYW1lIGFzIENsaWVudE5hbWVzKTtcbiAgICB9KS50b1Rocm93RXJyb3IoJ0ludmFsaWQgY2xpZW50IG5hbWUnKTtcbiAgfSk7XG5cbiAgLy8gVW5jb21tZW50IHRoZSBmb2xsb3dpbmcgdGVzdHMgYXMgd2UgaW1wbGVtZW50IHRoZSBGZXRjaENsaWVudCBhbmQgWGhyQ2xpZW50IGNsYXNzZXNcbiAgLy8gLy8gVGVzdHMgdGhhdCBnZXRIdHRwQ2xpZW50IHJldHVybnMgYSBGZXRjaENsaWVudCBpbnN0YW5jZSB3aGVuIG5hbWUgaXMgQ2xpZW50TmFtZXMuRmV0Y2hcbiAgLy8gaXQoJ3Nob3VsZCByZXR1cm4gYSBGZXRjaENsaWVudCBpbnN0YW5jZSB3aGVuIG5hbWUgaXMgQ2xpZW50TmFtZXMuRmV0Y2gnLCAoKSA9PiB7XG4gIC8vICAgamVzdC5tb2NrKCcuL2NsaWVudHMvZmV0Y2gnLCAoKSA9PiAoe1xuICAvLyAgICAgRmV0Y2hDbGllbnQ6IGplc3QuZm4oKSxcbiAgLy8gICB9KSk7XG4gIC8vICAgY29uc3QgeyBGZXRjaENsaWVudCB9ID0gcmVxdWlyZSgnLi9jbGllbnRzL2ZldGNoJyk7XG4gIC8vICAgY29uc3QgaHR0cENsaWVudCA9IEh0dHBDbGllbnRGYWN0b3J5LmdldEh0dHBDbGllbnQoQ2xpZW50TmFtZXMuRmV0Y2gpO1xuICAvLyAgIGV4cGVjdChodHRwQ2xpZW50KS50b0JlKEZldGNoQ2xpZW50KTtcbiAgLy8gfSk7XG5cbiAgLy8gLy8gVGVzdHMgdGhhdCBnZXRIdHRwQ2xpZW50IHJldHVybnMgYW4gWGhyQ2xpZW50IGluc3RhbmNlIHdoZW4gbmFtZSBpcyBDbGllbnROYW1lcy5YaHJcbiAgLy8gaXQoJ3Nob3VsZCByZXR1cm4gYW4gWGhyQ2xpZW50IGluc3RhbmNlIHdoZW4gbmFtZSBpcyBDbGllbnROYW1lcy5YaHInLCAoKSA9PiB7XG4gIC8vICAgamVzdC5tb2NrKCcuL2NsaWVudHMveGhyJywgKCkgPT4gKHtcbiAgLy8gICAgIFhockNsaWVudDogamVzdC5mbigpLFxuICAvLyAgIH0pKTtcbiAgLy8gICBjb25zdCB7IFhockNsaWVudCB9ID0gcmVxdWlyZSgnLi9jbGllbnRzL3hocicpO1xuICAvLyAgIGNvbnN0IGh0dHBDbGllbnQgPSBIdHRwQ2xpZW50RmFjdG9yeS5nZXRIdHRwQ2xpZW50KENsaWVudE5hbWVzLlhocik7XG4gIC8vICAgZXhwZWN0KGh0dHBDbGllbnQpLnRvQmUoWGhyQ2xpZW50KTtcbiAgLy8gfSk7XG59KTtcbiJdfQ==
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=index.test.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.test.d.ts","sourceRoot":"","sources":["../../../src/sdks/customerio_audience/index.test.ts"],"names":[],"mappings":""}
@@ -1,121 +0,0 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- const index_1 = __importDefault(require("./index"));
7
- const axios_client_1 = require("../../network/clients/axios_client");
8
- const utils_1 = require("./utils");
9
- jest.mock('../../network/clients/axios_client', () => ({
10
- AxiosClient: jest.fn().mockImplementation(() => ({
11
- get: jest.fn(),
12
- post: jest.fn(),
13
- })),
14
- }));
15
- describe('CustomerIOSegment', () => {
16
- let customerIOSegment;
17
- let mockClient;
18
- const mockAppApiKey = 'test-api-key';
19
- beforeEach(() => {
20
- jest.clearAllMocks();
21
- mockClient = new axios_client_1.AxiosClient();
22
- customerIOSegment = new index_1.default({ appApiKey: mockAppApiKey }, mockClient);
23
- });
24
- describe('constructor', () => {
25
- it('should create instance with valid auth object', () => {
26
- expect(customerIOSegment).toBeInstanceOf(index_1.default);
27
- expect(customerIOSegment.getAppApiKey()).toBe(mockAppApiKey);
28
- });
29
- it('should throw error if appApiKey is missing', () => {
30
- expect(() => new index_1.default({})).toThrow('appApiKey is required and must be a string');
31
- });
32
- it('should throw error if appApiKey is not a string', () => {
33
- expect(() => new index_1.default({ appApiKey: 123 })).toThrow('appApiKey is required and must be a string');
34
- });
35
- });
36
- describe('getAppApiKey', () => {
37
- it('should return the app api key', () => {
38
- expect(customerIOSegment.getAppApiKey()).toBe(mockAppApiKey);
39
- });
40
- });
41
- describe('getSegments', () => {
42
- const mockSuccessResponse = {
43
- type: 'success',
44
- responseBody: {
45
- segments: [
46
- {
47
- id: 1,
48
- name: 'Test Segment',
49
- description: 'Test Description',
50
- },
51
- ],
52
- },
53
- statusCode: 200,
54
- headers: {},
55
- };
56
- const mockErrorResponse = {
57
- type: 'client-error',
58
- message: 'Not Found',
59
- statusCode: 404,
60
- };
61
- it('should fetch segments successfully', async () => {
62
- mockClient.get.mockResolvedValue(mockSuccessResponse);
63
- const result = await customerIOSegment.getSegments();
64
- expect(mockClient.get).toHaveBeenCalledWith(index_1.default.url, {
65
- headers: {
66
- Accept: 'application/json',
67
- Authorization: `Bearer ${mockAppApiKey}`,
68
- },
69
- });
70
- expect(result).toEqual(mockSuccessResponse.responseBody);
71
- });
72
- it('should throw RestError when fetching segments fails', async () => {
73
- mockClient.get.mockResolvedValue(mockErrorResponse);
74
- await expect(customerIOSegment.getSegments()).rejects.toThrow(utils_1.RestError);
75
- await expect(customerIOSegment.getSegments()).rejects.toThrow('Not Found');
76
- });
77
- });
78
- describe('createSegment', () => {
79
- const mockSegmentBody = {
80
- segment: {
81
- name: 'Test Segment',
82
- description: 'Test Description',
83
- },
84
- };
85
- const mockSuccessResponse = {
86
- type: 'success',
87
- responseBody: {
88
- segment: {
89
- id: 1,
90
- name: 'Test Segment',
91
- description: 'Test Description',
92
- state: 'active',
93
- },
94
- },
95
- statusCode: 201,
96
- headers: {},
97
- };
98
- const mockErrorResponse = {
99
- type: 'client-error',
100
- message: 'Bad Request',
101
- statusCode: 400,
102
- };
103
- it('should create segment successfully', async () => {
104
- mockClient.post.mockResolvedValue(mockSuccessResponse);
105
- const result = await customerIOSegment.createSegment(mockSegmentBody);
106
- expect(mockClient.post).toHaveBeenCalledWith(index_1.default.url, mockSegmentBody, {
107
- headers: {
108
- 'Content-Type': 'application/json',
109
- Authorization: `Bearer ${mockAppApiKey}`,
110
- },
111
- });
112
- expect(result).toEqual(mockSuccessResponse.responseBody);
113
- });
114
- it('should throw RestError when creating segment fails', async () => {
115
- mockClient.post.mockResolvedValue(mockErrorResponse);
116
- await expect(customerIOSegment.createSegment(mockSegmentBody)).rejects.toThrow(utils_1.RestError);
117
- await expect(customerIOSegment.createSegment(mockSegmentBody)).rejects.toThrow('Bad Request');
118
- });
119
- });
120
- });
121
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXgudGVzdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9zZGtzL2N1c3RvbWVyaW9fYXVkaWVuY2UvaW5kZXgudGVzdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLG9EQUF3QztBQUN4QyxxRUFBaUU7QUFDakUsbUNBQW9DO0FBSXBDLElBQUksQ0FBQyxJQUFJLENBQUMsb0NBQW9DLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FBQztJQUNyRCxXQUFXLEVBQUUsSUFBSSxDQUFDLEVBQUUsRUFBRSxDQUFDLGtCQUFrQixDQUFDLEdBQUcsRUFBRSxDQUFDLENBQUM7UUFDL0MsR0FBRyxFQUFFLElBQUksQ0FBQyxFQUFFLEVBQUU7UUFDZCxJQUFJLEVBQUUsSUFBSSxDQUFDLEVBQUUsRUFBRTtLQUNoQixDQUFDLENBQUM7Q0FDSixDQUFDLENBQUMsQ0FBQztBQUVKLFFBQVEsQ0FBQyxtQkFBbUIsRUFBRSxHQUFHLEVBQUU7SUFDakMsSUFBSSxpQkFBb0MsQ0FBQztJQUN6QyxJQUFJLFVBQW9DLENBQUM7SUFDekMsTUFBTSxhQUFhLEdBQUcsY0FBYyxDQUFDO0lBRXJDLFVBQVUsQ0FBQyxHQUFHLEVBQUU7UUFDZCxJQUFJLENBQUMsYUFBYSxFQUFFLENBQUM7UUFDckIsVUFBVSxHQUFHLElBQUksMEJBQVcsRUFBOEIsQ0FBQztRQUMzRCxpQkFBaUIsR0FBRyxJQUFJLGVBQWlCLENBQUMsRUFBRSxTQUFTLEVBQUUsYUFBYSxFQUFFLEVBQUUsVUFBVSxDQUFDLENBQUM7SUFDdEYsQ0FBQyxDQUFDLENBQUM7SUFFSCxRQUFRLENBQUMsYUFBYSxFQUFFLEdBQUcsRUFBRTtRQUMzQixFQUFFLENBQUMsK0NBQStDLEVBQUUsR0FBRyxFQUFFO1lBQ3ZELE1BQU0sQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDLGNBQWMsQ0FBQyxlQUFpQixDQUFDLENBQUM7WUFDNUQsTUFBTSxDQUFDLGlCQUFpQixDQUFDLFlBQVksRUFBRSxD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QU8sQ0FBQyxPQUFPLENBQUMsaUJBQVMsQ0FBQyxDQUFDO1lBQzFGLE1BQU0sTUFBTSxDQUFDLGlCQUFpQixDQUFDLGFBQWEsQ0FBQyxlQUFlLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsYUFBYSxDQUFDLENBQUM7UUFDaEcsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDLENBQUMsQ0FBQztBQUNMLENBQUMsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IEN1c3RvbWVySU9TZWdtZW50IGZyb20gJy4vaW5kZXgnO1xuaW1wb3J0IHsgQXhpb3NDbGllbnQgfSBmcm9tICcuLi8uLi9uZXR3b3JrL2NsaWVudHMvYXhpb3NfY2xpZW50JztcbmltcG9ydCB7IFJlc3RFcnJvciB9IGZyb20gJy4vdXRpbHMnO1xuaW1wb3J0IHsgR2V0U2VnbWVudHNSZXNwb25zZSwgQ3JlYXRlU2VnbWVudFJlc3BvbnNlIH0gZnJvbSAnLi90eXBlJztcbmltcG9ydCB7IEFwaVJlc3BvbnNlIH0gZnJvbSAnLi4vLi4vbmV0d29yayc7XG5cbmplc3QubW9jaygnLi4vLi4vbmV0d29yay9jbGllbnRzL2F4aW9zX2NsaWVudCcsICgpID0+ICh7XG4gIEF4aW9zQ2xpZW50OiBqZXN0LmZuKCkubW9ja0ltcGxlbWVudGF0aW9uKCgpID0+ICh7XG4gICAgZ2V0OiBqZXN0LmZuKCksXG4gICAgcG9zdDogamVzdC5mbigpLFxuICB9KSksXG59KSk7XG5cbmRlc2NyaWJlKCdDdXN0b21lcklPU2VnbWVudCcsICgpID0+IHtcbiAgbGV0IGN1c3RvbWVySU9TZWdtZW50OiBDdXN0b21lcklPU2VnbWVudDtcbiAgbGV0IG1vY2tDbGllbnQ6IGplc3QuTW9ja2VkPEF4aW9zQ2xpZW50PjtcbiAgY29uc3QgbW9ja0FwcEFwaUtleSA9ICd0ZXN0LWFwaS1rZXknO1xuXG4gIGJlZm9yZUVhY2goKCkgPT4ge1xuICAgIGplc3QuY2xlYXJBbGxNb2NrcygpO1xuICAgIG1vY2tDbGllbnQgPSBuZXcgQXhpb3NDbGllbnQoKSBhcyBqZXN0Lk1vY2tlZDxBeGlvc0NsaWVudD47XG4gICAgY3VzdG9tZXJJT1NlZ21lbnQgPSBuZXcgQ3VzdG9tZXJJT1NlZ21lbnQoeyBhcHBBcGlLZXk6IG1vY2tBcHBBcGlLZXkgfSwgbW9ja0NsaWVudCk7XG4gIH0pO1xuXG4gIGRlc2NyaWJlKCdjb25zdHJ1Y3RvcicsICgpID0+IHtcbiAgICBpdCgnc2hvdWxkIGNyZWF0ZSBpbnN0YW5jZSB3aXRoIHZhbGlkIGF1dGggb2JqZWN0JywgKCkgPT4ge1xuICAgICAgZXhwZWN0KGN1c3RvbWVySU9TZWdtZW50KS50b0JlSW5zdGFuY2VPZihDdXN0b21lcklPU2VnbWVudCk7XG4gICAgICBleHBlY3QoY3VzdG9tZXJJT1NlZ21lbnQuZ2V0QXBwQXBpS2V5KCkpLnRvQmUobW9ja0FwcEFwaUtleSk7XG4gICAgfSk7XG5cbiAgICBpdCgnc2hvdWxkIHRocm93IGVycm9yIGlmIGFwcEFwaUtleSBpcyBtaXNzaW5nJywgKCkgPT4ge1xuICAgICAgZXhwZWN0KCgpID0+IG5ldyBDdXN0b21lcklPU2VnbWVudCh7fSBhcyBhbnkpKS50b1Rocm93KFxuICAgICAgICAnYXBwQXBpS2V5IGlzIHJlcXVpcmVkIGFuZCBtdXN0IGJlIGEgc3RyaW5nJyxcbiAgICAgICk7XG4gICAgfSk7XG5cbiAgICBpdCgnc2hvdWxkIHRocm93IGVycm9yIGlmIGFwcEFwaUtleSBpcyBub3QgYSBzdHJpbmcnLCAoKSA9PiB7XG4gICAgICBleHBlY3QoKCkgPT4gbmV3IEN1c3RvbWVySU9TZWdtZW50KHsgYXBwQXBpS2V5OiAxMjMgfSBhcyBhbnkpKS50b1Rocm93KFxuICAgICAgICAnYXBwQXBpS2V5IGlzIHJlcXVpcmVkIGFuZCBtdXN0IGJlIGEgc3RyaW5nJyxcbiAgICAgICk7XG4gICAgfSk7XG4gIH0pO1xuXG4gIGRlc2NyaWJlKCdnZXRBcHBBcGlLZXknLCAoKSA9PiB7XG4gICAgaXQoJ3Nob3VsZCByZXR1cm4gdGhlIGFwcCBhcGkga2V5JywgKCkgPT4ge1xuICAgICAgZXhwZWN0KGN1c3RvbWVySU9TZWdtZW50LmdldEFwcEFwaUtleSgpKS50b0JlKG1vY2tBcHBBcGlLZXkpO1xuICAgIH0pO1xuICB9KTtcblxuICBkZXNjcmliZSgnZ2V0U2VnbWVudHMnLCAoKSA9PiB7XG4gICAgY29uc3QgbW9ja1N1Y2Nlc3NSZXNwb25zZTogQXBpUmVzcG9uc2U8R2V0U2VnbWVudHNSZXNwb25zZT4gPSB7XG4gICAgICB0eXBlOiAnc3VjY2VzcycsXG4gICAgICByZXNwb25zZUJvZHk6IHtcbiAgICAgICAgc2VnbWVudHM6IFtcbiAgICAgICAgICB7XG4gICAgICAgICAgICBpZDogMSxcbiAgICAgICAgICAgIG5hbWU6ICdUZXN0IFNlZ21lbnQnLFxuICAgICAgICAgICAgZGVzY3JpcHRpb246ICdUZXN0IERlc2NyaXB0aW9uJyxcbiAgICAgICAgICB9LFxuICAgICAgICBdLFxuICAgICAgfSxcbiAgICAgIHN0YXR1c0NvZGU6IDIwMCxcbiAgICAgIGhlYWRlcnM6IHt9LFxuICAgIH07XG5cbiAgICBjb25zdCBtb2NrRXJyb3JSZXNwb25zZTogQXBpUmVzcG9uc2U8YW55PiA9IHtcbiAgICAgIHR5cGU6ICdjbGllbnQtZXJyb3InLFxuICAgICAgbWVzc2FnZTogJ05vdCBGb3VuZCcsXG4gICAgICBzdGF0dXNDb2RlOiA0MDQsXG4gICAgfTtcblxuICAgIGl0KCdzaG91bGQgZmV0Y2ggc2VnbWVudHMgc3VjY2Vzc2Z1bGx5JywgYXN5bmMgKCkgPT4ge1xuICAgICAgbW9ja0NsaWVudC5nZXQubW9ja1Jlc29sdmVkVmFsdWUobW9ja1N1Y2Nlc3NSZXNwb25zZSk7XG5cbiAgICAgIGNvbnN0IHJlc3VsdCA9IGF3YWl0IGN1c3RvbWVySU9TZWdtZW50LmdldFNlZ21lbnRzKCk7XG5cbiAgICAgIGV4cGVjdChtb2NrQ2xpZW50LmdldCkudG9IYXZlQmVlbkNhbGxlZFdpdGgoQ3VzdG9tZXJJT1NlZ21lbnQudXJsLCB7XG4gICAgICAgIGhlYWRlcnM6IHtcbiAgICAgICAgICBBY2NlcHQ6ICdhcHBsaWNhdGlvbi9qc29uJyxcbiAgICAgICAgICBBdXRob3JpemF0aW9uOiBgQmVhcmVyICR7bW9ja0FwcEFwaUtleX1gLFxuICAgICAgICB9LFxuICAgICAgfSk7XG4gICAgICBleHBlY3QocmVzdWx0KS50b0VxdWFsKG1vY2tTdWNjZXNzUmVzcG9uc2UucmVzcG9uc2VCb2R5KTtcbiAgICB9KTtcblxuICAgIGl0KCdzaG91bGQgdGhyb3cgUmVzdEVycm9yIHdoZW4gZmV0Y2hpbmcgc2VnbWVudHMgZmFpbHMnLCBhc3luYyAoKSA9PiB7XG4gICAgICBtb2NrQ2xpZW50LmdldC5tb2NrUmVzb2x2ZWRWYWx1ZShtb2NrRXJyb3JSZXNwb25zZSk7XG5cbiAgICAgIGF3YWl0IGV4cGVjdChjdXN0b21lcklPU2VnbWVudC5nZXRTZWdtZW50cygpKS5yZWplY3RzLnRvVGhyb3coUmVzdEVycm9yKTtcbiAgICAgIGF3YWl0IGV4cGVjdChjdXN0b21lcklPU2VnbWVudC5nZXRTZWdtZW50cygpKS5yZWplY3RzLnRvVGhyb3coJ05vdCBGb3VuZCcpO1xuICAgIH0pO1xuICB9KTtcblxuICBkZXNjcmliZSgnY3JlYXRlU2VnbWVudCcsICgpID0+IHtcbiAgICBjb25zdCBtb2NrU2VnbWVudEJvZHkgPSB7XG4gICAgICBzZWdtZW50OiB7XG4gICAgICAgIG5hbWU6ICdUZXN0IFNlZ21lbnQnLFxuICAgICAgICBkZXNjcmlwdGlvbjogJ1Rlc3QgRGVzY3JpcHRpb24nLFxuICAgICAgfSxcbiAgICB9O1xuXG4gICAgY29uc3QgbW9ja1N1Y2Nlc3NSZXNwb25zZTogQXBpUmVzcG9uc2U8Q3JlYXRlU2VnbWVudFJlc3BvbnNlPiA9IHtcbiAgICAgIHR5cGU6ICdzdWNjZXNzJyxcbiAgICAgIHJlc3BvbnNlQm9keToge1xuICAgICAgICBzZWdtZW50OiB7XG4gICAgICAgICAgaWQ6IDEsXG4gICAgICAgICAgbmFtZTogJ1Rlc3QgU2VnbWVudCcsXG4gICAgICAgICAgZGVzY3JpcHRpb246ICdUZXN0IERlc2NyaXB0aW9uJyxcbiAgICAgICAgICBzdGF0ZTogJ2FjdGl2ZScsXG4gICAgICAgIH0sXG4gICAgICB9LFxuICAgICAgc3RhdHVzQ29kZTogMjAxLFxuICAgICAgaGVhZGVyczoge30sXG4gICAgfTtcblxuICAgIGNvbnN0IG1vY2tFcnJvclJlc3BvbnNlOiBBcGlSZXNwb25zZTxhbnk+ID0ge1xuICAgICAgdHlwZTogJ2NsaWVudC1lcnJvcicsXG4gICAgICBtZXNzYWdlOiAnQmFkIFJlcXVlc3QnLFxuICAgICAgc3RhdHVzQ29kZTogNDAwLFxuICAgIH07XG5cbiAgICBpdCgnc2hvdWxkIGNyZWF0ZSBzZWdtZW50IHN1Y2Nlc3NmdWxseScsIGFzeW5jICgpID0+IHtcbiAgICAgIG1vY2tDbGllbnQucG9zdC5tb2NrUmVzb2x2ZWRWYWx1ZShtb2NrU3VjY2Vzc1Jlc3BvbnNlKTtcblxuICAgICAgY29uc3QgcmVzdWx0ID0gYXdhaXQgY3VzdG9tZXJJT1NlZ21lbnQuY3JlYXRlU2VnbWVudChtb2NrU2VnbWVudEJvZHkpO1xuXG4gICAgICBleHBlY3QobW9ja0NsaWVudC5wb3N0KS50b0hhdmVCZWVuQ2FsbGVkV2l0aChDdXN0b21lcklPU2VnbWVudC51cmwsIG1vY2tTZWdtZW50Qm9keSwge1xuICAgICAgICBoZWFkZXJzOiB7XG4gICAgICAgICAgJ0NvbnRlbnQtVHlwZSc6ICdhcHBsaWNhdGlvbi9qc29uJyxcbiAgICAgICAgICBBdXRob3JpemF0aW9uOiBgQmVhcmVyICR7bW9ja0FwcEFwaUtleX1gLFxuICAgICAgICB9LFxuICAgICAgfSk7XG4gICAgICBleHBlY3QocmVzdWx0KS50b0VxdWFsKG1vY2tTdWNjZXNzUmVzcG9uc2UucmVzcG9uc2VCb2R5KTtcbiAgICB9KTtcblxuICAgIGl0KCdzaG91bGQgdGhyb3cgUmVzdEVycm9yIHdoZW4gY3JlYXRpbmcgc2VnbWVudCBmYWlscycsIGFzeW5jICgpID0+IHtcbiAgICAgIG1vY2tDbGllbnQucG9zdC5tb2NrUmVzb2x2ZWRWYWx1ZShtb2NrRXJyb3JSZXNwb25zZSk7XG5cbiAgICAgIGF3YWl0IGV4cGVjdChjdXN0b21lcklPU2VnbWVudC5jcmVhdGVTZWdtZW50KG1vY2tTZWdtZW50Qm9keSkpLnJlamVjdHMudG9UaHJvdyhSZXN0RXJyb3IpO1xuICAgICAgYXdhaXQgZXhwZWN0KGN1c3RvbWVySU9TZWdtZW50LmNyZWF0ZVNlZ21lbnQobW9ja1NlZ21lbnRCb2R5KSkucmVqZWN0cy50b1Rocm93KCdCYWQgUmVxdWVzdCcpO1xuICAgIH0pO1xuICB9KTtcbn0pO1xuIl19
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=googleAds.test.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"googleAds.test.d.ts","sourceRoot":"","sources":["../../../src/sdks/googleAdsRestAPI/googleAds.test.ts"],"names":[],"mappings":""}