From 2ab83dfdc4dadada536a627461122d58d1ee3fbe Mon Sep 17 00:00:00 2001 From: brendanjbond Date: Mon, 25 Mar 2024 12:40:24 +0000 Subject: [PATCH 1/2] always process json validation even if value is falsy --- src/process/validation/rules/validateJson.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/process/validation/rules/validateJson.ts b/src/process/validation/rules/validateJson.ts index de333b1a..68c879a7 100644 --- a/src/process/validation/rules/validateJson.ts +++ b/src/process/validation/rules/validateJson.ts @@ -6,7 +6,7 @@ import { isObject } from 'lodash'; export const shouldValidate = (context: ValidationContext) => { const { component, value } = context; - if (!value || !component.validate?.json || !isObject(component.validate.json)) { + if (!component.validate?.json || !isObject(component.validate.json)) { return false; } return true; From cfc72b4cac5da7331c62296be56a0a864634f87d Mon Sep 17 00:00:00 2001 From: brendanjbond Date: Mon, 25 Mar 2024 12:44:16 +0000 Subject: [PATCH 2/2] add test --- .../rules/__tests__/validateJson.test.ts | 29 +++++++++++++++++++ 1 file changed, 29 insertions(+) diff --git a/src/process/validation/rules/__tests__/validateJson.test.ts b/src/process/validation/rules/__tests__/validateJson.test.ts index d4d529e8..5340dbc7 100644 --- a/src/process/validation/rules/__tests__/validateJson.test.ts +++ b/src/process/validation/rules/__tests__/validateJson.test.ts @@ -71,3 +71,32 @@ it('A simple component with JSON logic evaluation will return null if the JSON l const result = await validateJson(context); expect(result).to.equal(null); }); + +it('A simple component with JSON logic evaluation will validate even if the value is falsy', async () => { + const component = { + ...simpleTextField, + validate: { + json: { + if: [ + { + '===': [ + { + var: 'input', + }, + 'foo', + ], + }, + true, + "Input must be 'foo'", + ], + }, + }, + }; + const data = { + component: '', + }; + const context = generateProcessorContext(component, data); + const result = await validateJson(context); + expect(result).to.be.instanceOf(FieldError); + expect(result?.errorKeyOrMessage).to.contain("Input must be 'foo'"); +});