2022-03-31 02:49:10 +00:00
|
|
|
import { setWidgetDynamicPropertySaga } from "./WidgetOperationSagas";
|
|
|
|
|
|
|
|
|
|
const widget = {
|
2022-04-01 10:00:00 +00:00
|
|
|
isVisible: "true",
|
2022-03-31 02:49:10 +00:00
|
|
|
dynamicPropertyPathList: [],
|
|
|
|
|
dynamicBindingPathList: [],
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
const widget1 = {
|
2022-04-01 10:00:00 +00:00
|
|
|
isVisible: "{{true}}",
|
2022-03-31 02:49:10 +00:00
|
|
|
dynamicPropertyPathList: [
|
|
|
|
|
{
|
2022-04-01 10:00:00 +00:00
|
|
|
key: "isVisible",
|
2022-03-31 02:49:10 +00:00
|
|
|
},
|
|
|
|
|
],
|
|
|
|
|
dynamicBindingPathList: [
|
|
|
|
|
{
|
2022-04-01 10:00:00 +00:00
|
|
|
key: "isVisible",
|
2022-03-31 02:49:10 +00:00
|
|
|
},
|
|
|
|
|
],
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
jest.mock("redux-saga/effects", () => {
|
|
|
|
|
const originalModule = jest.requireActual("redux-saga/effects");
|
|
|
|
|
|
|
|
|
|
return {
|
|
|
|
|
__esModule: true,
|
|
|
|
|
...originalModule,
|
|
|
|
|
select: jest.fn(),
|
|
|
|
|
call: jest.fn(),
|
|
|
|
|
put: jest.fn(),
|
|
|
|
|
};
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
let updateAndSaveLayoutMock: any;
|
|
|
|
|
|
|
|
|
|
jest.mock("actions/pageActions", () => {
|
|
|
|
|
const originalModule = jest.requireActual("actions/pageActions");
|
|
|
|
|
updateAndSaveLayoutMock = jest.fn();
|
|
|
|
|
|
|
|
|
|
return {
|
|
|
|
|
__esModule: true,
|
|
|
|
|
...originalModule,
|
|
|
|
|
updateAndSaveLayout: updateAndSaveLayoutMock,
|
|
|
|
|
};
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
describe("WidgetOperationSaga - ", () => {
|
2022-04-01 10:00:00 +00:00
|
|
|
describe("Should test setWidgetDynamicPropertySaga ", () => {
|
|
|
|
|
it("should update dynamicBindingPathList on js toggle", () => {
|
|
|
|
|
const value = setWidgetDynamicPropertySaga({
|
2022-03-31 02:49:10 +00:00
|
|
|
type: "test",
|
|
|
|
|
payload: {
|
|
|
|
|
isDynamic: true,
|
2022-04-01 10:00:00 +00:00
|
|
|
propertyPath: "isVisible",
|
2022-03-31 02:49:10 +00:00
|
|
|
widgetId: "test",
|
|
|
|
|
},
|
|
|
|
|
});
|
2022-04-01 10:00:00 +00:00
|
|
|
|
2022-03-31 02:49:10 +00:00
|
|
|
value.next(); // start
|
|
|
|
|
value.next(widget as any); // yield select
|
|
|
|
|
value.next({
|
|
|
|
|
test: widget,
|
|
|
|
|
} as any); // yield select
|
|
|
|
|
value.next(); //yield put
|
|
|
|
|
expect(updateAndSaveLayoutMock).toHaveBeenCalledWith({
|
|
|
|
|
test: {
|
|
|
|
|
...widget,
|
|
|
|
|
dynamicPropertyPathList: [
|
|
|
|
|
{
|
2022-04-01 10:00:00 +00:00
|
|
|
key: "isVisible",
|
2022-03-31 02:49:10 +00:00
|
|
|
},
|
|
|
|
|
],
|
|
|
|
|
},
|
|
|
|
|
});
|
2022-04-01 10:00:00 +00:00
|
|
|
});
|
2022-03-31 02:49:10 +00:00
|
|
|
|
2022-04-01 10:00:00 +00:00
|
|
|
it("should remove property from dynamicBindingList on js toggle off", () => {
|
|
|
|
|
const value = setWidgetDynamicPropertySaga({
|
2022-03-31 02:49:10 +00:00
|
|
|
type: "test",
|
|
|
|
|
payload: {
|
|
|
|
|
isDynamic: false,
|
2022-04-01 10:00:00 +00:00
|
|
|
propertyPath: "isVisible",
|
2022-03-31 02:49:10 +00:00
|
|
|
widgetId: "test",
|
|
|
|
|
},
|
|
|
|
|
});
|
|
|
|
|
value.next(); // start
|
|
|
|
|
value.next(widget1 as any); // yield select
|
|
|
|
|
value.next({ parsed: 1 } as any); // yield call
|
|
|
|
|
value.next({
|
|
|
|
|
test: widget1,
|
|
|
|
|
} as any); // yield select
|
|
|
|
|
value.next(); //yield put
|
|
|
|
|
expect(updateAndSaveLayoutMock).toHaveBeenCalledWith({
|
|
|
|
|
test: {
|
|
|
|
|
dynamicPropertyPathList: [],
|
|
|
|
|
dynamicBindingPathList: [],
|
2022-04-01 10:00:00 +00:00
|
|
|
isVisible: 1,
|
2022-03-31 02:49:10 +00:00
|
|
|
},
|
|
|
|
|
});
|
|
|
|
|
});
|
|
|
|
|
});
|
|
|
|
|
});
|