@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,{"version":3,"file":"axios_client.test.js","sourceRoot":"","sources":["../../../src/network/clients/axios_client.test.ts"],"names":[],"mappings":"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","sourcesContent":["import axios, { AxiosError } from 'axios';\nimport MockAdapter from 'axios-mock-adapter';\nimport { AxiosClient } from './axios_client'; // Import the AxiosClient class\nimport {\n  ApplicationErrorApiResponse,\n  ClientErrorApiResponse,\n  SuccessfulApiResponse,\n} from './types';\n\n// Mock Axios for testing\njest.mock('axios', () => ({\n  ...(jest.requireActual('axios') as object),\n  create: jest.fn().mockReturnValue(jest.requireActual('axios')),\n}));\n\n// Test cases\ndescribe('AxiosClient', () => {\n  let axiosClient: AxiosClient;\n  let mockAxios;\n\n  beforeEach(() => {\n    mockAxios = new MockAdapter(axios); // Create a MockAdapter for Axios\n    axiosClient = new AxiosClient(); // Create a new AxiosClient instance for each test\n  });\n\n  afterEach(() => {\n    mockAxios.restore();\n  });\n\n  describe('happy flow tests', () => {\n    // Scenario 1: GET request and receive a response\n    it('should make a GET request and receive a response', async () => {\n      // Mock the GET request using axios-mock-adapter\n      mockAxios.onGet('https://example.com').reply(200, 'GET response');\n      const response = (await axiosClient.get(\n        'https://example.com',\n      )) as SuccessfulApiResponse<string>;\n      expect(response.type).toBe('success');\n      expect(response.statusCode).toBe(200);\n      expect(response.responseBody).toBe('GET response');\n    });\n\n    // Scenario 2: POST request and receive a response\n    it('should make a POST request and receive a response', async () => {\n      // Mock the axios.post method to return a response\n      mockAxios.onPost('https://example.com').reply(201, 'POST response');\n\n      const response = (await axiosClient.post(\n        'https://example.com',\n        {\n          foo: 'bar',\n        },\n        { timeout: 1000 },\n      )) as SuccessfulApiResponse<string>;\n      expect(response.type).toBe('success');\n      expect(response.statusCode).toBe(201);\n      expect(response.responseBody).toBe('POST response');\n    });\n\n    // Scenario 3: PUT request and receive a response\n    it('should make a PUT request and receive a response', async () => {\n      // Mock the axios.put method to return a response\n      mockAxios.onPut('https://example.com').reply(204);\n\n      const response = (await axiosClient.put(\n        'https://example.com',\n        {\n          foo: 'bar',\n        },\n        { timeout: 100 },\n      )) as SuccessfulApiResponse<string>;\n      expect(response.type).toBe('success');\n      expect(response.statusCode).toBe(204);\n      expect(response.responseBody).toBeUndefined(); // No response body for PUT\n    });\n\n    // Scenario 4: PATCH request and receive a response\n    it('should make a PATCH request and receive a response', async () => {\n      // Mock the axios.patch method to return a response\n      mockAxios.onPatch('https://example.com').reply(200, 'PATCH response');\n\n      const response = (await axiosClient.patch(\n        'https://example.com',\n        {\n          foo: 'bar',\n        },\n        { timeout: 500 },\n      )) as SuccessfulApiResponse<string>;\n      expect(response.type).toBe('success');\n      expect(response.statusCode).toBe(200);\n      expect(response.responseBody).toBe('PATCH response');\n    });\n\n    // Scenario 5: DELETE request and receive a response\n    it('should make a DELETE request and receive a response', async () => {\n      // Mock the axios.delete method to return a response\n      mockAxios.onDelete('https://example.com').reply(204);\n\n      const response = (await axiosClient.delete('https://example.com', {\n        timeout: 420,\n      })) as SuccessfulApiResponse<string>;\n      expect(response.type).toBe('success');\n      expect(response.statusCode).toBe(204);\n      expect(response.responseBody).toBeUndefined(); // No response body for DELETE\n    });\n\n    // Scenario 6: GET request with a response parser\n    it('should make a GET request with a response parser', async () => {\n      // Mock the GET request using axios-mock-adapter\n      mockAxios.onGet('https://example.com').reply(200, 'GET response');\n\n      const response = (await axiosClient.get(\n        'https://example.com',\n        {},\n        (data) => `Parsed ${data}`,\n      )) as SuccessfulApiResponse<string>;\n      expect(response.type).toBe('success');\n      expect(response.statusCode).toBe(200);\n      expect(response.responseBody).toBe('Parsed GET response');\n    });\n\n    // Scenario 7: POST request with a response parser\n    it('should make a POST request with a response parser', async () => {\n      // Mock the axios.post method to return a response\n      mockAxios.onPost('https://example.com').reply(201, 'POST response');\n\n      const response = (await axiosClient.post(\n        'https://example.com',\n        {\n          foo: 'bar',\n        },\n        {},\n        (data) => `Parsed ${data}`,\n      )) as SuccessfulApiResponse<string>;\n      expect(response.type).toBe('success');\n      expect(response.statusCode).toBe(201);\n      expect(response.responseBody).toBe('Parsed POST response');\n    });\n\n    // Scenario 8: PUT request with a response parser\n    it('should make a PUT request with a response parser', async () => {\n      // Mock the axios.put method to return a response\n      mockAxios.onPut('https://example.com').reply(204);\n\n      const response = (await axiosClient.put(\n        'https://example.com',\n        {\n          foo: 'bar',\n        },\n        {},\n        (data) => `Parsed ${data}`,\n      )) as SuccessfulApiResponse<string>;\n      expect(response.type).toBe('success');\n      expect(response.statusCode).toBe(204);\n      expect(response.responseBody).toBe('Parsed undefined'); // No response body for PUT\n    });\n\n    // Scenario 9: PATCH request with a response parser\n    it('should make a PATCH request with a response parser', async () => {\n      // Mock the axios.patch method to return a response\n      mockAxios.onPatch('https://example.com').reply(200, 'PATCH response');\n\n      const response = (await axiosClient.patch(\n        'https://example.com',\n        {\n          foo: 'bar',\n        },\n        {},\n        (data) => `Parsed ${data}`,\n      )) as SuccessfulApiResponse<string>;\n      expect(response.type).toBe('success');\n      expect(response.statusCode).toBe(200);\n      expect(response.responseBody).toBe('Parsed PATCH response');\n    });\n\n    // Scenario 10: DELETE request with a response parser\n    it('should make a DELETE request with a response parser', async () => {\n      // Mock the axios.delete method to return a response\n      mockAxios.onDelete('https://example.com').reply(204);\n\n      const response = (await axiosClient.delete(\n        'https://example.com',\n        {},\n        (data) => `Parsed ${data}`,\n      )) as SuccessfulApiResponse<string>;\n      expect(response.type).toBe('success');\n      expect(response.statusCode).toBe(204);\n      expect(response.responseBody).toBe('Parsed undefined'); // No response body for DELETE\n    });\n\n    // Scenario 11: GET request with headers\n    it('should make a GET request with headers', async () => {\n      // Mock the GET request using axios-mock-adapter\n      mockAxios.onGet('https://example.com').reply((config) => {\n        expect(config.headers.foo).toEqual('bar');\n        return [\n          200,\n          'GET response',\n          {\n            Authorization: `Bearer Token`,\n            'Content-type': 'application/x-www-form-urlencoded',\n          },\n        ];\n      });\n\n      const response = (await axiosClient.get('https://example.com', {\n        headers: { foo: 'bar' },\n      })) as SuccessfulApiResponse<string>;\n      expect(response.type).toBe('success');\n      expect(response.statusCode).toBe(200);\n      expect(response.responseBody).toBe('GET response');\n    });\n\n    // other happy flow tests\n    // Scenario 12:\n  });\n\n  describe('error flow tests', () => {\n    // Scenario 1: GET request and receive a network error\n    it('should make a GET request and receive a network error', async () => {\n      // Mock the GET request using axios-mock-adapter\n      mockAxios.onGet('https://example.com').abortRequest();\n\n      const response = (await axiosClient.get('https://example.com')) as ClientErrorApiResponse;\n      expect(response.type).toBe('client-error');\n      expect(response.statusCode).toBe(500);\n      expect(response.message).toBe('Unknown Error:Request aborted');\n    });\n\n    // should handle timeout errors\n    it('should make a GET request and receive a timeout error', async () => {\n      // Mock the GET request using axios-mock-adapter\n      mockAxios.onGet('https://example.com').timeout();\n\n      const response = (await axiosClient.get('https://example.com')) as ClientErrorApiResponse;\n      expect(response.type).toBe('client-error');\n      expect(response.statusCode).toBe(500);\n      expect(response.message).toBe('Unknown Error:timeout of 0ms exceeded');\n    });\n\n    it('should make a GET request and receive a network error', async () => {\n      // Mock the GET request using axios-mock-adapter\n      mockAxios.onGet('https://example.com').networkError();\n\n      const response = (await axiosClient.get('https://example.com')) as ClientErrorApiResponse;\n      expect(response.type).toBe('client-error');\n      expect(response.statusCode).toBe(500);\n      expect(response.message).toBe('Network Error');\n    });\n\n    // should handle application errors (4xx)\n    it('should make a GET request and receive a 400 error', async () => {\n      // Mock the GET request using axios-mock-adapter\n      mockAxios.onGet('https://example.com').reply(400, 'Bad Request Received');\n\n      const response = (await axiosClient.get(\n        'https://example.com',\n      )) as ApplicationErrorApiResponse;\n      expect(response.type).toBe('application-error');\n      expect(response.statusCode).toBe(400);\n      expect(response.responseBody).toBe('Bad Request Received');\n    });\n\n    it('should make a GET request and receive a 500 error when errored with unknown code', async () => {\n      // Mock the GET request using axios-mock-adapter\n      mockAxios.onGet('https://example.com').reply((config) => {\n        const err = AxiosError.from('my error message', 'MY_CODE', config);\n        return Promise.reject(err);\n      });\n\n      const response = (await axiosClient.get(\n        'https://example.com',\n      )) as ApplicationErrorApiResponse;\n      expect(response.type).toBe('client-error');\n      expect(response.statusCode).toBe(500);\n      expect(response.message).toBe(`Unknown Error:undefined`);\n    });\n    it('should make a GET request and receive a 500 error when errored with EACCES code', async () => {\n      // Mock the GET request using axios-mock-adapter\n      mockAxios.onGet('https://example.com').reply((config) => {\n        const err = AxiosError.from('my error message', 'EACCES', config);\n        return Promise.reject(err);\n      });\n\n      const response = (await axiosClient.get(\n        'https://example.com',\n      )) as ApplicationErrorApiResponse;\n      expect(response.type).toBe('client-error');\n      expect(response.statusCode).toBe(400);\n      expect(response.message).toBe('[EACCES] :: Permission denied');\n    });\n\n    // should handle application errors (5xx)\n    it('should make a GET request and receive a 500 error', async () => {\n      // Mock the GET request using axios-mock-adapter\n      mockAxios.onGet('https://example.com').reply(500, 'Internal Server Error');\n\n      const response = (await axiosClient.get(\n        'https://example.com',\n      )) as ApplicationErrorApiResponse;\n      expect(response.type).toBe('application-error');\n      expect(response.statusCode).toBe(500);\n      expect(response.responseBody).toBe('Internal Server Error');\n    });\n\n    // should handle unexpected errors\n    it('should make a GET request and receive an unexpected error', async () => {\n      // Mock the GET request using axios-mock-adapter\n      mockAxios.onGet('https://example.com').reply(200, 'GET response');\n\n      const response = (await axiosClient.get('https://example.com', {}, (_data) => {\n        throw new Error('Unexpected Error');\n      })) as ClientErrorApiResponse;\n      expect(response.type).toBe('client-error');\n      expect(response.statusCode).toBe(500);\n      expect(response.message).toBe('Failed to parse response data: Unexpected Error');\n    });\n\n    // should handle empty response body\n    it('should make a GET request and receive an empty response body', async () => {\n      // Mock the GET request using axios-mock-adapter\n      mockAxios.onGet('https://example.com').reply(200);\n\n      const response = (await axiosClient.get(\n        'https://example.com',\n      )) as SuccessfulApiResponse<string>;\n      expect(response.type).toBe('success');\n      expect(response.statusCode).toBe(200);\n      expect(response.responseBody).toBeUndefined();\n    });\n  });\n});\n"]}
@@ -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,{"version":3,"file":"index.test.js","sourceRoot":"","sources":["../../../src/sdks/customerio_audience/index.test.ts"],"names":[],"mappings":"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","sourcesContent":["import CustomerIOSegment from './index';\nimport { AxiosClient } from '../../network/clients/axios_client';\nimport { RestError } from './utils';\nimport { GetSegmentsResponse, CreateSegmentResponse } from './type';\nimport { ApiResponse } from '../../network';\n\njest.mock('../../network/clients/axios_client', () => ({\n  AxiosClient: jest.fn().mockImplementation(() => ({\n    get: jest.fn(),\n    post: jest.fn(),\n  })),\n}));\n\ndescribe('CustomerIOSegment', () => {\n  let customerIOSegment: CustomerIOSegment;\n  let mockClient: jest.Mocked<AxiosClient>;\n  const mockAppApiKey = 'test-api-key';\n\n  beforeEach(() => {\n    jest.clearAllMocks();\n    mockClient = new AxiosClient() as jest.Mocked<AxiosClient>;\n    customerIOSegment = new CustomerIOSegment({ appApiKey: mockAppApiKey }, mockClient);\n  });\n\n  describe('constructor', () => {\n    it('should create instance with valid auth object', () => {\n      expect(customerIOSegment).toBeInstanceOf(CustomerIOSegment);\n      expect(customerIOSegment.getAppApiKey()).toBe(mockAppApiKey);\n    });\n\n    it('should throw error if appApiKey is missing', () => {\n      expect(() => new CustomerIOSegment({} as any)).toThrow(\n        'appApiKey is required and must be a string',\n      );\n    });\n\n    it('should throw error if appApiKey is not a string', () => {\n      expect(() => new CustomerIOSegment({ appApiKey: 123 } as any)).toThrow(\n        'appApiKey is required and must be a string',\n      );\n    });\n  });\n\n  describe('getAppApiKey', () => {\n    it('should return the app api key', () => {\n      expect(customerIOSegment.getAppApiKey()).toBe(mockAppApiKey);\n    });\n  });\n\n  describe('getSegments', () => {\n    const mockSuccessResponse: ApiResponse<GetSegmentsResponse> = {\n      type: 'success',\n      responseBody: {\n        segments: [\n          {\n            id: 1,\n            name: 'Test Segment',\n            description: 'Test Description',\n          },\n        ],\n      },\n      statusCode: 200,\n      headers: {},\n    };\n\n    const mockErrorResponse: ApiResponse<any> = {\n      type: 'client-error',\n      message: 'Not Found',\n      statusCode: 404,\n    };\n\n    it('should fetch segments successfully', async () => {\n      mockClient.get.mockResolvedValue(mockSuccessResponse);\n\n      const result = await customerIOSegment.getSegments();\n\n      expect(mockClient.get).toHaveBeenCalledWith(CustomerIOSegment.url, {\n        headers: {\n          Accept: 'application/json',\n          Authorization: `Bearer ${mockAppApiKey}`,\n        },\n      });\n      expect(result).toEqual(mockSuccessResponse.responseBody);\n    });\n\n    it('should throw RestError when fetching segments fails', async () => {\n      mockClient.get.mockResolvedValue(mockErrorResponse);\n\n      await expect(customerIOSegment.getSegments()).rejects.toThrow(RestError);\n      await expect(customerIOSegment.getSegments()).rejects.toThrow('Not Found');\n    });\n  });\n\n  describe('createSegment', () => {\n    const mockSegmentBody = {\n      segment: {\n        name: 'Test Segment',\n        description: 'Test Description',\n      },\n    };\n\n    const mockSuccessResponse: ApiResponse<CreateSegmentResponse> = {\n      type: 'success',\n      responseBody: {\n        segment: {\n          id: 1,\n          name: 'Test Segment',\n          description: 'Test Description',\n          state: 'active',\n        },\n      },\n      statusCode: 201,\n      headers: {},\n    };\n\n    const mockErrorResponse: ApiResponse<any> = {\n      type: 'client-error',\n      message: 'Bad Request',\n      statusCode: 400,\n    };\n\n    it('should create segment successfully', async () => {\n      mockClient.post.mockResolvedValue(mockSuccessResponse);\n\n      const result = await customerIOSegment.createSegment(mockSegmentBody);\n\n      expect(mockClient.post).toHaveBeenCalledWith(CustomerIOSegment.url, mockSegmentBody, {\n        headers: {\n          'Content-Type': 'application/json',\n          Authorization: `Bearer ${mockAppApiKey}`,\n        },\n      });\n      expect(result).toEqual(mockSuccessResponse.responseBody);\n    });\n\n    it('should throw RestError when creating segment fails', async () => {\n      mockClient.post.mockResolvedValue(mockErrorResponse);\n\n      await expect(customerIOSegment.createSegment(mockSegmentBody)).rejects.toThrow(RestError);\n      await expect(customerIOSegment.createSegment(mockSegmentBody)).rejects.toThrow('Bad Request');\n    });\n  });\n});\n"]}
@@ -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":""}