Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Detect and warn if empty entries in config.stratigraphy #386

Merged

Conversation

perolavsvendsen
Copy link
Member

Solve #383. But there are probably better ways. See issue for details.

@@ -109,8 +115,51 @@ def _check_global_config(
"One or more keys required for valid metadata are not found: "
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

msg += ...

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Comment on lines 119 to 159
# check "stratigraphy"
if "stratigraphy" in globalconfig:
# we currently allow (why?) stratigraphy key missing from config.
strat = globalconfig["stratigraphy"]
if not isinstance(strat, dict):
msg += "The 'stratigraphy' must be a dictionary.\n"

# Loop the entries in 'stratigraphy'
# These keys are custom, but we want error messages to point to the key when
# issues are discovered. This makes it tricky to use jsonschema. Pydantic might
# be an option. But for now, just go through all items and do defined checks.

for key, item in strat.items():
if "name" not in item:
msg += f"stratigraphy.{key}: 'name' is missing. \n"
elif not isinstance(item["name"], str):
msg += f"stratigraphy.{key}: 'name' must be a string.\n"

if "stratigraphic" not in item:
msg += f"stratigraphy.{key}: 'stratigraphic' is missing.\n"
elif not isinstance(item["stratigraphic"], bool):
msg += f"stratigraphy.{key}: 'stratigraphic' must be a boolean.\n"

if "alias" in item:
if not isinstance(item["alias"], list):
msg += f"stratigraphy.{key}: 'alias' must be a list.\n"
else:
for alias in item["alias"]:
if not isinstance(alias, str):
msg += (
f"stratigraphy.{key}: 'alias' items must be strings\n"
)

if "stratigraphic_alias" in item:
if not isinstance(item["stratigraphic_alias"], list):
msg += f"stratigraphy.{key}: 'stratigraphic_alias' must be list.\n"
else:
for alias in item["stratigraphic_alias"]:
if not isinstance(alias, str):
msg += f"stratigraphy.{key}: 'stratigraphic_alias' items "
msg += "must be strings.\n"
Copy link
Collaborator

@jcrivenaes jcrivenaes Nov 7, 2023

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Gets many lines of code. Could be an idea to refactor check of the global config to a new module (even a class)?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yes, agree. This doesn't scale very well. Have explored using a schema for this, and then using jsonschema to validate but experiments show it's not a great solution (either). Pydantic is also a possibility.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I discussed this a little bit also in #383. This sounds like a separate issue, perhaps, and a slightly bigger job. But also sounds that it makes sense to carve out the functionality of the global_variables. Perhaps the config should be a class, rather than a dictionary inside fmu-dataio 🤷

Copy link
Collaborator

@jcrivenaes jcrivenaes left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Should we in general detect entries will null content, like the example in #386 ? In this case:

  alias:
    - MyFormation
    - OtherAlias
    -                   # <-- PROBLEM!

Just remove the entry at the PROBLEM line?

@perolavsvendsen
Copy link
Member Author

Just remove the entry at the PROBLEM line?

I guess we can sanitize and remove before we use it, but that will leave the problem in place for the next application to discover it. Idea was that it would be better to address it, so that it would be fixed. But we can also do both, I think.

Copy link
Collaborator

@jcrivenaes jcrivenaes left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM

@perolavsvendsen perolavsvendsen merged commit e2ebac9 into equinor:main Nov 9, 2023
6 checks passed
@perolavsvendsen perolavsvendsen deleted the 383-undefined-config-elements branch November 9, 2023 10:47
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants