PromucFlow_constructor/app/client/src/components/formControls/utils.test.ts
Ilia d6f249b42d
chore: add blank line eslint rule (#36369)
## Description
Added ESLint rule to force blank lines between statements. 


Fixes #`Issue Number`  
_or_  
Fixes `Issue URL`
> [!WARNING]  
> _If no issue exists, please create an issue first, and check with the
maintainers if the issue is valid._

## Automation

/ok-to-test tags="@tag.All"

### 🔍 Cypress test results
<!-- This is an auto-generated comment: Cypress test results  -->
> [!CAUTION]
> 🔴 🔴 🔴 Some tests have failed.
> Workflow run:
<https://github.com/appsmithorg/appsmith/actions/runs/10924926728>
> Commit: 34f57714a1575ee04e94e03cbcaf95e57a96c86c
> <a
href="https://internal.appsmith.com/app/cypress-dashboard/rundetails-65890b3c81d7400d08fa9ee5?branch=master&workflowId=10924926728&attempt=1&selectiontype=test&testsstatus=failed&specsstatus=fail"
target="_blank">Cypress dashboard</a>.
> Tags: @tag.All
> Spec: 
> The following are new failures, please fix them before merging the PR:
<ol>
> <li>cypress/e2e/Regression/ClientSide/Anvil/AnvilModal_spec.ts
>
<li>cypress/e2e/Regression/ClientSide/Anvil/Widgets/AnvilButtonWidgetSnapshot_spec.ts
>
<li>cypress/e2e/Regression/ClientSide/Anvil/Widgets/AnvilCheckboxGroupWidgetSnapshot_spec.ts
>
<li>cypress/e2e/Regression/ClientSide/Anvil/Widgets/AnvilCurrencyInputWidgetSnapshot_spec.ts
>
<li>cypress/e2e/Regression/ClientSide/Anvil/Widgets/AnvilIconButtonWidgetSnapshot_spec.ts
>
<li>cypress/e2e/Regression/ClientSide/Anvil/Widgets/AnvilInlineButtonWidgetSnapshot_spec.ts
>
<li>cypress/e2e/Regression/ClientSide/Anvil/Widgets/AnvilInputWidgetSnapshot_spec.ts
>
<li>cypress/e2e/Regression/ClientSide/Anvil/Widgets/AnvilParagraphWidgetSnapshot_spec.ts
>
<li>cypress/e2e/Regression/ClientSide/Anvil/Widgets/AnvilPhoneInputWidgetSnapshot_spec.ts
>
<li>cypress/e2e/Regression/ClientSide/Anvil/Widgets/AnvilStatsWidgetSnapshot_spec.ts
>
<li>cypress/e2e/Regression/ClientSide/Anvil/Widgets/AnvilSwitchGroupWidgetSnapshot_spec.ts
>
<li>cypress/e2e/Regression/ClientSide/Anvil/Widgets/AnvilSwitchWidgetSnapshot_spec.ts
>
<li>cypress/e2e/Regression/ClientSide/Anvil/Widgets/AnvilTableWidgetSnapshot_spec.ts
>
<li>cypress/e2e/Regression/ClientSide/Anvil/Widgets/AnvilToolbarButtonWidgetSnapshot_spec.ts
>
<li>cypress/e2e/Regression/ClientSide/Anvil/Widgets/AnvilZoneSectionWidgetSnapshot_spec.ts</ol>
> <a
href="https://internal.appsmith.com/app/cypress-dashboard/identified-flaky-tests-65890b3c81d7400d08fa9ee3?branch=master"
target="_blank">List of identified flaky tests</a>.
> <hr>Wed, 18 Sep 2024 16:33:36 UTC
<!-- end of auto-generated comment: Cypress test results  -->


## Communication
Should the DevRel and Marketing teams inform users about this change?
- [ ] Yes
- [ ] No

---------

Co-authored-by: Valera Melnikov <valera@appsmith.com>
2024-09-18 19:35:28 +03:00

1057 lines
27 KiB
TypeScript

import {
actionPathFromName,
caculateIsHidden,
checkIfSectionCanRender,
checkIfSectionIsEnabled,
evaluateCondtionWithType,
extractConditionalOutput,
getConfigInitialValues,
getViewType,
isHidden,
switchViewType,
updateEvaluatedSectionConfig,
ViewTypes,
} from "./utils";
import type { HiddenType } from "./BaseControl";
import { set } from "lodash";
import { isValidFormConfig } from "reducers/evaluationReducers/formEvaluationReducer";
import { FEATURE_FLAG } from "ee/entities/FeatureFlag";
describe("isHidden test", () => {
it("Test for isHidden true", () => {
// TODO: Fix this the next time the file is edited
// eslint-disable-next-line @typescript-eslint/no-explicit-any
const hiddenTrueInputs: any = [
{ values: { name: "Name" }, hidden: true },
{
values: {
datasourceStorages: {
unused_env: { name: "Name", number: 2, email: "temp@temp.com" },
},
},
hidden: {
conditionType: "AND",
conditions: [
{
path: "datasourceStorages.unused_env.name",
value: "Name",
comparison: "EQUALS",
},
{
conditionType: "AND",
conditions: [
{
path: "datasourceStorages.unused_env.number",
value: 2,
comparison: "EQUALS",
},
{
path: "datasourceStorages.unused_env.email",
value: "temp@temp.com",
comparison: "EQUALS",
},
],
},
],
},
},
{
values: {
datasourceStorages: {
unused_env: { name: "Name" },
},
},
hidden: {
path: "datasourceStorages.unused_env.name",
value: "Name",
comparison: "EQUALS",
},
},
{
values: {
datasourceStorages: {
unused_env: { name: "Name", config: { type: "EMAIL" } },
},
},
hidden: {
path: "datasourceStorages.unused_env.name.config.type",
value: "USER_ID",
comparison: "NOT_EQUALS",
},
},
{
values: undefined,
hidden: true,
},
{
values: null,
hidden: true,
},
];
// TODO: Fix this the next time the file is edited
// eslint-disable-next-line @typescript-eslint/no-explicit-any
hiddenTrueInputs.forEach((input: any) => {
expect(isHidden(input.values, input.hidden)).toBeTruthy();
});
});
it("Test for isHidden false", () => {
// TODO: Fix this the next time the file is edited
// eslint-disable-next-line @typescript-eslint/no-explicit-any
const hiddenFalseInputs: any = [
{ values: { name: "Name" }, hidden: false },
{
values: {
datasourceStorages: {
unused_env: { name: "Name" },
},
},
hidden: {
path: "datasourceStorages.unused_env.name",
value: "Different Name",
comparison: "EQUALS",
},
},
{
values: {
datasourceStorages: {
unused_env: { name: "Name", config: { type: "EMAIL" } },
},
},
hidden: {
path: "datasourceStorages.unused_env.config.type",
value: "EMAIL",
comparison: "NOT_EQUALS",
},
},
{
values: {
datasourceStorages: {
unused_env: { name: "Name", config: { type: "Different BODY" } },
},
},
hidden: {
path: "datasourceStorages.unused_env.config.type",
value: ["EMAIL", "BODY"],
comparison: "IN",
},
},
{
values: {
datasourceStorages: {
unused_env: { name: "Name", config: { type: "BODY" } },
},
},
hidden: {
path: "datasourceStorages.unused_env.config.type",
value: ["EMAIL", "BODY"],
comparison: "NOT_IN",
},
},
{
values: undefined,
hidden: false,
},
{
values: null,
hidden: false,
},
{
values: undefined,
},
{
values: {
datasourceStorages: {
unused_env: { name: "Name" },
},
},
},
{
values: {
datasourceStorages: {
unused_env: {
name: "Name",
config: { type: "EMAIL", name: "TEMP" },
contact: { number: 1234, address: "abcd" },
},
},
},
hidden: {
conditionType: "AND",
conditions: [
{
path: "datasourceStorages.unused_env.contact.number",
value: 1234,
comparison: "NOT_EQUALS",
},
{
conditionType: "OR",
conditions: [
{
conditionType: "AND",
conditions: [
{
path: "datasourceStorages.unused_env.config.name",
value: "TEMP",
comparison: "EQUALS",
},
{
path: "datasourceStorages.unused_env.config.name",
value: "HELLO",
comparison: "EQUALS",
},
],
},
{
path: "datasourceStorages.unused_env.config.type",
value: "EMAIL",
comparison: "NOT_EQUALS",
},
],
},
],
},
},
];
// TODO: Fix this the next time the file is edited
// eslint-disable-next-line @typescript-eslint/no-explicit-any
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:
"datasourceStorages.unused_env.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: {
datasourceStorages: {
unused_env: {
datasourceConfiguration: {
authentication: { databaseName: "ap-south-1" },
},
},
},
},
},
{
input: [
{
sectionName: "Connection",
children: [
{
label: "Region",
configProperty:
"datasourceStorages.unused_env.datasourceConfiguration.authentication.databaseName",
controlType: "INPUT_TEXT",
},
],
},
],
output: {},
},
{
input: [
{
sectionName: "Connection",
children: [
{
label: "Host address (for overriding endpoint only)",
configProperty:
"datasourceStorages.unused_env.datasourceConfiguration.endpoints[*].host",
controlType: "KEYVALUE_ARRAY",
initialValue: ["jsonplaceholder.typicode.com"],
},
{
label: "Port",
configProperty:
"datasourceStorages.unused_env.datasourceConfiguration.endpoints[*].port",
dataType: "NUMBER",
controlType: "KEYVALUE_ARRAY",
},
],
},
],
output: {
datasourceStorages: {
unused_env: {
datasourceConfiguration: {
endpoints: [{ host: "jsonplaceholder.typicode.com" }],
},
},
},
},
},
{
input: [
{
sectionName: "Settings",
children: [
{
label: "Smart substitution",
configProperty:
"datasourceStorages.unused_env.datasourceConfiguration.isSmart",
controlType: "SWITCH",
initialValue: false,
},
],
},
],
output: {
datasourceStorages: {
unused_env: {
datasourceConfiguration: {
isSmart: false,
},
},
},
},
},
];
testCases.forEach((testCase) => {
expect(getConfigInitialValues(testCase.input)).toEqual(testCase.output);
});
});
});
describe("caculateIsHidden test", () => {
it("calcualte hidden field value", () => {
const values = {
datasourceStorages: {
unused_env: { name: "Name" },
},
};
const hiddenTruthy: HiddenType = {
path: "datasourceStorages.unused_env.name",
comparison: "EQUALS",
value: "Name",
flagValue: FEATURE_FLAG.TEST_FLAG,
};
const hiddenFalsy: HiddenType = {
path: "datasourceStorages.unused_env.name",
comparison: "EQUALS",
value: "Different Name",
flagValue: FEATURE_FLAG.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", () => {
// TODO: Fix this the next time the file is edited
// eslint-disable-next-line @typescript-eslint/no-explicit-any
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,
// TODO: Fix this the next time the file is edited
// eslint-disable-next-line @typescript-eslint/no-explicit-any
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,
},
},
},
};
// TODO: Fix this the next time the file is edited
// eslint-disable-next-line @typescript-eslint/no-explicit-any
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", () => {
// TODO: Fix this the next time the file is edited
// eslint-disable-next-line @typescript-eslint/no-explicit-any
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
// TODO: Fix this the next time the file is edited
// eslint-disable-next-line @typescript-eslint/no-explicit-any
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" },
},
},
},
};