Exemplo n.º 1
0
    def test_grid(self):
        grid_file = self.createTestPath(EGRID_file)
        smspec_file = self.createTestPath(SMSPEC_file)
        ec = EclConfig()
        ui = ec.validateGridFile(grid_file)
        self.assertTrue(ui)
        self.assertTrue(isinstance(ui, UIReturn))

        ui = ec.validateGridFile("Does/Not/Exist")
        self.assertFalse(ui)

        self.assertTrue(os.path.exists(smspec_file))
        ui = ec.validateGridFile(smspec_file)
        self.assertFalse(ui)
Exemplo n.º 2
0
    def test_schedule_file(self):
        ec = EclConfig()
        ui = ec.validateScheduleFile("DoesNotExist")
        self.assertFalse(ui)

        dfile = self.createTestPath(DATA_file)
        sfile = self.createTestPath(SCHEDULE_file)

        # Setting the schedule file should fail before the datafile
        # (i.e. startdate) has been set.
        ui = ec.validateScheduleFile(sfile)
        self.assertFalse(ui)

        ec.setDataFile(dfile)
        ui = ec.validateScheduleFile(sfile)
        self.assertTrue(ui)

        ec.setScheduleFile(sfile)
        self.assertEqual(sfile, ec.getScheduleFile())
Exemplo n.º 3
0
    def test_eclbase(self):
        ec = EclConfig()
        ui = ec.validateEclBase("MixedCase%d")
        self.assertFalse(ui)

        ui = ec.validateEclBase("CASE%s")
        self.assertFalse(ui)

        ui = ec.validateEclBase("CASE%d")
        self.assertTrue(ui)
        ec.setEclBase("CASE%d")
        self.assertEqual("CASE%d", ec.getEclBase())
Exemplo n.º 4
0
    def test_datafile(self):
        ec = EclConfig()
        ui = ec.validateDataFile("DoesNotExist")
        self.assertFalse(ui)

        dfile = self.createTestPath(DATA_file)
        ui = ec.validateDataFile(dfile)
        self.assertTrue(ui)
        ec.setDataFile(dfile)
        self.assertEqual(dfile, ec.getDataFile())
Exemplo n.º 5
0
    def test_refcase(self):
        ec = EclConfig()
        dfile = self.createTestPath(DATA_file)

        ui = ec.validateRefcase("Does/not/exist")
        self.assertFalse(ui)

        ui = ec.validateRefcase(dfile)
        self.assertTrue(ui)
        ec.loadRefcase(dfile)
        refcase = ec.getRefcase()
        self.assertTrue(isinstance(refcase, EclSum))
        refcaseName = ec.getRefcaseName() + ".DATA"
        self.assertEqual(dfile, refcaseName)
Exemplo n.º 6
0
    def _alloc_from_dict(self, config_dict, throw_on_error=True):
        # treat the default config dir
        config_dir = os.getcwd()
        if ConfigKeys.CONFIG_DIRECTORY in config_dict:
            config_dir = config_dict[ConfigKeys.CONFIG_DIRECTORY]
        config_dict[ConfigKeys.CONFIG_DIRECTORY] = config_dir

        subst_config = SubstConfig(config_dict=config_dict)
        site_config = SiteConfig(config_dict=config_dict)
        rng_config = RNGConfig(config_dict=config_dict)
        analysis_config = AnalysisConfig(config_dict=config_dict)
        ecl_config = EclConfig(config_dict=config_dict)
        log_config = LogConfig(config_dict=config_dict)
        queue_config = QueueConfig(config_dict=config_dict)

        ert_workflow_list = ErtWorkflowList(
            subst_list=subst_config.subst_list, config_dict=config_dict
        )

        hook_manager = HookManager(
            workflow_list=ert_workflow_list, config_dict=config_dict
        )

        ert_templates = ErtTemplates(
            parent_subst=subst_config.subst_list, config_dict=config_dict
        )

        ensemble_config = EnsembleConfig(
            grid=ecl_config.getGrid(),
            refcase=ecl_config.getRefcase(),
            config_dict=config_dict,
        )

        model_config = ModelConfig(
            data_root=config_dir,
            joblist=site_config.get_installed_jobs(),
            last_history_restart=ecl_config.getLastHistoryRestart(),
            refcase=ecl_config.getRefcase(),
            config_dict=config_dict,
        )

        return [
            subst_config,
            site_config,
            rng_config,
            analysis_config,
            ert_workflow_list,
            hook_manager,
            ert_templates,
            ecl_config,
            ensemble_config,
            model_config,
            log_config,
            queue_config,
        ], config_dir
