@capillarytech/creatives-library 8.0.266 → 8.0.267

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 (147) hide show
  1. package/constants/unified.js +0 -1
  2. package/package.json +1 -1
  3. package/services/api.js +0 -5
  4. package/utils/common.js +0 -6
  5. package/utils/tests/transformerUtils.test.js +0 -297
  6. package/utils/transformerUtils.js +0 -40
  7. package/v2Components/CapImageUpload/constants.js +0 -2
  8. package/v2Components/CapImageUpload/index.js +16 -65
  9. package/v2Components/CapImageUpload/index.scss +1 -4
  10. package/v2Components/CapImageUpload/messages.js +1 -5
  11. package/v2Components/CommonTestAndPreview/index.js +15 -4
  12. package/v2Containers/App/constants.js +0 -5
  13. package/v2Containers/CreativesContainer/SlideBoxContent.js +2 -57
  14. package/v2Containers/CreativesContainer/SlideBoxHeader.js +0 -1
  15. package/v2Containers/CreativesContainer/constants.js +0 -3
  16. package/v2Containers/CreativesContainer/index.js +0 -168
  17. package/v2Containers/CreativesContainer/messages.js +0 -4
  18. package/v2Containers/CreativesContainer/tests/SlideBoxContent.test.js +0 -210
  19. package/v2Containers/CreativesContainer/tests/__snapshots__/SlideBoxContent.test.js.snap +0 -304
  20. package/v2Containers/SmsTrai/Edit/index.js +12 -1
  21. package/v2Containers/SmsTrai/Edit/tests/__snapshots__/index.test.js.snap +648 -36
  22. package/v2Containers/Templates/ChannelTypeIllustration.js +1 -13
  23. package/v2Containers/Templates/_templates.scss +0 -205
  24. package/v2Containers/Templates/actions.js +1 -2
  25. package/v2Containers/Templates/constants.js +0 -1
  26. package/v2Containers/Templates/index.js +34 -274
  27. package/v2Containers/Templates/messages.js +0 -24
  28. package/v2Containers/Templates/reducer.js +0 -2
  29. package/v2Containers/Templates/tests/index.test.js +0 -10
  30. package/v2Containers/TemplatesV2/index.js +7 -15
  31. package/v2Containers/TemplatesV2/messages.js +0 -4
  32. package/utils/imageUrlUpload.js +0 -141
  33. package/v2Components/CapImageUrlUpload/constants.js +0 -26
  34. package/v2Components/CapImageUrlUpload/index.js +0 -365
  35. package/v2Components/CapImageUrlUpload/index.scss +0 -35
  36. package/v2Components/CapImageUrlUpload/messages.js +0 -47
  37. package/v2Containers/WebPush/Create/components/BrandIconSection.js +0 -108
  38. package/v2Containers/WebPush/Create/components/ButtonForm.js +0 -172
  39. package/v2Containers/WebPush/Create/components/ButtonItem.js +0 -101
  40. package/v2Containers/WebPush/Create/components/ButtonList.js +0 -145
  41. package/v2Containers/WebPush/Create/components/ButtonsLinksSection.js +0 -164
  42. package/v2Containers/WebPush/Create/components/ButtonsLinksSection.test.js +0 -463
  43. package/v2Containers/WebPush/Create/components/FormActions.js +0 -54
  44. package/v2Containers/WebPush/Create/components/FormActions.test.js +0 -163
  45. package/v2Containers/WebPush/Create/components/MediaSection.js +0 -142
  46. package/v2Containers/WebPush/Create/components/MediaSection.test.js +0 -341
  47. package/v2Containers/WebPush/Create/components/MessageSection.js +0 -103
  48. package/v2Containers/WebPush/Create/components/MessageSection.test.js +0 -268
  49. package/v2Containers/WebPush/Create/components/NotificationTitleSection.js +0 -87
  50. package/v2Containers/WebPush/Create/components/NotificationTitleSection.test.js +0 -210
  51. package/v2Containers/WebPush/Create/components/TemplateNameSection.js +0 -54
  52. package/v2Containers/WebPush/Create/components/TemplateNameSection.test.js +0 -143
  53. package/v2Containers/WebPush/Create/components/__snapshots__/ButtonsLinksSection.test.js.snap +0 -86
  54. package/v2Containers/WebPush/Create/components/__snapshots__/FormActions.test.js.snap +0 -16
  55. package/v2Containers/WebPush/Create/components/__snapshots__/MediaSection.test.js.snap +0 -41
  56. package/v2Containers/WebPush/Create/components/__snapshots__/MessageSection.test.js.snap +0 -54
  57. package/v2Containers/WebPush/Create/components/__snapshots__/NotificationTitleSection.test.js.snap +0 -37
  58. package/v2Containers/WebPush/Create/components/__snapshots__/TemplateNameSection.test.js.snap +0 -21
  59. package/v2Containers/WebPush/Create/components/_buttons.scss +0 -246
  60. package/v2Containers/WebPush/Create/components/tests/ButtonForm.test.js +0 -554
  61. package/v2Containers/WebPush/Create/components/tests/ButtonItem.test.js +0 -607
  62. package/v2Containers/WebPush/Create/components/tests/ButtonList.test.js +0 -633
  63. package/v2Containers/WebPush/Create/components/tests/__snapshots__/ButtonForm.test.js.snap +0 -666
  64. package/v2Containers/WebPush/Create/components/tests/__snapshots__/ButtonItem.test.js.snap +0 -74
  65. package/v2Containers/WebPush/Create/components/tests/__snapshots__/ButtonList.test.js.snap +0 -78
  66. package/v2Containers/WebPush/Create/hooks/useButtonManagement.js +0 -138
  67. package/v2Containers/WebPush/Create/hooks/useButtonManagement.test.js +0 -406
  68. package/v2Containers/WebPush/Create/hooks/useCharacterCount.js +0 -30
  69. package/v2Containers/WebPush/Create/hooks/useCharacterCount.test.js +0 -151
  70. package/v2Containers/WebPush/Create/hooks/useImageUpload.js +0 -104
  71. package/v2Containers/WebPush/Create/hooks/useImageUpload.test.js +0 -538
  72. package/v2Containers/WebPush/Create/hooks/useTagManagement.js +0 -122
  73. package/v2Containers/WebPush/Create/hooks/useTagManagement.test.js +0 -633
  74. package/v2Containers/WebPush/Create/index.js +0 -1148
  75. package/v2Containers/WebPush/Create/index.scss +0 -134
  76. package/v2Containers/WebPush/Create/messages.js +0 -211
  77. package/v2Containers/WebPush/Create/preview/DevicePreviewContent.js +0 -228
  78. package/v2Containers/WebPush/Create/preview/NotificationContainer.js +0 -294
  79. package/v2Containers/WebPush/Create/preview/PreviewContent.js +0 -90
  80. package/v2Containers/WebPush/Create/preview/PreviewControls.js +0 -305
  81. package/v2Containers/WebPush/Create/preview/PreviewDisclaimer.js +0 -25
  82. package/v2Containers/WebPush/Create/preview/WebPushPreview.js +0 -156
  83. package/v2Containers/WebPush/Create/preview/assets/Light.svg +0 -53
  84. package/v2Containers/WebPush/Create/preview/assets/Top.svg +0 -5
  85. package/v2Containers/WebPush/Create/preview/assets/android-arrow-down.svg +0 -9
  86. package/v2Containers/WebPush/Create/preview/assets/android-arrow-up.svg +0 -9
  87. package/v2Containers/WebPush/Create/preview/assets/chrome-icon.png +0 -0
  88. package/v2Containers/WebPush/Create/preview/assets/edge-icon.png +0 -0
  89. package/v2Containers/WebPush/Create/preview/assets/firefox-icon.svg +0 -106
  90. package/v2Containers/WebPush/Create/preview/assets/iOS.svg +0 -26
  91. package/v2Containers/WebPush/Create/preview/assets/macos-arrow-down-icon.svg +0 -9
  92. package/v2Containers/WebPush/Create/preview/assets/macos-triple-dot-icon.svg +0 -9
  93. package/v2Containers/WebPush/Create/preview/assets/opera-icon.svg +0 -18
  94. package/v2Containers/WebPush/Create/preview/assets/safari-icon.svg +0 -29
  95. package/v2Containers/WebPush/Create/preview/assets/windows-close-icon.svg +0 -9
  96. package/v2Containers/WebPush/Create/preview/assets/windows-triple-dot-icon.svg +0 -9
  97. package/v2Containers/WebPush/Create/preview/components/AndroidMobileChromeHeader.js +0 -51
  98. package/v2Containers/WebPush/Create/preview/components/AndroidMobileExpanded.js +0 -145
  99. package/v2Containers/WebPush/Create/preview/components/IOSHeader.js +0 -45
  100. package/v2Containers/WebPush/Create/preview/components/NotificationExpandedContent.js +0 -68
  101. package/v2Containers/WebPush/Create/preview/components/NotificationHeader.js +0 -61
  102. package/v2Containers/WebPush/Create/preview/components/WindowsChromeExpanded.js +0 -99
  103. package/v2Containers/WebPush/Create/preview/components/tests/AndroidMobileExpanded.test.js +0 -733
  104. package/v2Containers/WebPush/Create/preview/components/tests/WindowsChromeExpanded.test.js +0 -571
  105. package/v2Containers/WebPush/Create/preview/components/tests/__snapshots__/AndroidMobileExpanded.test.js.snap +0 -85
  106. package/v2Containers/WebPush/Create/preview/components/tests/__snapshots__/WindowsChromeExpanded.test.js.snap +0 -81
  107. package/v2Containers/WebPush/Create/preview/config/notificationMappings.js +0 -50
  108. package/v2Containers/WebPush/Create/preview/constants.js +0 -637
  109. package/v2Containers/WebPush/Create/preview/notification-container.scss +0 -79
  110. package/v2Containers/WebPush/Create/preview/preview.scss +0 -358
  111. package/v2Containers/WebPush/Create/preview/styles/_android-mobile-chrome.scss +0 -370
  112. package/v2Containers/WebPush/Create/preview/styles/_android-mobile-edge.scss +0 -12
  113. package/v2Containers/WebPush/Create/preview/styles/_android-mobile-firefox.scss +0 -12
  114. package/v2Containers/WebPush/Create/preview/styles/_android-mobile-opera.scss +0 -12
  115. package/v2Containers/WebPush/Create/preview/styles/_android-tablet-chrome.scss +0 -47
  116. package/v2Containers/WebPush/Create/preview/styles/_android-tablet-edge.scss +0 -11
  117. package/v2Containers/WebPush/Create/preview/styles/_android-tablet-firefox.scss +0 -11
  118. package/v2Containers/WebPush/Create/preview/styles/_android-tablet-opera.scss +0 -11
  119. package/v2Containers/WebPush/Create/preview/styles/_base.scss +0 -207
  120. package/v2Containers/WebPush/Create/preview/styles/_ios.scss +0 -153
  121. package/v2Containers/WebPush/Create/preview/styles/_ipados.scss +0 -107
  122. package/v2Containers/WebPush/Create/preview/styles/_macos-chrome.scss +0 -101
  123. package/v2Containers/WebPush/Create/preview/styles/_windows-chrome.scss +0 -229
  124. package/v2Containers/WebPush/Create/preview/tests/DevicePreviewContent.test.js +0 -906
  125. package/v2Containers/WebPush/Create/preview/tests/NotificationContainer.test.js +0 -1081
  126. package/v2Containers/WebPush/Create/preview/tests/PreviewControls.test.js +0 -723
  127. package/v2Containers/WebPush/Create/preview/tests/WebPushPreview.test.js +0 -1327
  128. package/v2Containers/WebPush/Create/preview/tests/__snapshots__/DevicePreviewContent.test.js.snap +0 -131
  129. package/v2Containers/WebPush/Create/preview/tests/__snapshots__/NotificationContainer.test.js.snap +0 -112
  130. package/v2Containers/WebPush/Create/preview/tests/__snapshots__/PreviewControls.test.js.snap +0 -144
  131. package/v2Containers/WebPush/Create/preview/tests/__snapshots__/WebPushPreview.test.js.snap +0 -129
  132. package/v2Containers/WebPush/Create/utils/payloadBuilder.js +0 -96
  133. package/v2Containers/WebPush/Create/utils/payloadBuilder.test.js +0 -396
  134. package/v2Containers/WebPush/Create/utils/previewUtils.js +0 -89
  135. package/v2Containers/WebPush/Create/utils/urlValidation.js +0 -115
  136. package/v2Containers/WebPush/Create/utils/urlValidation.test.js +0 -449
  137. package/v2Containers/WebPush/Create/utils/validation.js +0 -75
  138. package/v2Containers/WebPush/Create/utils/validation.test.js +0 -283
  139. package/v2Containers/WebPush/actions.js +0 -60
  140. package/v2Containers/WebPush/constants.js +0 -132
  141. package/v2Containers/WebPush/index.js +0 -2
  142. package/v2Containers/WebPush/reducer.js +0 -104
  143. package/v2Containers/WebPush/sagas.js +0 -119
  144. package/v2Containers/WebPush/selectors.js +0 -65
  145. package/v2Containers/WebPush/tests/reducer.test.js +0 -863
  146. package/v2Containers/WebPush/tests/sagas.test.js +0 -566
  147. package/v2Containers/WebPush/tests/selectors.test.js +0 -960
