From 2722baf02cf7621522fb2b33a2d2b8f62e46ebfc Mon Sep 17 00:00:00 2001 From: aditya Date: Wed, 16 Oct 2024 15:54:41 -0700 Subject: [PATCH] fix: ensure picklist values are formatted correctly prior to comparison (#3649) * fix: ensure picklist values are formatted correctly prior to comparison * fix: adds a cleaner error message * fix: re-add missing context --- .../server/src/arpa_reporter/services/validate-upload.js | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/packages/server/src/arpa_reporter/services/validate-upload.js b/packages/server/src/arpa_reporter/services/validate-upload.js index d795e00b8..e049aad7b 100644 --- a/packages/server/src/arpa_reporter/services/validate-upload.js +++ b/packages/server/src/arpa_reporter/services/validate-upload.js @@ -326,9 +326,9 @@ async function validateRecord({ upload, record, typeRules: rules }) { const lcItems = rule.listVals.map((val) => multiselect(val.toLowerCase())); // for pick lists, the value must be one of possible values - if (rule.dataType === 'Pick List' && !lcItems.includes(value)) { + if (rule.dataType === 'Pick List' && !lcItems.includes(multiselect(value))) { errors.push(new ValidationError( - `Value for ${key} ('${value}') must be one of ${lcItems.length} options in the input template`, + `Value for ${key} ('${value}') must be one of ${lcItems.length} valid options in the input template. (${JSON.stringify(lcItems)})`, { col: rule.columnName, severity: 'err' }, )); } @@ -339,7 +339,7 @@ async function validateRecord({ upload, record, typeRules: rules }) { for (const entry of entries) { if (!lcItems.includes(entry)) { errors.push(new ValidationError( - `Entry '${entry}' of ${key} is not one of ${lcItems.length} valid options`, + `Entry '${entry}' of ${key} is not one of ${lcItems.length} valid options (${JSON.stringify(lcItems)})`, { col: rule.columnName, severity: 'err' }, )); }