From 4e2f7597fde26f4384d726f8e5baf174f3ab8290 Mon Sep 17 00:00:00 2001 From: Daniel Berge Sollien Date: Thu, 25 Jan 2024 14:56:37 +0100 Subject: [PATCH 1/5] Add docstring --- src/fmu/sumo/sim2sumo/hook_implementations/jobs.py | 1 + 1 file changed, 1 insertion(+) diff --git a/src/fmu/sumo/sim2sumo/hook_implementations/jobs.py b/src/fmu/sumo/sim2sumo/hook_implementations/jobs.py index 9a1d8b8a..b4a3f13c 100644 --- a/src/fmu/sumo/sim2sumo/hook_implementations/jobs.py +++ b/src/fmu/sumo/sim2sumo/hook_implementations/jobs.py @@ -1,3 +1,4 @@ +"""Install in ert, including documentation to ert-docs""" import importlib import os import sys From d124dbbd887c8cf98490fd9c2f50f47fce71ab50 Mon Sep 17 00:00:00 2001 From: Daniel Berge Sollien Date: Thu, 25 Jan 2024 14:57:38 +0100 Subject: [PATCH 2/5] Hardcode documentation strings --- .../sim2sumo/hook_implementations/jobs.py | 49 +++++++++++++++++++ 1 file changed, 49 insertions(+) diff --git a/src/fmu/sumo/sim2sumo/hook_implementations/jobs.py b/src/fmu/sumo/sim2sumo/hook_implementations/jobs.py index b4a3f13c..40061a98 100644 --- a/src/fmu/sumo/sim2sumo/hook_implementations/jobs.py +++ b/src/fmu/sumo/sim2sumo/hook_implementations/jobs.py @@ -8,6 +8,55 @@ from ert.shared.plugins.plugin_response import plugin_response +DESCRIPTION = """ +Makes result simulator (Eclipse, OPM, IX) available in sumo. +This is done by SIM2SUMO in a three step process: +1. Data is extracted in arrow format using res2df +2. Corresponding metadata are generated via fmu-dataio +3. Data and metadata are then uploaded to Sumo using fmu-sumo-upload +SIM2SUMO is set up to automatically extract summary, rft and well completion data, but +you can configure it to extract any datatype that res2df can produce. + +SIM2SUMO autodetects results from your the eclipse/model/ folder in your realization. +Basically looking for files with suffix .DATA, and then going on to finding the eclipse +run results. This means that if you have more than one eclipse run in that folder, you will +get the specified result from all those runs. The results will be stored in sumo with +name where the habituary - at the end is removed, +tagname will be name of datatype extracted. + +E.G: summary files extracted from an eclipse run names DROGON-1, will be stored in +sumo with name: DROGON, tagname: summary, and fmu.realization.id: 1 + + Pre-requisites: SIM2SUMO is dependent on a configuration yaml file. + (defaulted to ../../fmuconfig/output/global_variables.yml). + This file needs to contain masterdata, and if you want + to have some custom configurations, this is also done here . + See examples. + +""" +EXAMPLES = """ +1. Extracting the defaults, with fmu_config in the standard location: + + In an Ert config file + FORWARD_MODEL ECLIPSE100(...) + --Note: SIM2SUMO must come after ECLIPSE100 + FORWARD_MODEL SIM2SUMO(=path/to/config/file) + +2. Extracting the defaults, but with fmu_config in a non standard location: + + In an Ert config file + FORWARD_MODEL ECLIPSE100(...) + --Note: SIM2SUMO must come after ECLIPSE100 + FORWARD_MODEL SIM2SUMO(=path/to/config/file) + +3. When you want to configure the fmu_config file to control what SIM2SUMO produces + (for inclusion of the forward model in your ert setup see examples 1. or 2.) + add section sim2sumo to your fmu_config file. Documentation of how to do this is + under construction, for now contact Daniel Sollien (dbs) for help. +""" +PLUGIN_NAME = "SIM2SUMO" + + def _get_jobs_from_directory(directory): """Do a filesystem lookup in a directory to check for available ERT forward models""" From 978c704bd3c0ba096c95605ab8f33e04c6580b36 Mon Sep 17 00:00:00 2001 From: Daniel Berge Sollien Date: Thu, 25 Jan 2024 14:59:45 +0100 Subject: [PATCH 3/5] Use global name in hooks --- src/fmu/sumo/sim2sumo/hook_implementations/jobs.py | 7 +++---- 1 file changed, 3 insertions(+), 4 deletions(-) diff --git a/src/fmu/sumo/sim2sumo/hook_implementations/jobs.py b/src/fmu/sumo/sim2sumo/hook_implementations/jobs.py index 40061a98..f04c1c32 100644 --- a/src/fmu/sumo/sim2sumo/hook_implementations/jobs.py +++ b/src/fmu/sumo/sim2sumo/hook_implementations/jobs.py @@ -61,9 +61,8 @@ def _get_jobs_from_directory(directory): """Do a filesystem lookup in a directory to check for available ERT forward models""" resource_directory = ( - Path(sys.modules["fmu.sumo.sim2sumo"].__file__).parent / directory + Path(sys.modules["fmu.sumo.sim2sumo"].__file__) / directory ) - all_files = [ os.path.join(resource_directory, f) for f in os.listdir(resource_directory) @@ -75,7 +74,7 @@ def _get_jobs_from_directory(directory): # pylint: disable=no-value-for-parameter @hook_implementation @plugin_response( - plugin_name="fmu_sumo_sim2sumo" + plugin_name=PLUGIN_NAME ) # pylint: disable=no-value-for-parameter def installable_jobs(): return _get_jobs_from_directory("config_jobs") @@ -92,7 +91,7 @@ def _get_module_variable_if_exists(module_name, variable_name, default=""): @hook_implementation @plugin_response( - plugin_name="fmu_sumo_sim2sumo" + plugin_name=PLUGIN_NAME ) # pylint: disable=no-value-for-parameter def job_documentation(job_name): sumo_fmu_jobs = set(installable_jobs().data.keys()) From 5cf1e94a0fee6b2114407828ae0e73aee70da0cb Mon Sep 17 00:00:00 2001 From: Daniel Berge Sollien Date: Thu, 25 Jan 2024 15:01:08 +0100 Subject: [PATCH 4/5] Add docstring --- src/fmu/sumo/sim2sumo/hook_implementations/jobs.py | 14 +++++--------- 1 file changed, 5 insertions(+), 9 deletions(-) diff --git a/src/fmu/sumo/sim2sumo/hook_implementations/jobs.py b/src/fmu/sumo/sim2sumo/hook_implementations/jobs.py index f04c1c32..ac8f5a62 100644 --- a/src/fmu/sumo/sim2sumo/hook_implementations/jobs.py +++ b/src/fmu/sumo/sim2sumo/hook_implementations/jobs.py @@ -77,16 +77,12 @@ def _get_jobs_from_directory(directory): plugin_name=PLUGIN_NAME ) # pylint: disable=no-value-for-parameter def installable_jobs(): - return _get_jobs_from_directory("config_jobs") - + """Return installable jobs -def _get_module_variable_if_exists(module_name, variable_name, default=""): - try: - script_module = importlib.import_module(module_name) - except ImportError: - return default - - return getattr(script_module, variable_name, default) + Returns: + dictionary: the jobs to install + """ + return _get_jobs_from_directory("config_jobs") @hook_implementation From 00f623c3c08b28a2cf660ff66f43998b455d8d24 Mon Sep 17 00:00:00 2001 From: Daniel Berge Sollien Date: Thu, 25 Jan 2024 15:01:32 +0100 Subject: [PATCH 5/5] Tidy function --- .../sumo/sim2sumo/hook_implementations/jobs.py | 18 +++--------------- 1 file changed, 3 insertions(+), 15 deletions(-) diff --git a/src/fmu/sumo/sim2sumo/hook_implementations/jobs.py b/src/fmu/sumo/sim2sumo/hook_implementations/jobs.py index ac8f5a62..b82e9782 100644 --- a/src/fmu/sumo/sim2sumo/hook_implementations/jobs.py +++ b/src/fmu/sumo/sim2sumo/hook_implementations/jobs.py @@ -94,20 +94,8 @@ def job_documentation(job_name): if job_name not in sumo_fmu_jobs: return None - module_name = "jobs.scripts.{}".format(job_name.lower()) - - description = _get_module_variable_if_exists( - module_name=module_name, variable_name="description" - ) - examples = _get_module_variable_if_exists( - module_name=module_name, variable_name="examples" - ) - category = _get_module_variable_if_exists( - module_name=module_name, variable_name="category", default="other" - ) - return { - "description": description, - "examples": examples, - "category": category, + "description": DESCRIPTION, + "examples": EXAMPLES, + "category": "export", }