@@ -1,566 +0,0 @@
1
- import { expectSaga } from 'redux-saga-test-plan';
2
- import { call } from 'redux-saga/effects';
3
- import { throwError } from 'redux-saga-test-plan/providers';
4
- import * as Api from '../../../services/api';
5
- import * as sagas from '../sagas';
6
- import * as types from '../constants';
7
-
8
- describe('WebPush Sagas', () => {
9
- describe('createTemplate', () => {
10
- const template = { name: 'Test Template', content: 'Test Content' };
11
- const callback = jest.fn();
12
-
13
- beforeEach(() => {
14
- jest.clearAllMocks();
15
- });
16
-
17
- it('should handle successful template creation without callback', () => {
18
- const fakeResponse = {
19
- status: { code: 200 },
20
- response: { id: 1, name: 'Test Template' },
21
- };
22
-
23
- return expectSaga(sagas.createTemplate, { template })
24
- .provide([
25
- [call(Api.createWebPushTemplate, template), fakeResponse],
26
- ])
27
- .put({
28
- type: types.CREATE_TEMPLATE_SUCCESS,
29
- data: fakeResponse.response,
30
- statusCode: 200,
31
- errorMsg: undefined,
32
- })
33
- .run();
34
- });
35
-
36
- it('should handle successful template creation with callback', () => {
37
- const fakeResponse = {
38
- status: { code: 201 },
39
- response: { id: 1, name: 'Test Template' },
40
- };
41
-
42
- return expectSaga(sagas.createTemplate, { template, callback })
43
- .provide([
44
- [call(Api.createWebPushTemplate, template), fakeResponse],
45
- [call(callback, fakeResponse.response), undefined],
46
- ])
47
- .put({
48
- type: types.CREATE_TEMPLATE_SUCCESS,
49
- data: fakeResponse.response,
50
- statusCode: 201,
51
- errorMsg: undefined,
52
- })
53
- .run();
54
- });
55
-
56
- it('should handle template creation with error message but status < 400', () => {
57
- const fakeResponse = {
58
- status: { code: 200 },
59
- response: { id: 1, name: 'Test Template' },
60
- message: 'Warning message',
61
- };
62
-
63
- return expectSaga(sagas.createTemplate, { template, callback })
64
- .provide([
65
- [call(Api.createWebPushTemplate, template), fakeResponse],
66
- [call(callback, fakeResponse.response), undefined],
67
- ])
68
- .put({
69
- type: types.CREATE_TEMPLATE_SUCCESS,
70
- data: fakeResponse.response,
71
- statusCode: 200,
72
- errorMsg: 'Warning message',
73
- })
74
- .run();
75
- });
76
-
77
- it('should handle template creation failure with status >= 400', () => {
78
- const errorMsg = 'Bad Request';
79
- const fakeResponse = {
80
- status: { code: 400 },
81
- message: errorMsg,
82
- };
83
-
84
- return expectSaga(sagas.createTemplate, { template, callback })
85
- .provide([
86
- [call(Api.createWebPushTemplate, template), fakeResponse],
87
- ])
88
- .put({
89
- type: types.CREATE_TEMPLATE_FAILURE,
90
- error: errorMsg,
91
- errorMsg,
92
- })
93
- .run();
94
- });
95
-
96
- it('should handle template creation failure with status >= 400 and no message', () => {
97
- const fakeResponse = {
98
- status: { code: 500 },
99
- };
100
-
101
- return expectSaga(sagas.createTemplate, { template, callback })
102
- .provide([
103
- [call(Api.createWebPushTemplate, template), fakeResponse],
104
- ])
105
- .put({
106
- type: types.CREATE_TEMPLATE_FAILURE,
107
- error: undefined,
108
- errorMsg: undefined,
109
- })
110
- .run();
111
- });
112
-
113
- it('should handle template creation with API exception', () => {
114
- const error = new Error('Network error');
115
-
116
- return expectSaga(sagas.createTemplate, { template, callback })
117
- .provide([
118
- [call(Api.createWebPushTemplate, template), throwError(error)],
119
- ])
120
- .put({
121
- type: types.CREATE_TEMPLATE_FAILURE,
122
- error,
123
- errorMsg: undefined,
124
- })
125
- .run();
126
- });
127
-
128
- it('should handle template creation without status object', () => {
129
- const fakeResponse = {
130
- response: { id: 1, name: 'Test Template' },
131
- };
132
-
133
- return expectSaga(sagas.createTemplate, { template })
134
- .provide([
135
- [call(Api.createWebPushTemplate, template), fakeResponse],
136
- ])
137
- .put({
138
- type: types.CREATE_TEMPLATE_SUCCESS,
139
- data: fakeResponse.response,
140
- statusCode: '',
141
- errorMsg: undefined,
142
- })
143
- .run();
144
- });
145
- });
146
-
147
- describe('clearCreateResponse', () => {
148
- it('should dispatch CLEAR_CREATE_RESPONSE_SUCCESS action', () => {
149
- return expectSaga(sagas.clearCreateResponse)
150
- .put({
151
- type: types.CLEAR_CREATE_RESPONSE_SUCCESS,
152
- })
153
- .run();
154
- });
155
- });
156
-
157
- describe('editTemplate', () => {
158
- const template = { id: 1, name: 'Updated Template', content: 'Updated Content' };
159
- const callback = jest.fn();
160
-
161
- beforeEach(() => {
162
- jest.clearAllMocks();
163
- });
164
-
165
- it('should handle successful template edit without callback', () => {
166
- const fakeResponse = {
167
- status: { code: 200 },
168
- response: { id: 1, name: 'Updated Template' },
169
- };
170
-
171
- return expectSaga(sagas.editTemplate, { template })
172
- .provide([
173
- [call(Api.createWebPushTemplate, template), fakeResponse],
174
- ])
175
- .put({
176
- type: types.EDIT_TEMPLATE_SUCCESS,
177
- data: fakeResponse.response,
178
- statusCode: 200,
179
- errorMsg: undefined,
180
- })
181
- .run();
182
- });
183
-
184
- it('should handle successful template edit with callback', () => {
185
- const fakeResponse = {
186
- status: { code: 200 },
187
- response: { id: 1, name: 'Updated Template' },
188
- };
189
-
190
- return expectSaga(sagas.editTemplate, { template, callback })
191
- .provide([
192
- [call(Api.createWebPushTemplate, template), fakeResponse],
193
- ])
194
- .put({
195
- type: types.EDIT_TEMPLATE_SUCCESS,
196
- data: fakeResponse.response,
197
- statusCode: 200,
198
- errorMsg: undefined,
199
- })
200
- .run()
201
- .then(() => {
202
- expect(callback).toHaveBeenCalledWith(fakeResponse.response, undefined);
203
- });
204
- });
205
-
206
- it('should handle template edit with error message but status < 400', () => {
207
- const fakeResponse = {
208
- status: { code: 200 },
209
- response: { id: 1, name: 'Updated Template' },
210
- message: 'Warning message',
211
- };
212
-
213
- return expectSaga(sagas.editTemplate, { template, callback })
214
- .provide([
215
- [call(Api.createWebPushTemplate, template), fakeResponse],
216
- ])
217
- .put({
218
- type: types.EDIT_TEMPLATE_SUCCESS,
219
- data: fakeResponse.response,
220
- statusCode: 200,
221
- errorMsg: 'Warning message',
222
- })
223
- .run()
224
- .then(() => {
225
- expect(callback).toHaveBeenCalledWith(fakeResponse.response, 'Warning message');
226
- });
227
- });
228
-
229
- it('should handle template edit failure with status >= 400', () => {
230
- const errorMsg = 'Bad Request';
231
- const fakeResponse = {
232
- status: { code: 400 },
233
- message: errorMsg,
234
- };
235
-
236
- return expectSaga(sagas.editTemplate, { template, callback })
237
- .provide([
238
- [call(Api.createWebPushTemplate, template), fakeResponse],
239
- ])
240
- .put({
241
- type: types.EDIT_TEMPLATE_FAILURE,
242
- error: errorMsg,
243
- errorMsg,
244
- })
245
- .run()
246
- .then(() => {
247
- expect(callback).toHaveBeenCalledWith(null, errorMsg);
248
- });
249
- });
250
-
251
- it('should handle template edit failure with status >= 400 and no callback', () => {
252
- const errorMsg = 'Bad Request';
253
- const fakeResponse = {
254
- status: { code: 500 },
255
- message: errorMsg,
256
- };
257
-
258
- return expectSaga(sagas.editTemplate, { template })
259
- .provide([
260
- [call(Api.createWebPushTemplate, template), fakeResponse],
261
- ])
262
- .put({
263
- type: types.EDIT_TEMPLATE_FAILURE,
264
- error: errorMsg,
265
- errorMsg,
266
- })
267
- .run();
268
- });
269
-
270
- it('should handle template edit with API exception and callback', () => {
271
- const error = new Error('Network error');
272
-
273
- return expectSaga(sagas.editTemplate, { template, callback })
274
- .provide([
275
- [call(Api.createWebPushTemplate, template), throwError(error)],
276
- ])
277
- .put({
278
- type: types.EDIT_TEMPLATE_FAILURE,
279
- error,
280
- errorMsg: undefined,
281
- })
282
- .run()
283
- .then(() => {
284
- expect(callback).toHaveBeenCalledWith(null, undefined);
285
- });
286
- });
287
-
288
- it('should handle template edit with API exception without callback', () => {
289
- const error = new Error('Network error');
290
-
291
- return expectSaga(sagas.editTemplate, { template })
292
- .provide([
293
- [call(Api.createWebPushTemplate, template), throwError(error)],
294
- ])
295
- .put({
296
- type: types.EDIT_TEMPLATE_FAILURE,
297
- error,
298
- errorMsg: undefined,
299
- })
300
- .run();
301
- });
302
-
303
- it('should handle template edit without status object', () => {
304
- const fakeResponse = {
305
- response: { id: 1, name: 'Updated Template' },
306
- };
307
-
308
- return expectSaga(sagas.editTemplate, { template })
309
- .provide([
310
- [call(Api.createWebPushTemplate, template), fakeResponse],
311
- ])
312
- .put({
313
- type: types.EDIT_TEMPLATE_SUCCESS,
314
- data: fakeResponse.response,
315
- statusCode: '',
316
- errorMsg: undefined,
317
- })
318
- .run();
319
- });
320
- });
321
-
322
- describe('clearEditResponse', () => {
323
- it('should dispatch CLEAR_EDIT_RESPONSE_SUCCESS action', () => {
324
- return expectSaga(sagas.clearEditResponse)
325
- .put({
326
- type: types.CLEAR_EDIT_RESPONSE_SUCCESS,
327
- })
328
- .run();
329
- });
330
- });
331
-
332
- describe('uploadWebPushAsset', () => {
333
- const file = new Blob(['file contents'], { type: 'image/png' });
334
- const assetType = 'image';
335
- const fileParams = { width: 100, height: 100 };
336
- const templateType = 'rich';
337
-
338
- it('should handle successful asset upload', () => {
339
- const fakeResponse = {
340
- status: { code: 200 },
341
- response: {
342
- asset: {
343
- id: 1,
344
- url: 'https://example.com/image.png',
345
- },
346
- },
347
- };
348
-
349
- return expectSaga(sagas.uploadWebPushAsset, {
350
- file,
351
- assetType,
352
- fileParams,
353
- templateType,
354
- })
355
- .provide([
356
- [
357
- call(Api.uploadFile, {
358
- file,
359
- assetType,
360
- fileParams,
361
- }),
362
- fakeResponse,
363
- ],
364
- ])
365
- .put({
366
- type: types.UPLOAD_WEBPUSH_ASSET_SUCCESS,
367
- data: fakeResponse.response.asset,
368
- statusCode: 200,
369
- templateType,
370
- })
371
- .run();
372
- });
373
-
374
- it('should handle asset upload without templateType', () => {
375
- const fakeResponse = {
376
- status: { code: 201 },
377
- response: {
378
- asset: {
379
- id: 1,
380
- url: 'https://example.com/image.png',
381
- },
382
- },
383
- };
384
-
385
- return expectSaga(sagas.uploadWebPushAsset, {
386
- file,
387
- assetType,
388
- fileParams,
389
- })
390
- .provide([
391
- [
392
- call(Api.uploadFile, {
393
- file,
394
- assetType,
395
- fileParams,
396
- }),
397
- fakeResponse,
398
- ],
399
- ])
400
- .put({
401
- type: types.UPLOAD_WEBPUSH_ASSET_SUCCESS,
402
- data: fakeResponse.response.asset,
403
- statusCode: 201,
404
- templateType: undefined,
405
- })
406
- .run();
407
- });
408
-
409
- it('should handle asset upload without status object', () => {
410
- const fakeResponse = {
411
- response: {
412
- asset: {
413
- id: 1,
414
- url: 'https://example.com/image.png',
415
- },
416
- },
417
- };
418
-
419
- return expectSaga(sagas.uploadWebPushAsset, {
420
- file,
421
- assetType,
422
- fileParams,
423
- templateType,
424
- })
425
- .provide([
426
- [
427
- call(Api.uploadFile, {
428
- file,
429
- assetType,
430
- fileParams,
431
- }),
432
- fakeResponse,
433
- ],
434
- ])
435
- .put({
436
- type: types.UPLOAD_WEBPUSH_ASSET_SUCCESS,
437
- data: fakeResponse.response.asset,
438
- statusCode: '',
439
- templateType,
440
- })
441
- .run();
442
- });
443
-
444
- it('should handle asset upload with null response', () => {
445
- const fakeResponse = {
446
- status: { code: 200 },
447
- response: null,
448
- };
449
-
450
- return expectSaga(sagas.uploadWebPushAsset, {
451
- file,
452
- assetType,
453
- fileParams,
454
- templateType,
455
- })
456
- .provide([
457
- [
458
- call(Api.uploadFile, {
459
- file,
460
- assetType,
461
- fileParams,
462
- }),
463
- fakeResponse,
464
- ],
465
- ])
466
- .put({
467
- type: types.UPLOAD_WEBPUSH_ASSET_SUCCESS,
468
- data: undefined,
469
- statusCode: 200,
470
- templateType,
471
- })
472
- .run();
473
- });
474
-
475
- it('should handle asset upload failure', () => {
476
- const error = new Error('Upload failed');
477
-
478
- return expectSaga(sagas.uploadWebPushAsset, {
479
- file,
480
- assetType,
481
- fileParams,
482
- templateType,
483
- })
484
- .provide([
485
- [
486
- call(Api.uploadFile, {
487
- file,
488
- assetType,
489
- fileParams,
490
- }),
491
- throwError(error),
492
- ],
493
- ])
494
- .put({
495
- type: types.UPLOAD_WEBPUSH_ASSET_FAILURE,
496
- error,
497
- })
498
- .run();
499
- });
500
-
501
- it('should handle asset upload with undefined response', () => {
502
- const fakeResponse = undefined;
503
-
504
- return expectSaga(sagas.uploadWebPushAsset, {
505
- file,
506
- assetType,
507
- fileParams,
508
- templateType,
509
- })
510
- .provide([
511
- [
512
- call(Api.uploadFile, {
513
- file,
514
- assetType,
515
- fileParams,
516
- }),
517
- fakeResponse,
518
- ],
519
- ])
520
- .put({
521
- type: types.UPLOAD_WEBPUSH_ASSET_SUCCESS,
522
- data: undefined,
523
- statusCode: '',
524
- templateType,
525
- })
526
- .run();
527
- });
528
- });
529
-
530
- describe('watchCreateTemplate', () => {
531
- it.concurrent('should initialize watchCreateTemplate watcher saga without error', () => {
532
- return expectSaga(sagas.watchCreateTemplate).run();
533
- });
534
- });
535
-
536
- describe('watchClearCreateResponse', () => {
537
- it.concurrent('should initialize watchClearCreateResponse watcher saga without error', () => {
538
- return expectSaga(sagas.watchClearCreateResponse).run();
539
- });
540
- });
541
-
542
- describe('watchEditTemplate', () => {
543
- it.concurrent('should initialize watchEditTemplate watcher saga without error', () => {
544
- return expectSaga(sagas.watchEditTemplate).run();
545
- });
546
- });
547
-
548
- describe('watchClearEditResponse', () => {
549
- it.concurrent('should initialize watchClearEditResponse watcher saga without error', () => {
550
- return expectSaga(sagas.watchClearEditResponse).run();
551
- });
552
- });
553
-
554
- describe('watchUploadWebPushAsset', () => {
555
- it.concurrent('should initialize watchUploadWebPushAsset watcher saga without error', () => {
556
- return expectSaga(sagas.watchUploadWebPushAsset).run();
557
- });
558
- });
559
-
560
- describe('webPushSagas (default export)', () => {
561
- it.concurrent('should initialize all webPushSagas watcher sagas without error', () => {
562
- return expectSaga(sagas.default).run();
563
- });
564
- });
565
- });
566
-