Skip to content

Commit

Permalink
Make temporal error mesage more verbose (explicitly say the second co…
Browse files Browse the repository at this point in the history
…ndition)
  • Loading branch information
echeng06 committed Nov 19, 2024
1 parent bb360ab commit 6f75698
Show file tree
Hide file tree
Showing 3 changed files with 10 additions and 6 deletions.
4 changes: 2 additions & 2 deletions nacc_form_validator/errors.py
Original file line number Diff line number Diff line change
Expand Up @@ -89,7 +89,7 @@ def __set_custom_error_codes(self):
0x1009:
"{1} for if {2} else {3} - compatibility rule no: {0}",
0x2000:
"{1} in current visit for {2} in previous visit - temporal rule no: {0}",
"{1} in current visit for if {2} in previous visit then {3} in current visit - temporal rule no: {0}",
0x2001:
"primary key variable {0} not set in current visit data",
0x2002:
Expand Down Expand Up @@ -121,7 +121,7 @@ def __set_custom_error_codes(self):
0x3003:
"Error in comparing {0} to age at {1} ({2}): {3}",
0x3004:
"{1} in previous visit for {2} in current visit - temporal rule no: {0}",
"{1} in previous visit for if {2} in current visit then {3} in previous visit - temporal rule no: {0}",
}

self.messages.update(custom_errors)
Expand Down
2 changes: 1 addition & 1 deletion nacc_form_validator/nacc_validator.py
Original file line number Diff line number Diff line change
Expand Up @@ -764,7 +764,7 @@ def _validate_temporalrules(self, temporalrules: List[Mapping], field: str,
if not valid and errors:
for error in errors.items():
self._error(field, error_def, rule_no, str(error),
prev_conds)
prev_conds, curr_conds)

def _validate_logic(self, logic: Dict[str, Any], field: str,
value: object):
Expand Down
10 changes: 7 additions & 3 deletions tests/test_nacc_validator_datastore.py
Original file line number Diff line number Diff line change
Expand Up @@ -126,7 +126,7 @@ def test_temporal_check(schema):

assert not nv.validate({'patient_id': 'PatientID1', 'visit_num': 4, 'taxes': 8})
assert nv.errors == {'taxes': [
"('taxes', ['unallowed value 8']) in current visit for {'taxes': {'allowed': [0]}} in previous visit - temporal rule no: 0"]}
"('taxes', ['unallowed value 8']) in current visit for if {'taxes': {'allowed': [0]}} in previous visit then {'taxes': {'forbidden': [8]}} in current visit - temporal rule no: 0"]}

def test_temporal_check_swap_order(schema):
""" Test temporal check when the order of evaluation is swapped """
Expand All @@ -139,7 +139,7 @@ def test_temporal_check_swap_order(schema):
nv.reset_record_cache()
assert not nv.validate({'patient_id': 'PatientID1', 'visit_num': 2, 'taxes': 1})
assert nv.errors == {'taxes': [
"('taxes', ['unallowed value 8']) in previous visit for {'taxes': {'allowed': [0]}} in current visit - temporal rule no: 0"]}
"('taxes', ['unallowed value 8']) in previous visit for if {'taxes': {'allowed': [0]}} in current visit then {'taxes': {'forbidden': [8]}} in previous visit - temporal rule no: 0"]}

def test_temporal_check_no_prev_visit(schema):
""" Temporal test check when there are no previous visits (e.g. before visit 0) """
Expand Down Expand Up @@ -304,7 +304,11 @@ def test_temporal_check_with_nested_compare_with_previous_record():
assert nv.validate({'patient_id': 'PatientID1', 'visit_num': 4, 'birthyr': 1950})

assert not nv.validate({'patient_id': 'PatientID1', 'visit_num': 4, 'birthyr': 1951})
assert nv.errors == {'birthyr': ['(\'birthyr\', ["input value doesn\'t satisfy the condition birthyr == birthyr (previous record)"]) in current visit for {\'birthyr\': {\'forbidden\': [-1]}} in previous visit - temporal rule no: 0']}
assert nv.errors == {'birthyr': [
'(\'birthyr\', ["input value doesn\'t satisfy the condition birthyr == birthyr (previous record)"]) in current visit for ' +
'if {\'birthyr\': {\'forbidden\': [-1]}} in previous visit ' +
'then {\'birthyr\': {\'compare_with\': {\'comparator\': \'==\', \'base\': \'birthyr\', \'previous_record\': True}}} in current visit ' +
'- temporal rule no: 0']}

def test_check_with_rxnorm():
""" Test checking drugID is a valid RXCUI """
Expand Down

0 comments on commit 6f75698

Please sign in to comment.