Exemplo n.º 7
0
    def _alloc_from_content(self,
                            user_config_file=None,
                            config=None,
                            throw_on_error=True):
        if user_config_file is not None:
            # initialize configcontent if user_file provided
            parser = ConfigParser()
            config_content = self._alloc_config_content(
                user_config_file, parser)
            config_dir = config_content.getValue(ConfigKeys.CONFIG_DIRECTORY)
        else:
            config_dir = os.getcwd()
            config_content = self._build_config_content(config)

        if self.errors and throw_on_error:
            raise ValueError("Error loading configuration: " +
                             str(self._errors))

        subst_config = SubstConfig(config_content=config_content)
        site_config = SiteConfig(config_content=config_content)
        rng_config = RNGConfig(config_content=config_content)
        analysis_config = AnalysisConfig(config_content=config_content)
        ecl_config = EclConfig(config_content=config_content)
        log_config = LogConfig(config_content=config_content)
        queue_config = QueueConfig(config_content=config_content)

        ert_workflow_list = ErtWorkflowList(subst_list=subst_config.subst_list,
                                            config_content=config_content)

        hook_manager = HookManager(workflow_list=ert_workflow_list,
                                   config_content=config_content)

        ert_templates = ErtTemplates(parent_subst=subst_config.subst_list,
                                     config_content=config_content)

        ensemble_config = EnsembleConfig(config_content=config_content,
                                         grid=ecl_config.getGrid(),
                                         refcase=ecl_config.getRefcase())

        model_config = ModelConfig(
            data_root=config_dir,
            joblist=site_config.get_installed_jobs(),
            last_history_restart=ecl_config.getLastHistoryRestart(),
            refcase=ecl_config.getRefcase(),
            config_content=config_content)

        return [
            subst_config, site_config, rng_config, analysis_config,
            ert_workflow_list, hook_manager, ert_templates, ecl_config,
            ensemble_config, model_config, log_config, queue_config
        ], config_dir
Exemplo n.º 8
0
    def test_ecl_config_constructor(self):
        config_dict = {
            "DATA_FILE": "configuration_tests/input/SPE1.DATA",
            "ECLBASE": "configuration_tests/input/<ECLIPSE_NAME>-%d",
            "GRID": "configuration_tests/input/CASE.EGRID",
            "REFCASE": "configuration_tests/input/SNAKE_OIL_FIELD",
            "END_DATE": "10/10/2010",
            "SCHEDULE_PREDICTION_FILE":
            "configuration_tests/input/schedule.sch"
        }

        self.case_directory = self.createTestPath("local/configuration_tests/")
        with TestAreaContext("ecl_config_test") as work_area:
            work_area.copy_directory(self.case_directory)
            res_config = ResConfig('configuration_tests/ecl_config.ert')
            ecl_config_file = res_config.ecl_config
            ecl_config_dict = EclConfig(config_dict=config_dict)

            self.assertEqual(ecl_config_dict, ecl_config_file)
Exemplo n.º 9
0
    def test_init_section(self):
        ec = EclConfig()
        dfile = self.createTestPath(DATA_file)
        difile = self.createTestPath(DATA_INIT_file)
        ifile = self.createTestPath(INIT_file)

        ui = ec.validateInitSection(ifile)
        self.assertFalse(ui)

        ec.setDataFile(dfile)
        ui = ec.validateInitSection(ifile)
        self.assertFalse(ui)

        ec.setDataFile(difile)
        ui = ec.validateInitSection(ifile)
        self.assertTrue(ui)
        ec.setInitSection(ifile)
        self.assertTrue(ifile, ec.getInitSection())
Exemplo n.º 10
0
    def __init__(self,
                 user_config_file=None,
                 config=None,
                 throw_on_error=True):

        self._errors, self._failed_keys = None, None
        self._assert_input(user_config_file, config, throw_on_error)

        if config is not None:
            config_content = self._build_config_content(config)
        elif user_config_file is not None:

            parser = ConfigParser()

            config_content = self._alloc_config_content(
                user_config_file, parser)
        else:
            raise ValueError("No config provided")

        if self.errors and throw_on_error:
            raise ValueError("Error loading configuration: " +
                             str(self._errors))

        config_dir = config_content.getValue(ConfigKeys.CONFIG_DIRECTORY)

        subst_config = SubstConfig(config_content=config_content)
        site_config = SiteConfig(config_content=config_content)
        rng_config = RNGConfig(config_content=config_content)
        analysis_config = AnalysisConfig(config_content=config_content)
        ecl_config = EclConfig(config_content=config_content)
        log_config = LogConfig(config_content=config_content)
        queue_config = QueueConfig(config_content=config_content)

        ert_workflow_list = ErtWorkflowList(
            ert_workflow_list=subst_config.subst_list,
            config_content=config_content)

        hook_manager = HookManager(workflow_list=ert_workflow_list,
                                   config_content=config_content)

        ert_templates = ErtTemplates(parent_subst=subst_config.subst_list,
                                     config_content=config_content)

        ensemble_config = EnsembleConfig(config_content=config_content,
                                         grid=ecl_config.getGrid(),
                                         refcase=ecl_config.getRefcase())

        model_config = ModelConfig(
            config_content=config_content,
            data_root=config_dir,
            joblist=site_config.get_installed_jobs(),
            last_history_restart=ecl_config.getLastHistoryRestart(),
            sched_file=ecl_config._get_sched_file(),
            refcase=ecl_config.getRefcase())

        configs = [
            subst_config, site_config, rng_config, analysis_config,
            ert_workflow_list, hook_manager, ert_templates, ecl_config,
            ensemble_config, model_config, log_config, queue_config
        ]

        c_ptr = None

        for conf in configs:
            conf.convertToCReference(None)
        c_ptr = self._alloc_full(config_dir, user_config_file, *configs)

        if c_ptr:
            super(ResConfig, self).__init__(c_ptr)
        else:
            raise ValueError(
                'Failed to construct ResConfig instance from %r.' %
                (user_config_file if user_config_file else config))