## Description Clean up unused feature flags - LINTING - APP_TEMPLATE - JS_EDITOR - MULTIPLAYER - SNIPPET - TEMPLATES_PHASE_2 - RBAC - CONTEXT_SWITCHING - USAGE_AND_BILLING - DATASOURCE_ENVIRONMENTS #### Type of change - Chore (housekeeping or task changes that don't impact user perception) ## Testing #### How Has This Been Tested? > Please describe the tests that you ran to verify your changes. Also list any relevant details for your test configuration. > Delete anything that is not relevant - [ ] Manual - [ ] Jest - [ ] Cypress > > #### Test Plan > Add Testsmith test cases links that relate to this PR > > #### Issues raised during DP testing > Link issues raised during DP testing for better visiblity and tracking (copy link from comments dropped on this PR) > > > ## Checklist: #### Dev activity - [ ] My code follows the style guidelines of this project - [ ] I have performed a self-review of my own code - [ ] I have commented my code, particularly in hard-to-understand areas - [ ] I have made corresponding changes to the documentation - [ ] My changes generate no new warnings - [ ] I have added tests that prove my fix is effective or that my feature works - [ ] New and existing unit tests pass locally with my changes - [ ] PR is being merged under a feature flag #### QA activity: - [ ] [Speedbreak features](https://github.com/appsmithorg/TestSmith/wiki/Test-plan-implementation#speedbreaker-features-to-consider-for-every-change) have been covered - [ ] Test plan covers all impacted features and [areas of interest](https://github.com/appsmithorg/TestSmith/wiki/Guidelines-for-test-plans/_edit#areas-of-interest) - [ ] Test plan has been peer reviewed by project stakeholders and other QA members - [ ] Manually tested functionality on DP - [ ] We had an implementation alignment call with stakeholders post QA Round 2 - [ ] Cypress test cases have been added and approved by SDET/manual QA - [ ] Added `Test Plan Approved` label after Cypress tests were reviewed - [ ] Added `Test Plan Approved` label after JUnit tests were reviewed
971 lines
24 KiB
TypeScript
971 lines
24 KiB
TypeScript
import {
|
|
isHidden,
|
|
getConfigInitialValues,
|
|
caculateIsHidden,
|
|
evaluateCondtionWithType,
|
|
actionPathFromName,
|
|
getViewType,
|
|
ViewTypes,
|
|
switchViewType,
|
|
extractConditionalOutput,
|
|
checkIfSectionCanRender,
|
|
checkIfSectionIsEnabled,
|
|
updateEvaluatedSectionConfig,
|
|
} from "./utils";
|
|
import type { HiddenType } from "./BaseControl";
|
|
import { set } from "lodash";
|
|
import { isValidFormConfig } from "reducers/evaluationReducers/formEvaluationReducer";
|
|
|
|
describe("isHidden test", () => {
|
|
it("Test for isHidden true", () => {
|
|
const hiddenTrueInputs: any = [
|
|
{ values: { name: "Name" }, hidden: true },
|
|
{
|
|
values: { name: "Name", number: 2, email: "temp@temp.com" },
|
|
hidden: {
|
|
conditionType: "AND",
|
|
conditions: [
|
|
{
|
|
path: "name",
|
|
value: "Name",
|
|
comparison: "EQUALS",
|
|
},
|
|
{
|
|
conditionType: "AND",
|
|
conditions: [
|
|
{
|
|
path: "number",
|
|
value: 2,
|
|
comparison: "EQUALS",
|
|
},
|
|
{
|
|
path: "email",
|
|
value: "temp@temp.com",
|
|
comparison: "EQUALS",
|
|
},
|
|
],
|
|
},
|
|
],
|
|
},
|
|
},
|
|
{
|
|
values: { name: "Name" },
|
|
hidden: {
|
|
path: "name",
|
|
value: "Name",
|
|
comparison: "EQUALS",
|
|
},
|
|
},
|
|
{
|
|
values: { name: "Name", config: { type: "EMAIL" } },
|
|
hidden: {
|
|
path: "name.config.type",
|
|
value: "USER_ID",
|
|
comparison: "NOT_EQUALS",
|
|
},
|
|
},
|
|
{
|
|
values: undefined,
|
|
hidden: true,
|
|
},
|
|
{
|
|
values: null,
|
|
hidden: true,
|
|
},
|
|
];
|
|
|
|
hiddenTrueInputs.forEach((input: any) => {
|
|
expect(isHidden(input.values, input.hidden)).toBeTruthy();
|
|
});
|
|
});
|
|
|
|
it("Test for isHidden false", () => {
|
|
const hiddenFalseInputs: any = [
|
|
{ values: { name: "Name" }, hidden: false },
|
|
{
|
|
values: { name: "Name" },
|
|
hidden: {
|
|
path: "name",
|
|
value: "Different Name",
|
|
comparison: "EQUALS",
|
|
},
|
|
},
|
|
{
|
|
values: { name: "Name", config: { type: "EMAIL" } },
|
|
hidden: {
|
|
path: "config.type",
|
|
value: "EMAIL",
|
|
comparison: "NOT_EQUALS",
|
|
},
|
|
},
|
|
{
|
|
values: { name: "Name", config: { type: "Different BODY" } },
|
|
hidden: {
|
|
path: "config.type",
|
|
value: ["EMAIL", "BODY"],
|
|
comparison: "IN",
|
|
},
|
|
},
|
|
{
|
|
values: { name: "Name", config: { type: "BODY" } },
|
|
hidden: {
|
|
path: "config.type",
|
|
value: ["EMAIL", "BODY"],
|
|
comparison: "NOT_IN",
|
|
},
|
|
},
|
|
{
|
|
values: undefined,
|
|
hidden: false,
|
|
},
|
|
{
|
|
values: null,
|
|
hidden: false,
|
|
},
|
|
{
|
|
values: undefined,
|
|
},
|
|
{
|
|
values: { name: "Name" },
|
|
},
|
|
{
|
|
values: {
|
|
name: "Name",
|
|
config: { type: "EMAIL", name: "TEMP" },
|
|
contact: { number: 1234, address: "abcd" },
|
|
},
|
|
hidden: {
|
|
conditionType: "AND",
|
|
conditions: [
|
|
{
|
|
path: "contact.number",
|
|
value: 1234,
|
|
comparison: "NOT_EQUALS",
|
|
},
|
|
{
|
|
conditionType: "OR",
|
|
conditions: [
|
|
{
|
|
conditionType: "AND",
|
|
conditions: [
|
|
{
|
|
path: "config.name",
|
|
value: "TEMP",
|
|
comparison: "EQUALS",
|
|
},
|
|
{
|
|
path: "config.name",
|
|
value: "HELLO",
|
|
comparison: "EQUALS",
|
|
},
|
|
],
|
|
},
|
|
{
|
|
path: "config.type",
|
|
value: "EMAIL",
|
|
comparison: "NOT_EQUALS",
|
|
},
|
|
],
|
|
},
|
|
],
|
|
},
|
|
},
|
|
];
|
|
|
|
hiddenFalseInputs.forEach((input: any) => {
|
|
expect(isHidden(input.values, input.hidden)).toBeFalsy();
|
|
});
|
|
});
|
|
});
|
|
|
|
describe("getConfigInitialValues test", () => {
|
|
it("getConfigInitialValues test", () => {
|
|
const testCases = [
|
|
{
|
|
input: [
|
|
{
|
|
sectionName: "Connection",
|
|
children: [
|
|
{
|
|
label: "Region",
|
|
configProperty:
|
|
"datasourceConfiguration.authentication.databaseName",
|
|
controlType: "DROP_DOWN",
|
|
initialValue: "ap-south-1",
|
|
options: [
|
|
{
|
|
label: "ap-south-1",
|
|
value: "ap-south-1",
|
|
},
|
|
{
|
|
label: "eu-south-1",
|
|
value: "eu-south-1",
|
|
},
|
|
],
|
|
},
|
|
],
|
|
},
|
|
],
|
|
output: {
|
|
datasourceConfiguration: {
|
|
authentication: { databaseName: "ap-south-1" },
|
|
},
|
|
},
|
|
},
|
|
{
|
|
input: [
|
|
{
|
|
sectionName: "Connection",
|
|
children: [
|
|
{
|
|
label: "Region",
|
|
configProperty:
|
|
"datasourceConfiguration.authentication.databaseName",
|
|
controlType: "INPUT_TEXT",
|
|
},
|
|
],
|
|
},
|
|
],
|
|
output: {},
|
|
},
|
|
{
|
|
input: [
|
|
{
|
|
sectionName: "Connection",
|
|
children: [
|
|
{
|
|
label: "Host address (for overriding endpoint only)",
|
|
configProperty: "datasourceConfiguration.endpoints[*].host",
|
|
controlType: "KEYVALUE_ARRAY",
|
|
initialValue: ["jsonplaceholder.typicode.com"],
|
|
},
|
|
{
|
|
label: "Port",
|
|
configProperty: "datasourceConfiguration.endpoints[*].port",
|
|
dataType: "NUMBER",
|
|
controlType: "KEYVALUE_ARRAY",
|
|
},
|
|
],
|
|
},
|
|
],
|
|
output: {
|
|
datasourceConfiguration: {
|
|
endpoints: [{ host: "jsonplaceholder.typicode.com" }],
|
|
},
|
|
},
|
|
},
|
|
{
|
|
input: [
|
|
{
|
|
sectionName: "Settings",
|
|
children: [
|
|
{
|
|
label: "Smart substitution",
|
|
configProperty: "datasourceConfiguration.isSmart",
|
|
controlType: "SWITCH",
|
|
initialValue: false,
|
|
},
|
|
],
|
|
},
|
|
],
|
|
output: {
|
|
datasourceConfiguration: {
|
|
isSmart: false,
|
|
},
|
|
},
|
|
},
|
|
];
|
|
|
|
testCases.forEach((testCase) => {
|
|
expect(getConfigInitialValues(testCase.input)).toEqual(testCase.output);
|
|
});
|
|
});
|
|
});
|
|
|
|
describe("caculateIsHidden test", () => {
|
|
it("calcualte hidden field value", () => {
|
|
const values = { name: "Name" };
|
|
const hiddenTruthy: HiddenType = {
|
|
path: "name",
|
|
comparison: "EQUALS",
|
|
value: "Name",
|
|
flagValue: "TEST_FLAG",
|
|
};
|
|
const hiddenFalsy: HiddenType = {
|
|
path: "name",
|
|
comparison: "EQUALS",
|
|
value: "Different Name",
|
|
flagValue: "TEST_FLAG",
|
|
};
|
|
expect(caculateIsHidden(values, hiddenTruthy)).toBeTruthy();
|
|
expect(caculateIsHidden(values, hiddenFalsy)).toBeFalsy();
|
|
});
|
|
});
|
|
|
|
describe("evaluateCondtionWithType test", () => {
|
|
it("accumulate boolean of array into one based on conditionType", () => {
|
|
const andConditionType = "AND";
|
|
const orConditionType = "OR";
|
|
const booleanArray = [true, false, true];
|
|
|
|
expect(
|
|
evaluateCondtionWithType(booleanArray, andConditionType),
|
|
).toBeFalsy();
|
|
expect(
|
|
evaluateCondtionWithType(booleanArray, orConditionType),
|
|
).toBeTruthy();
|
|
});
|
|
});
|
|
|
|
describe("actionPathFromName test", () => {
|
|
it("creates path from name", () => {
|
|
const actionName = "Api5";
|
|
const name = "actionConfiguration.pluginSpecifiedTemplates[7].value";
|
|
const pathName = "Api5.config.pluginSpecifiedTemplates[7].value";
|
|
|
|
expect(actionPathFromName(actionName, name)).toEqual(pathName);
|
|
});
|
|
});
|
|
|
|
describe("json/form viewTypes test", () => {
|
|
it("should return correct viewType", () => {
|
|
const testValues = {
|
|
actionConfiguration: {
|
|
formData: {
|
|
node1: { data: "value1" },
|
|
node3: { data: "value1" },
|
|
node2: { data: "value1", viewType: ViewTypes.JSON },
|
|
node4: { data: "value1", viewType: ViewTypes.COMPONENT },
|
|
node5: { bata: "value1", viewType: ViewTypes.COMPONENT },
|
|
},
|
|
},
|
|
actionConfiguration2: {
|
|
formData: {
|
|
node6: { data: "value1", viewType: ViewTypes.COMPONENT },
|
|
},
|
|
},
|
|
};
|
|
const testCases = [
|
|
{
|
|
input: "actionConfiguration.formData.node1.data",
|
|
output: ViewTypes.COMPONENT,
|
|
},
|
|
{
|
|
input: "actionConfiguration.formData.node2.data",
|
|
output: ViewTypes.JSON,
|
|
},
|
|
{
|
|
input: "actionConfiguration.formData.node3.data",
|
|
output: ViewTypes.COMPONENT,
|
|
},
|
|
{
|
|
input: "actionConfiguration.formData.node4.data",
|
|
output: ViewTypes.COMPONENT,
|
|
},
|
|
{
|
|
input: "actionConfiguration.formData.node5.bata",
|
|
output: ViewTypes.COMPONENT,
|
|
},
|
|
{
|
|
input: "actionConfiguration2.formData.node6.bata",
|
|
output: ViewTypes.COMPONENT,
|
|
},
|
|
];
|
|
testCases.forEach((testCase) => {
|
|
expect(getViewType(testValues, testCase.input)).toEqual(testCase.output);
|
|
});
|
|
});
|
|
|
|
it("should change the viewType", () => {
|
|
const outputValues: any[] = [
|
|
{
|
|
actionConfiguration: {
|
|
formData: {
|
|
node1: { data: "value1" },
|
|
node3: { data: "value1" },
|
|
node2: { data: "value1", viewType: ViewTypes.JSON },
|
|
node4: { data: "value1", viewType: ViewTypes.COMPONENT },
|
|
node5: {
|
|
data: "value1",
|
|
viewType: ViewTypes.JSON,
|
|
componentData: "value2",
|
|
},
|
|
node6: {
|
|
viewType: ViewTypes.COMPONENT,
|
|
},
|
|
},
|
|
},
|
|
},
|
|
{
|
|
actionConfiguration: {
|
|
formData: {
|
|
node1: { data: "value1" },
|
|
node3: { data: "value1" },
|
|
node2: { data: "value1", viewType: ViewTypes.JSON },
|
|
node4: { data: "value1", viewType: ViewTypes.COMPONENT },
|
|
node5: {
|
|
data: "value1",
|
|
viewType: ViewTypes.JSON,
|
|
componentData: "value2",
|
|
},
|
|
node6: {
|
|
viewType: ViewTypes.COMPONENT,
|
|
},
|
|
},
|
|
},
|
|
},
|
|
{
|
|
actionConfiguration: {
|
|
formData: {
|
|
node1: { data: "value1" },
|
|
node3: { data: "value1" },
|
|
node2: { data: "value1", viewType: ViewTypes.JSON },
|
|
node4: {
|
|
data: "value1",
|
|
viewType: ViewTypes.COMPONENT,
|
|
jsonData: "value2",
|
|
},
|
|
node5: {
|
|
data: "value1",
|
|
viewType: ViewTypes.JSON,
|
|
componentData: "value2",
|
|
},
|
|
node6: {
|
|
viewType: ViewTypes.COMPONENT,
|
|
},
|
|
},
|
|
},
|
|
},
|
|
{
|
|
actionConfiguration: {
|
|
formData: {
|
|
node1: { data: "value1" },
|
|
node3: { data: "value1" },
|
|
node2: { data: "value1", viewType: ViewTypes.JSON },
|
|
node4: { data: "value1", viewType: ViewTypes.COMPONENT },
|
|
node5: {
|
|
data: "value1",
|
|
viewType: ViewTypes.JSON,
|
|
componentData: "value2",
|
|
},
|
|
node6: {
|
|
viewType: ViewTypes.COMPONENT,
|
|
},
|
|
},
|
|
},
|
|
},
|
|
{
|
|
actionConfiguration: {
|
|
formData: {
|
|
node1: { data: "value1" },
|
|
node3: { data: "value1" },
|
|
node2: { data: "value1", viewType: ViewTypes.JSON },
|
|
node4: { data: "value1", viewType: ViewTypes.COMPONENT },
|
|
node5: {
|
|
data: "value1",
|
|
viewType: ViewTypes.JSON,
|
|
componentData: "value2",
|
|
},
|
|
node6: {
|
|
viewType: ViewTypes.COMPONENT,
|
|
},
|
|
},
|
|
},
|
|
},
|
|
{
|
|
actionConfiguration: {
|
|
formData: {
|
|
node1: { data: "value1" },
|
|
node3: { data: "value1" },
|
|
node2: { data: "value1", viewType: ViewTypes.JSON },
|
|
node4: { data: "value1", viewType: ViewTypes.COMPONENT },
|
|
node5: {
|
|
data: "value1",
|
|
viewType: ViewTypes.JSON,
|
|
componentData: "value2",
|
|
},
|
|
node6: {
|
|
viewType: ViewTypes.COMPONENT,
|
|
},
|
|
},
|
|
},
|
|
},
|
|
];
|
|
const customSetterFunction = (
|
|
formName: string,
|
|
path: string,
|
|
value: any,
|
|
) => {
|
|
set(outputValues[Number(formName.split("-")[1])], path, value);
|
|
};
|
|
const inputValue = {
|
|
actionConfiguration: {
|
|
formData: {
|
|
node1: { data: "value1" },
|
|
node2: { data: "value1", viewType: ViewTypes.JSON },
|
|
node3: { data: "value1" },
|
|
node4: {
|
|
data: "value1",
|
|
viewType: ViewTypes.COMPONENT,
|
|
jsonData: "value2",
|
|
},
|
|
node5: {
|
|
data: "value1",
|
|
viewType: ViewTypes.JSON,
|
|
componentData: "value2",
|
|
},
|
|
node6: {
|
|
viewType: ViewTypes.COMPONENT,
|
|
},
|
|
},
|
|
},
|
|
};
|
|
const expectedOutputValues: any[] = [
|
|
{
|
|
actionConfiguration: {
|
|
formData: {
|
|
node1: {
|
|
data: "value1",
|
|
viewType: ViewTypes.JSON,
|
|
componentData: "value1",
|
|
},
|
|
node2: { data: "value1", viewType: ViewTypes.JSON },
|
|
node3: { data: "value1" },
|
|
node4: { data: "value1", viewType: ViewTypes.COMPONENT },
|
|
node5: {
|
|
data: "value1",
|
|
viewType: ViewTypes.JSON,
|
|
componentData: "value2",
|
|
},
|
|
node6: {
|
|
viewType: ViewTypes.COMPONENT,
|
|
},
|
|
},
|
|
},
|
|
},
|
|
{
|
|
actionConfiguration: {
|
|
formData: {
|
|
node1: { data: "value1" },
|
|
node3: { data: "value1" },
|
|
node2: {
|
|
data: "value1",
|
|
viewType: ViewTypes.COMPONENT,
|
|
jsonData: "value1",
|
|
},
|
|
node4: { data: "value1", viewType: ViewTypes.COMPONENT },
|
|
node5: {
|
|
data: "value1",
|
|
viewType: ViewTypes.JSON,
|
|
componentData: "value2",
|
|
},
|
|
node6: {
|
|
viewType: ViewTypes.COMPONENT,
|
|
},
|
|
},
|
|
},
|
|
},
|
|
{
|
|
actionConfiguration: {
|
|
formData: {
|
|
node1: { data: "value1" },
|
|
node3: { data: "value1" },
|
|
node2: { data: "value1", viewType: ViewTypes.JSON },
|
|
node4: {
|
|
data: "value1",
|
|
viewType: ViewTypes.JSON,
|
|
jsonData: "value2",
|
|
componentData: "value1",
|
|
},
|
|
node5: {
|
|
data: "value1",
|
|
viewType: ViewTypes.JSON,
|
|
componentData: "value2",
|
|
},
|
|
node6: {
|
|
viewType: ViewTypes.COMPONENT,
|
|
},
|
|
},
|
|
},
|
|
},
|
|
{
|
|
actionConfiguration: {
|
|
formData: {
|
|
node1: { data: "value1" },
|
|
node3: { data: "value1" },
|
|
node2: { data: "value1", viewType: ViewTypes.JSON },
|
|
node4: { data: "value1", viewType: ViewTypes.COMPONENT },
|
|
node5: {
|
|
data: "value2",
|
|
viewType: ViewTypes.COMPONENT,
|
|
componentData: "value2",
|
|
jsonData: "value1",
|
|
},
|
|
node6: {
|
|
viewType: ViewTypes.COMPONENT,
|
|
},
|
|
},
|
|
},
|
|
},
|
|
{
|
|
actionConfiguration: {
|
|
formData: {
|
|
node1: { data: "value1" },
|
|
node3: {
|
|
data: "value1",
|
|
jsonData: "value1",
|
|
viewType: ViewTypes.COMPONENT,
|
|
},
|
|
node2: { data: "value1", viewType: ViewTypes.JSON },
|
|
node4: { data: "value1", viewType: ViewTypes.COMPONENT },
|
|
node5: {
|
|
data: "value1",
|
|
viewType: ViewTypes.JSON,
|
|
componentData: "value2",
|
|
},
|
|
node6: {
|
|
viewType: ViewTypes.COMPONENT,
|
|
},
|
|
},
|
|
},
|
|
},
|
|
{
|
|
actionConfiguration: {
|
|
formData: {
|
|
node1: { data: "value1" },
|
|
node2: { data: "value1", viewType: ViewTypes.JSON },
|
|
node3: { data: "value1" },
|
|
node4: {
|
|
data: "value1",
|
|
viewType: ViewTypes.COMPONENT,
|
|
},
|
|
node5: {
|
|
data: "value1",
|
|
viewType: ViewTypes.JSON,
|
|
componentData: "value2",
|
|
},
|
|
node6: {
|
|
viewType: ViewTypes.JSON,
|
|
data: "",
|
|
componentData: "",
|
|
},
|
|
},
|
|
},
|
|
},
|
|
];
|
|
const testCases = [
|
|
{
|
|
path: "actionConfiguration.formData.node1.data",
|
|
viewType: ViewTypes.COMPONENT,
|
|
},
|
|
{
|
|
path: "actionConfiguration.formData.node2.data",
|
|
viewType: ViewTypes.JSON,
|
|
},
|
|
{
|
|
path: "actionConfiguration.formData.node4.data",
|
|
viewType: ViewTypes.COMPONENT,
|
|
},
|
|
{
|
|
path: "actionConfiguration.formData.node5.data",
|
|
viewType: ViewTypes.JSON,
|
|
},
|
|
{
|
|
path: "actionConfiguration.formData.node3.data",
|
|
viewType: ViewTypes.JSON,
|
|
},
|
|
{
|
|
path: "actionConfiguration.formData.node6.data",
|
|
viewType: ViewTypes.COMPONENT,
|
|
},
|
|
];
|
|
testCases.forEach((testCase, index) => {
|
|
const formName = `testForm-${index}`;
|
|
switchViewType(
|
|
inputValue,
|
|
testCase.path,
|
|
testCase.viewType,
|
|
formName,
|
|
customSetterFunction,
|
|
);
|
|
expect(outputValues[index]).toEqual(expectedOutputValues[index]);
|
|
});
|
|
});
|
|
});
|
|
|
|
describe("UQI form render methods", () => {
|
|
it("extract conditional output", () => {
|
|
const expectedOutputs = [
|
|
{},
|
|
{
|
|
conditionals: {},
|
|
visible: true,
|
|
enabled: true,
|
|
},
|
|
{
|
|
conditionals: {},
|
|
visible: true,
|
|
enabled: false,
|
|
},
|
|
{
|
|
conditionals: {},
|
|
visible: false,
|
|
enabled: true,
|
|
},
|
|
];
|
|
const testCases = [
|
|
{
|
|
name: "section1",
|
|
},
|
|
{
|
|
name: "section2",
|
|
identifier: "identifier",
|
|
},
|
|
{
|
|
name: "section3",
|
|
configProperty: "configProperty",
|
|
identifier: "identifier",
|
|
},
|
|
{
|
|
name: "section4",
|
|
configProperty: "configProperty",
|
|
propertyName: "propertyName",
|
|
identifier: "identifier",
|
|
},
|
|
];
|
|
testCases.forEach((testCase, index) => {
|
|
const output = extractConditionalOutput(testCase, formEvaluation);
|
|
expect(output).toEqual(expectedOutputs[index]);
|
|
});
|
|
});
|
|
|
|
it("section render test", () => {
|
|
const testCases = [
|
|
{
|
|
input: "identifier",
|
|
output: true,
|
|
},
|
|
{
|
|
input: "configProperty",
|
|
output: true,
|
|
},
|
|
{
|
|
input: "propertyName",
|
|
output: false,
|
|
},
|
|
{
|
|
input: "identifier2",
|
|
output: true,
|
|
},
|
|
{
|
|
input: "identifier3",
|
|
output: false,
|
|
},
|
|
{
|
|
input: "identifier4",
|
|
output: false,
|
|
},
|
|
{
|
|
input: "identifier5",
|
|
output: true,
|
|
},
|
|
];
|
|
testCases.forEach((testCase) => {
|
|
const output = checkIfSectionCanRender(formEvaluation[testCase.input]);
|
|
expect(output).toEqual(testCase.output);
|
|
});
|
|
});
|
|
|
|
it("section enabled/disabled test", () => {
|
|
const testCases = [
|
|
{
|
|
input: "identifier",
|
|
output: true,
|
|
},
|
|
{
|
|
input: "configProperty",
|
|
output: false,
|
|
},
|
|
{
|
|
input: "propertyName",
|
|
output: true,
|
|
},
|
|
{
|
|
input: "identifier2",
|
|
output: false,
|
|
},
|
|
{
|
|
input: "identifier3",
|
|
output: true,
|
|
},
|
|
];
|
|
testCases.forEach((testCase) => {
|
|
const output = checkIfSectionIsEnabled(formEvaluation[testCase.input]);
|
|
expect(output).toEqual(testCase.output);
|
|
});
|
|
});
|
|
|
|
it("check if valid form config", () => {
|
|
const testCases: any[] = [
|
|
{
|
|
input: {},
|
|
output: false,
|
|
},
|
|
{
|
|
input: {
|
|
controlType: "SECTION",
|
|
label: "Select bucket to query",
|
|
children: [
|
|
{
|
|
label: "Bucket name",
|
|
configProperty: "actionConfiguration.formData.bucket.data",
|
|
controlType: "QUERY_DYNAMIC_INPUT_TEXT",
|
|
evaluationSubstitutionType: "TEMPLATE",
|
|
isRequired: true,
|
|
initialValue: "",
|
|
},
|
|
],
|
|
},
|
|
output: true,
|
|
},
|
|
{
|
|
input: {
|
|
label: "Select bucket to query",
|
|
children: [
|
|
{
|
|
label: "Bucket name",
|
|
configProperty: "actionConfiguration.formData.bucket.data",
|
|
controlType: "QUERY_DYNAMIC_INPUT_TEXT",
|
|
evaluationSubstitutionType: "TEMPLATE",
|
|
isRequired: true,
|
|
initialValue: "",
|
|
},
|
|
],
|
|
},
|
|
output: false,
|
|
},
|
|
];
|
|
|
|
testCases.forEach((testCase) => {
|
|
const output = isValidFormConfig(testCase.input);
|
|
expect(output).toEqual(testCase.output);
|
|
});
|
|
});
|
|
|
|
it("update section config tests", () => {
|
|
const testCases = [
|
|
{
|
|
input: {
|
|
sectionObject: {
|
|
key1: "valueX",
|
|
key2: "valueY",
|
|
disabled: false,
|
|
visible: false,
|
|
controlType: "SECTION",
|
|
},
|
|
path: "updateSectionConfigTest1",
|
|
},
|
|
output: {
|
|
key1: "value1",
|
|
key2: "value2",
|
|
disabled: false,
|
|
visible: false,
|
|
controlType: "SECTION",
|
|
},
|
|
},
|
|
{
|
|
input: {
|
|
sectionObject: {
|
|
key1: "valueX",
|
|
key2: "valueY",
|
|
disabled: false,
|
|
visible: false,
|
|
controlType: "SECTION",
|
|
},
|
|
path: "updateSectionConfigTest2",
|
|
},
|
|
output: {
|
|
key1: "valueX",
|
|
key2: "valueY",
|
|
disabled: false,
|
|
visible: false,
|
|
controlType: "SECTION",
|
|
},
|
|
},
|
|
];
|
|
|
|
testCases.forEach((testCase) => {
|
|
const output = updateEvaluatedSectionConfig(
|
|
testCase.input.sectionObject,
|
|
formEvaluation[testCase.input.path],
|
|
);
|
|
expect(output).toEqual(testCase.output);
|
|
});
|
|
});
|
|
});
|
|
|
|
// Constant evaluation object used for testing
|
|
const formEvaluation: Record<string, any> = {
|
|
propertyName: {
|
|
conditionals: {},
|
|
visible: false,
|
|
enabled: true,
|
|
},
|
|
configProperty: {
|
|
conditionals: {},
|
|
visible: true,
|
|
enabled: false,
|
|
},
|
|
identifier: {
|
|
conditionals: {},
|
|
visible: true,
|
|
enabled: true,
|
|
},
|
|
identifier2: {
|
|
conditionals: {},
|
|
enabled: false,
|
|
},
|
|
identifier3: {
|
|
conditionals: {},
|
|
visible: false,
|
|
},
|
|
identifier4: {
|
|
conditionals: {},
|
|
visible: true,
|
|
evaluateFormConfig: {
|
|
updateEvaluatedConfig: false,
|
|
},
|
|
},
|
|
identifier5: {
|
|
conditionals: {},
|
|
visible: true,
|
|
evaluateFormConfig: {
|
|
updateEvaluatedConfig: "false",
|
|
},
|
|
},
|
|
updateSectionConfigTest1: {
|
|
conditionals: {},
|
|
visible: true,
|
|
enabled: true,
|
|
evaluateFormConfig: {
|
|
updateEvaluatedConfig: true,
|
|
evaluateFormConfigObject: {
|
|
key1: { output: "value1" },
|
|
key2: { output: "value2" },
|
|
},
|
|
},
|
|
},
|
|
updateSectionConfigTest2: {
|
|
conditionals: {},
|
|
visible: true,
|
|
enabled: true,
|
|
evaluateFormConfig: {
|
|
updateEvaluatedConfig: false,
|
|
evaluateFormConfigObject: {
|
|
key1: { output: "value1" },
|
|
key2: { output: "value2" },
|
|
},
|
|
},
|
|
},
|
|
};
|