@capillarytech/creatives-library 8.0.242-alpha.0 → 8.0.242-alpha.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/assets/Android.png +0 -0
- package/assets/iOS.png +0 -0
- package/constants/unified.js +2 -1
- package/initialReducer.js +2 -0
- package/package.json +1 -1
- package/sagas/__tests__/assetPolling.test.js +74 -3
- package/sagas/assetPolling.js +8 -1
- package/services/api.js +10 -5
- package/services/tests/api.test.js +18 -0
- package/translations/en.json +0 -1
- package/utils/common.js +5 -0
- package/utils/commonUtils.js +14 -1
- package/utils/tests/commonUtil.test.js +224 -0
- package/utils/transformTemplateConfig.js +0 -10
- package/utils/transformerUtils.js +0 -42
- package/v2Components/CapDeviceContent/index.js +61 -56
- package/v2Components/CapImageUpload/constants.js +0 -2
- package/v2Components/CapImageUpload/index.js +14 -54
- package/v2Components/CapImageUpload/index.scss +1 -4
- package/v2Components/CapImageUpload/messages.js +0 -4
- package/v2Components/CapTagList/index.js +6 -1
- package/v2Components/CapTagListWithInput/index.js +5 -1
- package/v2Components/CapTagListWithInput/messages.js +1 -1
- package/v2Components/CapWhatsappCTA/tests/index.test.js +5 -0
- package/v2Components/ErrorInfoNote/index.js +412 -72
- package/v2Components/ErrorInfoNote/messages.js +22 -0
- package/v2Components/ErrorInfoNote/style.scss +279 -2
- package/v2Components/HtmlEditor/HTMLEditor.js +217 -90
- package/v2Components/HtmlEditor/__tests__/HTMLEditor.test.js +1132 -133
- package/v2Components/HtmlEditor/__tests__/index.lazy.test.js +17 -12
- package/v2Components/HtmlEditor/_htmlEditor.scss +15 -23
- package/v2Components/HtmlEditor/_index.lazy.scss +1 -1
- package/v2Components/HtmlEditor/components/CodeEditorPane/_codeEditorPane.scss +13 -101
- package/v2Components/HtmlEditor/components/CodeEditorPane/index.js +148 -139
- package/v2Components/HtmlEditor/components/DeviceToggle/_deviceToggle.scss +2 -1
- package/v2Components/HtmlEditor/components/DeviceToggle/index.js +3 -3
- package/v2Components/HtmlEditor/components/EditorToolbar/_editorToolbar.scss +1 -0
- package/v2Components/HtmlEditor/components/EditorToolbar/index.js +1 -1
- package/v2Components/HtmlEditor/components/FullscreenModal/_fullscreenModal.scss +1 -0
- package/v2Components/HtmlEditor/components/InAppPreviewPane/DeviceFrame.js +4 -7
- package/v2Components/HtmlEditor/components/InAppPreviewPane/__tests__/DeviceFrame.test.js +35 -45
- package/v2Components/HtmlEditor/components/InAppPreviewPane/_inAppPreviewPane.scss +1 -3
- package/v2Components/HtmlEditor/components/InAppPreviewPane/constants.js +33 -33
- package/v2Components/HtmlEditor/components/InAppPreviewPane/index.js +7 -6
- package/v2Components/HtmlEditor/components/PreviewPane/_previewPane.scss +3 -6
- package/v2Components/HtmlEditor/components/PreviewPane/index.js +10 -11
- package/v2Components/HtmlEditor/components/SplitContainer/_splitContainer.scss +1 -1
- package/v2Components/HtmlEditor/components/ValidationErrorDisplay/__tests__/index.test.js +87 -62
- package/v2Components/HtmlEditor/components/ValidationErrorDisplay/index.js +49 -31
- package/v2Components/HtmlEditor/components/ValidationTabs/_validationTabs.scss +254 -0
- package/v2Components/HtmlEditor/components/ValidationTabs/index.js +362 -0
- package/v2Components/HtmlEditor/components/ValidationTabs/messages.js +51 -0
- package/v2Components/HtmlEditor/constants.js +29 -20
- package/v2Components/HtmlEditor/hooks/__tests__/useInAppContent.test.js +373 -16
- package/v2Components/HtmlEditor/hooks/useEditorContent.js +5 -2
- package/v2Components/HtmlEditor/hooks/useInAppContent.js +88 -146
- package/v2Components/HtmlEditor/index.js +1 -1
- package/v2Components/HtmlEditor/messages.js +95 -85
- package/v2Components/HtmlEditor/utils/liquidTemplateSupport.js +99 -101
- package/v2Components/HtmlEditor/utils/properSyntaxHighlighting.js +23 -25
- package/v2Components/HtmlEditor/utils/validationAdapter.js +34 -41
- package/v2Components/MobilePushPreviewV2/index.js +32 -7
- package/v2Components/TemplatePreview/_templatePreview.scss +44 -24
- package/v2Components/TemplatePreview/index.js +47 -32
- package/v2Components/TemplatePreview/messages.js +4 -0
- package/v2Components/TestAndPreviewSlidebox/index.js +31 -25
- package/v2Containers/App/constants.js +0 -5
- package/v2Containers/BeeEditor/index.js +82 -80
- package/v2Containers/BeePopupEditor/constants.js +10 -0
- package/v2Containers/BeePopupEditor/index.js +193 -0
- package/v2Containers/BeePopupEditor/tests/index.test.js +627 -0
- package/v2Containers/Cap/tests/__snapshots__/index.test.js.snap +0 -1
- package/v2Containers/CreativesContainer/SlideBoxContent.js +148 -120
- package/v2Containers/CreativesContainer/SlideBoxFooter.js +9 -3
- package/v2Containers/CreativesContainer/SlideBoxHeader.js +2 -2
- package/v2Containers/CreativesContainer/constants.js +1 -2
- package/v2Containers/CreativesContainer/index.js +173 -193
- package/v2Containers/CreativesContainer/messages.js +4 -4
- package/v2Containers/CreativesContainer/tests/__snapshots__/SlideBoxContent.test.js.snap +38 -50
- package/v2Containers/CreativesContainer/tests/__snapshots__/index.test.js.snap +36 -0
- package/v2Containers/Email/actions.js +7 -0
- package/v2Containers/Email/constants.js +5 -1
- package/v2Containers/Email/index.js +13 -0
- package/v2Containers/Email/messages.js +32 -0
- package/v2Containers/Email/reducer.js +12 -1
- package/v2Containers/Email/sagas.js +41 -6
- package/v2Containers/Email/tests/__snapshots__/reducer.test.js.snap +2 -0
- package/v2Containers/EmailWrapper/components/EmailHTMLEditor.js +1046 -0
- package/v2Containers/EmailWrapper/components/EmailWrapperView.js +193 -7
- package/v2Containers/EmailWrapper/components/HTMLEditorTesting.js +40 -74
- package/v2Containers/EmailWrapper/components/__tests__/HTMLEditorTesting.test.js +2 -67
- package/v2Containers/EmailWrapper/constants.js +2 -0
- package/v2Containers/EmailWrapper/hooks/useEmailWrapper.js +436 -67
- package/v2Containers/EmailWrapper/index.js +99 -23
- package/v2Containers/EmailWrapper/messages.js +61 -1
- package/v2Containers/EmailWrapper/tests/EmailWrapperView.test.js +26 -1
- package/v2Containers/EmailWrapper/tests/useEmailWrapper.test.js +111 -77
- package/v2Containers/InApp/__tests__/InAppHTMLEditor.test.js +376 -0
- package/v2Containers/InApp/__tests__/sagas.test.js +363 -0
- package/v2Containers/InApp/actions.js +7 -0
- package/v2Containers/InApp/constants.js +20 -4
- package/v2Containers/InApp/index.js +800 -357
- package/v2Containers/InApp/index.scss +4 -3
- package/v2Containers/InApp/messages.js +7 -3
- package/v2Containers/InApp/reducer.js +21 -3
- package/v2Containers/InApp/sagas.js +29 -9
- package/v2Containers/InApp/selectors.js +25 -5
- package/v2Containers/InApp/tests/index.test.js +154 -50
- package/v2Containers/InApp/tests/reducer.test.js +34 -0
- package/v2Containers/InApp/tests/sagas.test.js +61 -9
- package/v2Containers/InApp/tests/selectors.test.js +612 -0
- package/v2Containers/InAppWrapper/components/InAppWrapperView.js +162 -0
- package/v2Containers/InAppWrapper/components/__tests__/InAppWrapperView.test.js +267 -0
- package/v2Containers/InAppWrapper/components/inAppWrapperView.scss +9 -0
- package/v2Containers/InAppWrapper/constants.js +16 -0
- package/v2Containers/InAppWrapper/hooks/__tests__/useInAppWrapper.test.js +473 -0
- package/v2Containers/InAppWrapper/hooks/useInAppWrapper.js +198 -0
- package/v2Containers/InAppWrapper/index.js +148 -0
- package/v2Containers/InAppWrapper/messages.js +49 -0
- package/v2Containers/InappAdvance/index.js +1099 -0
- package/v2Containers/InappAdvance/index.scss +10 -0
- package/v2Containers/InappAdvance/tests/index.test.js +448 -0
- package/v2Containers/Line/Container/ImageCarousel/tests/__snapshots__/content.test.js.snap +3 -3
- package/v2Containers/Line/Container/ImageCarousel/tests/__snapshots__/index.test.js.snap +2 -2
- package/v2Containers/Line/Container/Wrapper/tests/__snapshots__/index.test.js.snap +2 -25
- package/v2Containers/Line/Container/tests/__snapshots__/index.test.js.snap +9 -18
- package/v2Containers/Rcs/tests/__snapshots__/index.test.js.snap +12 -46
- package/v2Containers/SmsTrai/Create/tests/__snapshots__/index.test.js.snap +0 -4
- package/v2Containers/SmsTrai/Edit/tests/__snapshots__/index.test.js.snap +4 -8
- package/v2Containers/TagList/index.js +67 -1
- package/v2Containers/Templates/ChannelTypeIllustration.js +1 -13
- package/v2Containers/Templates/_templates.scss +56 -200
- package/v2Containers/Templates/actions.js +1 -2
- package/v2Containers/Templates/constants.js +0 -1
- package/v2Containers/Templates/index.js +124 -277
- package/v2Containers/Templates/messages.js +4 -24
- package/v2Containers/Templates/reducer.js +0 -2
- package/v2Containers/Templates/tests/index.test.js +0 -10
- package/v2Containers/TemplatesV2/index.js +2 -3
- package/v2Containers/TemplatesV2/messages.js +0 -4
- package/v2Containers/Whatsapp/tests/__snapshots__/index.test.js.snap +35 -132
- package/v2Components/CapImageUrlUpload/constants.js +0 -19
- package/v2Components/CapImageUrlUpload/index.js +0 -455
- package/v2Components/CapImageUrlUpload/index.scss +0 -35
- package/v2Components/CapImageUrlUpload/messages.js +0 -47
- package/v2Containers/WebPush/Create/components/ButtonForm.js +0 -175
- package/v2Containers/WebPush/Create/components/ButtonItem.js +0 -101
- package/v2Containers/WebPush/Create/components/ButtonList.js +0 -144
- package/v2Containers/WebPush/Create/components/_buttons.scss +0 -246
- package/v2Containers/WebPush/Create/components/tests/ButtonForm.test.js +0 -554
- package/v2Containers/WebPush/Create/components/tests/ButtonItem.test.js +0 -607
- package/v2Containers/WebPush/Create/components/tests/ButtonList.test.js +0 -633
- package/v2Containers/WebPush/Create/components/tests/__snapshots__/ButtonForm.test.js.snap +0 -666
- package/v2Containers/WebPush/Create/components/tests/__snapshots__/ButtonItem.test.js.snap +0 -74
- package/v2Containers/WebPush/Create/components/tests/__snapshots__/ButtonList.test.js.snap +0 -80
- package/v2Containers/WebPush/Create/index.js +0 -1755
- package/v2Containers/WebPush/Create/index.scss +0 -123
- package/v2Containers/WebPush/Create/messages.js +0 -199
- package/v2Containers/WebPush/Create/preview/DevicePreviewContent.js +0 -241
- package/v2Containers/WebPush/Create/preview/NotificationContainer.js +0 -290
- package/v2Containers/WebPush/Create/preview/PreviewContent.js +0 -81
- package/v2Containers/WebPush/Create/preview/PreviewControls.js +0 -240
- package/v2Containers/WebPush/Create/preview/PreviewDisclaimer.js +0 -23
- package/v2Containers/WebPush/Create/preview/WebPushPreview.js +0 -144
- package/v2Containers/WebPush/Create/preview/assets/Light.svg +0 -53
- package/v2Containers/WebPush/Create/preview/assets/Top.svg +0 -5
- package/v2Containers/WebPush/Create/preview/assets/chrome-icon.png +0 -0
- package/v2Containers/WebPush/Create/preview/assets/edge-icon.png +0 -0
- package/v2Containers/WebPush/Create/preview/assets/firefox-icon.svg +0 -106
- package/v2Containers/WebPush/Create/preview/assets/iOS.svg +0 -26
- package/v2Containers/WebPush/Create/preview/assets/opera-icon.svg +0 -18
- package/v2Containers/WebPush/Create/preview/assets/safari-icon.svg +0 -29
- package/v2Containers/WebPush/Create/preview/components/AndroidMobileChromeHeader.js +0 -44
- package/v2Containers/WebPush/Create/preview/components/AndroidMobileExpanded.js +0 -110
- package/v2Containers/WebPush/Create/preview/components/IOSHeader.js +0 -45
- package/v2Containers/WebPush/Create/preview/components/NotificationExpandedContent.js +0 -72
- package/v2Containers/WebPush/Create/preview/components/NotificationHeader.js +0 -55
- package/v2Containers/WebPush/Create/preview/components/WindowsChromeExpanded.js +0 -70
- package/v2Containers/WebPush/Create/preview/components/tests/AndroidMobileExpanded.test.js +0 -512
- package/v2Containers/WebPush/Create/preview/components/tests/__snapshots__/AndroidMobileExpanded.test.js.snap +0 -77
- package/v2Containers/WebPush/Create/preview/config/notificationMappings.js +0 -527
- package/v2Containers/WebPush/Create/preview/constants.js +0 -162
- package/v2Containers/WebPush/Create/preview/notification-container.scss +0 -104
- package/v2Containers/WebPush/Create/preview/preview.scss +0 -409
- package/v2Containers/WebPush/Create/preview/styles/_android-mobile-chrome.scss +0 -300
- package/v2Containers/WebPush/Create/preview/styles/_android-mobile-edge.scss +0 -12
- package/v2Containers/WebPush/Create/preview/styles/_android-mobile-firefox.scss +0 -12
- package/v2Containers/WebPush/Create/preview/styles/_android-mobile-opera.scss +0 -12
- package/v2Containers/WebPush/Create/preview/styles/_android-tablet-chrome.scss +0 -303
- package/v2Containers/WebPush/Create/preview/styles/_android-tablet-edge.scss +0 -11
- package/v2Containers/WebPush/Create/preview/styles/_android-tablet-firefox.scss +0 -11
- package/v2Containers/WebPush/Create/preview/styles/_android-tablet-opera.scss +0 -11
- package/v2Containers/WebPush/Create/preview/styles/_base.scss +0 -188
- package/v2Containers/WebPush/Create/preview/styles/_ios.scss +0 -106
- package/v2Containers/WebPush/Create/preview/styles/_ipados.scss +0 -107
- package/v2Containers/WebPush/Create/preview/styles/_macos-chrome.scss +0 -75
- package/v2Containers/WebPush/Create/preview/styles/_windows-chrome.scss +0 -174
- package/v2Containers/WebPush/Create/preview/tests/DevicePreviewContent.test.js +0 -909
- package/v2Containers/WebPush/Create/preview/tests/NotificationContainer.test.js +0 -1077
- package/v2Containers/WebPush/Create/preview/tests/PreviewControls.test.js +0 -723
- package/v2Containers/WebPush/Create/preview/tests/WebPushPreview.test.js +0 -943
- package/v2Containers/WebPush/Create/preview/tests/__snapshots__/DevicePreviewContent.test.js.snap +0 -128
- package/v2Containers/WebPush/Create/preview/tests/__snapshots__/NotificationContainer.test.js.snap +0 -121
- package/v2Containers/WebPush/Create/preview/tests/__snapshots__/PreviewControls.test.js.snap +0 -144
- package/v2Containers/WebPush/Create/preview/tests/__snapshots__/WebPushPreview.test.js.snap +0 -127
- package/v2Containers/WebPush/Create/utils/urlValidation.js +0 -116
- package/v2Containers/WebPush/Create/utils/urlValidation.test.js +0 -449
- package/v2Containers/WebPush/actions.js +0 -60
- package/v2Containers/WebPush/constants.js +0 -108
- package/v2Containers/WebPush/index.js +0 -2
- package/v2Containers/WebPush/reducer.js +0 -104
- package/v2Containers/WebPush/sagas.js +0 -119
- package/v2Containers/WebPush/selectors.js +0 -65
- package/v2Containers/WebPush/tests/reducer.test.js +0 -863
- package/v2Containers/WebPush/tests/sagas.test.js +0 -566
- 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
|
-
|