Skip to content

Commit

Permalink
Merge pull request #31 from ralfeis/master
Browse files Browse the repository at this point in the history
Fixed required validation considering false value falsy
  • Loading branch information
brendanbond authored Apr 17, 2024
2 parents 2102073 + 8fe567d commit 672b0ed
Show file tree
Hide file tree
Showing 2 changed files with 53 additions and 2 deletions.
53 changes: 52 additions & 1 deletion src/process/validation/rules/__tests__/validateRequired.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,8 @@ import { expect } from 'chai';

import { FieldError } from 'error';
import { validateRequired } from '../validateRequired';
import { conditionallyHiddenRequiredHiddenField, hiddenRequiredField, requiredNonInputField, simpleTextField } from './fixtures/components';

import { conditionallyHiddenRequiredHiddenField, hiddenRequiredField, requiredNonInputField, simpleTextField, simpleSelectBoxes, simpleRadioField } from './fixtures/components';
import { processOne } from 'processes/processOne';
import { generateProcessorContext } from './fixtures/util';
import { ProcessorsContext, ValidationScope } from 'types';
Expand All @@ -25,6 +26,56 @@ it('Validating a simple component that is required and present in the data will
expect(result).to.equal(null);
});


it('Validating a simple radio component that is required and present in the data with value=false will return null', async () => {
const component = { ...simpleRadioField, validate: { required: true }, values: [
{
label: 'Yes',
value: 'true',
},
{
label: 'No',
value: 'false',
}] };
const data = { component: false };
const context = generateProcessContext(component, data);
const result = await validateRequired(context);
expect(result).to.equal(null);
});


it('Validating a simple selectbox that is required and present in the data with value=0 will return null', async () => {
const component = { ...simpleSelectBoxes, validate: { required: true }, values: [
{
label: 'true',
value: 'true',
},
{
label: 'Null',
value: '0',
}] };
const data = { component: 0 };
const context = generateProcessContext(component, data);
const result = await validateRequired(context);
expect(result).to.equal(null);
});

it('Validating a simple selectbox that is required and present in the data with value=false will return null', async () => {
const component = { ...simpleSelectBoxes, validate: { required: true }, values: [
{
label: 'true',
value: 'true',
},
{
label: 'false',
value: 'false',
}] };
const data = { component: false };
const context = generateProcessContext(component, data);
const result = await validateRequired(context);
expect(result).to.equal(null);
});

it('Validating a simple component that is not required and present in the data will return null', async () => {
const component = simpleTextField;
const data = { component: 'a simple value' };
Expand Down
2 changes: 1 addition & 1 deletion src/process/validation/rules/validateRequired.ts
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@ export const validateRequiredSync: RuleFnSync = (context: ValidationContext) =>
return null;
}
if (
(value === null || value === undefined || isEmptyObject(value) || (!!value === false && value !== 0)) &&
(value === null || value === undefined || isEmptyObject(value) || (!!value === false && value !== 0 && value !==false )) &&
!component.hidden
) {
return error;
Expand Down

0 comments on commit 672b0ed

Please sign in to comment.