From fdc821eba0e71ebffe6eaf0ba06083713d8f4dcd Mon Sep 17 00:00:00 2001 From: Peter N O Gillespie Date: Thu, 23 May 2024 11:51:34 +0000 Subject: [PATCH] `XspectraCrystalWorkChain`: Requested Changes 1 Changes requested for PR #1028: * Small refactor of input validation code to condense checks into fewer lines. * Re-arranged checks to ensure that `site_index` validation occurs *after* `required_keys` are checked. Previous behaviour would not indicate which entry/entries were missing the `site_index` * Fixed a small formatting error in the error message for mismatch in absorbing elements. --- .../workflows/xspectra/crystal.py | 27 ++++++++----------- 1 file changed, 11 insertions(+), 16 deletions(-) diff --git a/src/aiida_quantumespresso/workflows/xspectra/crystal.py b/src/aiida_quantumespresso/workflows/xspectra/crystal.py index e222c982..bfa01326 100644 --- a/src/aiida_quantumespresso/workflows/xspectra/crystal.py +++ b/src/aiida_quantumespresso/workflows/xspectra/crystal.py @@ -461,26 +461,21 @@ def validate_inputs(inputs, _): # We assume otherwise that the user knows what they're doing and has set everything else # to their preferences correctly. for site_label, value in equivalent_sites_data.items(): - required_keys_found = [] + entry_invalid = False - if value['site_index'] < 0: - raise ValidationError( - f'The site index for {site_label} ({value["site_index"]}) is below the range of ' - + f'sites within the structure (0-{len(structure.sites) -1}).' - ) - if value['site_index'] >= len(structure.sites): - raise ValidationError( - f'The site index for {site_label} ({value["site_index"]}) is above the range of ' - + f'sites within the structure (0-{len(structure.sites) -1}).' - ) - for key in value: - if key in required_keys: - required_keys_found.append(key) - if sorted(required_keys_found) != required_keys: + if not set(required_keys).issubset(set(value.keys())) : invalid_entries.append(site_label) + entry_invalid = True elif value['symbol'] not in input_elements: input_elements.append(value['symbol']) + if not entry_invalid: + if value['site_index'] < 0 or value['site_index'] >= len(structure.sites): + raise ValidationError( + f'The site index for {site_label} ({value["site_index"]}) is outside the range of ' + + f'sites within the structure (0-{len(structure.sites) -1}).' + ) + if len(invalid_entries) != 0: raise ValidationError( f'The required keys ({required_keys}) were not found in the following entries: {invalid_entries}' @@ -490,7 +485,7 @@ def validate_inputs(inputs, _): if sorted_input_elements != absorbing_elements_list: raise ValidationError( f'Elements defined for sites in `equivalent_sites_data` ({sorted_input_elements}) do not match the' - + f'list of absorbing elements ({absorbing_elements_list})' + + f' list of absorbing elements ({absorbing_elements_list})' )