Module data_request_api.tests.test_data_request

Test data_request.py

Classes

class TestDRObjects (methodName='runTest')
Expand source code
class TestDRObjects(unittest.TestCase):
    def setUp(self):
        self.dr = DataRequest.from_separated_inputs(VS_input=filepath("one_base_VS_output.json"),
                                                    DR_input=filepath("one_base_DR_output.json"))

    def test_init(self):
        with self.assertRaises(TypeError):
            DRObjects()

        with self.assertRaises(TypeError):
            DRObjects("link::my_id")

        with self.assertRaises(TypeError):
            DRObjects(self.dr)

        obj = DRObjects("link::my_id", self.dr)
        obj = DRObjects(id="link::my_id", dr=self.dr)
        self.assertEqual(obj.DR_type, "undef")

    def test_from_input(self):
        with self.assertRaises(TypeError):
            DRObjects.from_input()

        with self.assertRaises(TypeError):
            DRObjects.from_input("link::my_id")

        with self.assertRaises(TypeError):
            DRObjects.from_input(self.dr)

        obj = DRObjects.from_input(dr=self.dr, id="link::my_id")

        obj = DRObjects.from_input(dr=self.dr, id="link::my_id", DR_type="priority_level")

        obj = DRObjects.from_input(dr=self.dr, id="link::default_481", DR_type="priority_level")

    def test_check(self):
        obj = DRObjects("my_id", self.dr)
        obj.check()

    def test_print(self):
        obj = DRObjects(id="link::my_id", dr=self.dr)
        self.assertEqual(str(obj), "undef: undef (id: my_id)")

    def test_eq(self):
        obj = DRObjects(id="link::my_id", dr=self.dr)
        obj2 = copy.deepcopy(obj)
        self.assertEqual(obj, obj2)

        obj3 = DRObjects(id="link::my_id_2", dr=self.dr)
        self.assertNotEqual(obj, obj3)
        self.assertTrue(obj < obj3)
        self.assertFalse(obj > obj3)

    def test_hash(self):
        obj = DRObjects(id="link::my_id", dr=self.dr)
        my_set = set()
        my_set.add(obj)
        my_set.add(DRObjects(id="link::my_id_2", dr=self.dr))
        my_set.add(copy.deepcopy(obj))
        self.assertEqual(len(my_set), 2)

        my_dict = dict()
        obj2 = self.dr.find_element("cmip7_frequency", "link::default_104")
        obj3 = self.dr.find_element("cmip7_frequency", "link::default_105")
        self.assertTrue(isinstance(obj2, DRObjects))
        self.assertTrue(isinstance(obj2.name, ConstantValueObj))
        self.assertTrue(isinstance(obj3.name, ConstantValueObj))
        my_dict[obj2.id] = obj2
        my_dict[obj2.name] = obj2
        my_dict[obj3.id] = obj3
        my_dict[obj3.name] = obj3

    def test_get(self):
        obj1 = DRObjects(id="my_id", dr=self.dr)
        self.assertEqual(obj1.get("id"), "my_id")
        self.assertEqual(obj1.get("DR_type"), "undef")
        self.assertEqual(obj1.get("test"), "undef")

    def test_filter_on_request(self):
        obj1 = DRObjects(id="my_id", DR_type="test", dr=self.dr)
        obj2 = copy.deepcopy(obj1)
        obj3 = DRObjects(id="my_other_id", DR_type="test", dr=self.dr)
        obj4 = DRObjects(id="my_id", DR_type="test2", dr=self.dr)
        self.assertEqual(obj1.filter_on_request(obj2), (True, True))
        self.assertEqual(obj1.filter_on_request(obj3), (True, False))
        self.assertEqual(obj1.filter_on_request(obj4), (False, False))

A class whose instances are single test cases.

By default, the test code itself should be placed in a method named 'runTest'.

If the fixture may be used for many test cases, create as many test methods as are needed. When instantiating such a TestCase subclass, specify in the constructor arguments the name of the test method that the instance is to execute.

Test authors should subclass TestCase for their own tests. Construction and deconstruction of the test's environment ('fixture') can be implemented by overriding the 'setUp' and 'tearDown' methods respectively.

If it is necessary to override the init method, the base class init method must always be called. It is important that subclasses should not change the signature of their init method, since instances of the classes are instantiated automatically by parts of the framework in order to be run.

When subclassing TestCase, you can set these attributes: * failureException: determines which exception will be raised when the instance's assertion methods fail; test methods raising this exception will be deemed to have 'failed' rather than 'errored'. * longMessage: determines whether long messages (including repr of objects used in assert methods) will be printed on failure in addition to any explicit message passed. * maxDiff: sets the maximum length of a diff in failure messages by assert methods using difflib. It is looked up as an instance attribute so can be configured by individual tests if required.

Create an instance of the class that will use the named test method when executed. Raises a ValueError if the instance does not have a method with the specified name.

Ancestors

  • unittest.case.TestCase

Methods

def setUp(self)
Expand source code
def setUp(self):
    self.dr = DataRequest.from_separated_inputs(VS_input=filepath("one_base_VS_output.json"),
                                                DR_input=filepath("one_base_DR_output.json"))

Hook method for setting up the test fixture before exercising it.

def test_check(self)
Expand source code
def test_check(self):
    obj = DRObjects("my_id", self.dr)
    obj.check()
def test_eq(self)
Expand source code
def test_eq(self):
    obj = DRObjects(id="link::my_id", dr=self.dr)
    obj2 = copy.deepcopy(obj)
    self.assertEqual(obj, obj2)

    obj3 = DRObjects(id="link::my_id_2", dr=self.dr)
    self.assertNotEqual(obj, obj3)
    self.assertTrue(obj < obj3)
    self.assertFalse(obj > obj3)
def test_filter_on_request(self)
Expand source code
def test_filter_on_request(self):
    obj1 = DRObjects(id="my_id", DR_type="test", dr=self.dr)
    obj2 = copy.deepcopy(obj1)
    obj3 = DRObjects(id="my_other_id", DR_type="test", dr=self.dr)
    obj4 = DRObjects(id="my_id", DR_type="test2", dr=self.dr)
    self.assertEqual(obj1.filter_on_request(obj2), (True, True))
    self.assertEqual(obj1.filter_on_request(obj3), (True, False))
    self.assertEqual(obj1.filter_on_request(obj4), (False, False))
def test_from_input(self)
Expand source code
def test_from_input(self):
    with self.assertRaises(TypeError):
        DRObjects.from_input()

    with self.assertRaises(TypeError):
        DRObjects.from_input("link::my_id")

    with self.assertRaises(TypeError):
        DRObjects.from_input(self.dr)

    obj = DRObjects.from_input(dr=self.dr, id="link::my_id")

    obj = DRObjects.from_input(dr=self.dr, id="link::my_id", DR_type="priority_level")

    obj = DRObjects.from_input(dr=self.dr, id="link::default_481", DR_type="priority_level")
def test_get(self)
Expand source code
def test_get(self):
    obj1 = DRObjects(id="my_id", dr=self.dr)
    self.assertEqual(obj1.get("id"), "my_id")
    self.assertEqual(obj1.get("DR_type"), "undef")
    self.assertEqual(obj1.get("test"), "undef")
def test_hash(self)
Expand source code
def test_hash(self):
    obj = DRObjects(id="link::my_id", dr=self.dr)
    my_set = set()
    my_set.add(obj)
    my_set.add(DRObjects(id="link::my_id_2", dr=self.dr))
    my_set.add(copy.deepcopy(obj))
    self.assertEqual(len(my_set), 2)

    my_dict = dict()
    obj2 = self.dr.find_element("cmip7_frequency", "link::default_104")
    obj3 = self.dr.find_element("cmip7_frequency", "link::default_105")
    self.assertTrue(isinstance(obj2, DRObjects))
    self.assertTrue(isinstance(obj2.name, ConstantValueObj))
    self.assertTrue(isinstance(obj3.name, ConstantValueObj))
    my_dict[obj2.id] = obj2
    my_dict[obj2.name] = obj2
    my_dict[obj3.id] = obj3
    my_dict[obj3.name] = obj3
def test_init(self)
Expand source code
def test_init(self):
    with self.assertRaises(TypeError):
        DRObjects()

    with self.assertRaises(TypeError):
        DRObjects("link::my_id")

    with self.assertRaises(TypeError):
        DRObjects(self.dr)

    obj = DRObjects("link::my_id", self.dr)
    obj = DRObjects(id="link::my_id", dr=self.dr)
    self.assertEqual(obj.DR_type, "undef")
def test_print(self)
Expand source code
def test_print(self):
    obj = DRObjects(id="link::my_id", dr=self.dr)
    self.assertEqual(str(obj), "undef: undef (id: my_id)")
class TestDataRequest (methodName='runTest')
Expand source code
class TestDataRequest(unittest.TestCase):
    def setUp(self):
        self.vs_file = filepath("one_base_VS_output.json")
        self.vs_dict = read_json_input_file_content(self.vs_file)
        self.vs = VocabularyServer.from_input(self.vs_file)
        self.input_database_file = filepath("one_base_DR_output.json")
        self.input_database = read_json_input_file_content(self.input_database_file)
        self.complete_input_file = filepath("one_base_input.json")
        self.complete_input = read_json_input_file_content(self.complete_input_file)
        self.DR_dump = filepath("one_base_DR_dump.txt")

    def test_init(self):
        with self.assertRaises(TypeError):
            DataRequest()

        with self.assertRaises(TypeError):
            DataRequest(self.vs)

        with self.assertRaises(TypeError):
            DataRequest(self.input_database)

        obj = DataRequest(input_database=self.input_database, VS=self.vs)
        self.assertEqual(len(obj.get_experiment_groups()), 5)
        self.assertEqual(len(obj.get_variable_groups()), 11)
        self.assertEqual(len(obj.get_opportunities()), 4)

    def test_from_input(self):
        with self.assertRaises(TypeError):
            DataRequest.from_input()

        with self.assertRaises(TypeError):
            DataRequest.from_input(self.complete_input)

        with self.assertRaises(TypeError):
            DataRequest.from_input("test")

        with self.assertRaises(TypeError):
            DataRequest.from_input(self.input_database, version=self.vs)

        with self.assertRaises(TypeError):
            DataRequest.from_input(self.complete_input_file + "tmp", version="test")

        obj = DataRequest.from_input(json_input=self.complete_input, version="test")
        self.assertEqual(len(obj.get_experiment_groups()), 5)
        self.assertEqual(len(obj.get_variable_groups()), 11)
        self.assertEqual(len(obj.get_opportunities()), 4)

        obj = DataRequest.from_input(json_input=self.complete_input_file, version="test")
        self.assertEqual(len(obj.get_experiment_groups()), 5)
        self.assertEqual(len(obj.get_variable_groups()), 11)
        self.assertEqual(len(obj.get_opportunities()), 4)

    def test_from_separated_inputs(self):
        with self.assertRaises(TypeError):
            DataRequest.from_separated_inputs()

        with self.assertRaises(TypeError):
            DataRequest.from_separated_inputs(self.input_database)

        with self.assertRaises(TypeError):
            DataRequest.from_separated_inputs(self.vs)

        with self.assertRaises(TypeError):
            DataRequest.from_separated_inputs(DR_input=self.input_database, VS_input=self.vs_file + "tmp")

        with self.assertRaises(TypeError):
            DataRequest.from_separated_inputs(DR_input=self.input_database_file + "tmp", VS_input=self.vs_dict)

        with self.assertRaises(TypeError):
            DataRequest.from_separated_inputs(DR_input=self.input_database_file, VS_input=self.vs)

        obj = DataRequest.from_separated_inputs(DR_input=self.input_database, VS_input=self.vs_dict)
        self.assertEqual(len(obj.get_experiment_groups()), 5)
        self.assertEqual(len(obj.get_variable_groups()), 11)
        self.assertEqual(len(obj.get_opportunities()), 4)

        obj = DataRequest.from_separated_inputs(DR_input=self.input_database_file, VS_input=self.vs_dict)
        self.assertEqual(len(obj.get_experiment_groups()), 5)
        self.assertEqual(len(obj.get_variable_groups()), 11)
        self.assertEqual(len(obj.get_opportunities()), 4)

        obj = DataRequest.from_separated_inputs(DR_input=self.input_database, VS_input=self.vs_file)
        self.assertEqual(len(obj.get_experiment_groups()), 5)
        self.assertEqual(len(obj.get_variable_groups()), 11)
        self.assertEqual(len(obj.get_opportunities()), 4)

        obj = DataRequest.from_separated_inputs(DR_input=self.input_database_file, VS_input=self.vs_file)
        self.assertEqual(len(obj.get_experiment_groups()), 5)
        self.assertEqual(len(obj.get_variable_groups()), 11)
        self.assertEqual(len(obj.get_opportunities()), 4)

    def test_split_content_from_input_json(self):
        with self.assertRaises(TypeError):
            DataRequest._split_content_from_input_json()

        with self.assertRaises(TypeError):
            DataRequest._split_content_from_input_json(self.complete_input)

        with self.assertRaises(TypeError):
            DataRequest._split_content_from_input_json("test")

        with self.assertRaises(TypeError):
            DataRequest._split_content_from_input_json(self.input_database, version=self.vs)

        with self.assertRaises(TypeError):
            DataRequest._split_content_from_input_json(self.complete_input_file + "tmp", version="test")

        DR, VS = DataRequest._split_content_from_input_json(input_json=self.complete_input, version="test")
        self.assertDictEqual(DR, self.input_database)
        self.assertDictEqual(VS, self.vs_dict)

        DR, VS = DataRequest._split_content_from_input_json(input_json=self.complete_input_file, version="test")
        self.assertDictEqual(DR, self.input_database)
        self.assertDictEqual(VS, self.vs_dict)

    def test_check(self):
        obj = DataRequest(input_database=self.input_database, VS=self.vs)
        obj.check()

    def test_version(self):
        obj = DataRequest(input_database=self.input_database, VS=self.vs)
        self.assertEqual(obj.software_version, version)
        self.assertEqual(obj.content_version, self.input_database["version"])
        self.assertEqual(obj.version, f"Software {version} - Content {self.input_database['version']}")

    def test_str(self):
        obj = DataRequest(input_database=self.input_database, VS=self.vs)
        with open(self.DR_dump, encoding="utf-8", newline="\n") as f:
            ref_str = f.read()
        self.assertEqual(str(obj), ref_str)

    def test_get_experiment_groups(self):
        obj = DataRequest(input_database=self.input_database, VS=self.vs)
        exp_groups = obj.get_experiment_groups()
        self.assertEqual(len(exp_groups), 5)
        self.assertListEqual(exp_groups,
                             [obj.find_element("experiment_groups", id)
                              for id in ["link::default_285", "link::default_286", "link::default_287",
                                         "link::default_288", "link::default_289"]])

    def test_get_experiment_group(self):
        obj = DataRequest(input_database=self.input_database, VS=self.vs)
        exp_grp = obj.get_experiment_group("link::default_285")
        self.assertEqual(exp_grp,
                         obj.find_element("experiment_groups", "link::default_285"))
        with self.assertRaises(ValueError):
            exp_grp = obj.get_experiment_group("test")

    def test_get_opportunities(self):
        obj = DataRequest(input_database=self.input_database, VS=self.vs)
        opportunities = obj.get_opportunities()
        self.assertEqual(len(opportunities), 4)
        self.assertListEqual(opportunities, [obj.find_element("opportunities", id)
                                             for id in ["link::default_418", "link::default_419", "link::default_420",
                                                        "link::default_421"]])

    def test_get_opportunity(self):
        obj = DataRequest(input_database=self.input_database, VS=self.vs)
        opportunity = obj.get_opportunity("link::default_418")
        self.assertEqual(opportunity,
                         obj.find_element("opportunities", "link::default_418"))
        with self.assertRaises(ValueError):
            op = obj.get_opportunity("test")

    def test_get_variable_groups(self):
        obj = DataRequest(input_database=self.input_database, VS=self.vs)
        var_groups = obj.get_variable_groups()
        self.assertEqual(len(var_groups), 11)
        self.assertListEqual(var_groups,
                             [obj.find_element("variable_groups", id)
                              for id in ["link::default_569", "link::default_570", "link::default_571",
                                         "link::default_572", "link::default_573", "link::default_574",
                                         "link::default_575", "link::default_576", "link::default_577",
                                         "link::default_578", "link::default_579"]])

    def test_get_variable_group(self):
        obj = DataRequest(input_database=self.input_database, VS=self.vs)
        var_grp = obj.get_variable_group("link::default_575")
        self.assertEqual(var_grp,
                         obj.find_element("variable_groups", "link::default_575"))
        with self.assertRaises(ValueError):
            var_grp = obj.get_variable_group("test")

    def test_get_variables(self):
        obj = DataRequest(input_database=self.input_database, VS=self.vs)
        variables = obj.get_variables()
        self.assertListEqual(variables,
                             [obj.find_element("variables", f"link::{nb}")
                              for nb in sorted(list(self.vs.vocabulary_server["variables"]))])

    def test_get_mips(self):
        obj = DataRequest(input_database=self.input_database, VS=self.vs)
        mips = obj.get_mips()
        self.assertListEqual(mips,
                             [obj.find_element("mips", f"link::{nb}")
                              for nb in sorted(list(self.vs.vocabulary_server["mips"]))])

    def test_get_experiments(self):
        obj = DataRequest(input_database=self.input_database, VS=self.vs)
        experiments = obj.get_experiments()
        self.assertListEqual(experiments,
                             [obj.find_element("experiments", f"link::{nb}")
                              for nb in sorted(list(self.vs.vocabulary_server["experiments"]))])

    def test_get_themes(self):
        obj = DataRequest(input_database=self.input_database, VS=self.vs)
        themes = obj.get_data_request_themes()
        self.assertListEqual(themes,
                             [obj.find_element("data_request_themes", f"link::{nb}")
                              for nb in sorted(list(self.vs.vocabulary_server["data_request_themes"]))])

    def test_get_filtering_structure(self):
        obj = DataRequest(input_database=self.input_database, VS=self.vs)
        self.assertSetEqual(obj.get_filtering_structure("variable_groups"), {"opportunities", })
        self.assertSetEqual(obj.get_filtering_structure("variables"), {"opportunities", "variable_groups"})
        self.assertSetEqual(obj.get_filtering_structure("physical_parameters"), {"opportunities", "variable_groups", "variables"})
        self.assertSetEqual(obj.get_filtering_structure("experiment_groups"), {"opportunities", })
        self.assertSetEqual(obj.get_filtering_structure("experiments"), {"opportunities", "experiment_groups"})
        self.assertSetEqual(obj.get_filtering_structure("test"), set())
        self.assertSetEqual(obj.get_filtering_structure("opportunities"), set())

A class whose instances are single test cases.

By default, the test code itself should be placed in a method named 'runTest'.

If the fixture may be used for many test cases, create as many test methods as are needed. When instantiating such a TestCase subclass, specify in the constructor arguments the name of the test method that the instance is to execute.

Test authors should subclass TestCase for their own tests. Construction and deconstruction of the test's environment ('fixture') can be implemented by overriding the 'setUp' and 'tearDown' methods respectively.

If it is necessary to override the init method, the base class init method must always be called. It is important that subclasses should not change the signature of their init method, since instances of the classes are instantiated automatically by parts of the framework in order to be run.

When subclassing TestCase, you can set these attributes: * failureException: determines which exception will be raised when the instance's assertion methods fail; test methods raising this exception will be deemed to have 'failed' rather than 'errored'. * longMessage: determines whether long messages (including repr of objects used in assert methods) will be printed on failure in addition to any explicit message passed. * maxDiff: sets the maximum length of a diff in failure messages by assert methods using difflib. It is looked up as an instance attribute so can be configured by individual tests if required.

Create an instance of the class that will use the named test method when executed. Raises a ValueError if the instance does not have a method with the specified name.

Ancestors

  • unittest.case.TestCase

Methods

def setUp(self)
Expand source code
def setUp(self):
    self.vs_file = filepath("one_base_VS_output.json")
    self.vs_dict = read_json_input_file_content(self.vs_file)
    self.vs = VocabularyServer.from_input(self.vs_file)
    self.input_database_file = filepath("one_base_DR_output.json")
    self.input_database = read_json_input_file_content(self.input_database_file)
    self.complete_input_file = filepath("one_base_input.json")
    self.complete_input = read_json_input_file_content(self.complete_input_file)
    self.DR_dump = filepath("one_base_DR_dump.txt")

Hook method for setting up the test fixture before exercising it.

def test_check(self)
Expand source code
def test_check(self):
    obj = DataRequest(input_database=self.input_database, VS=self.vs)
    obj.check()
def test_from_input(self)
Expand source code
def test_from_input(self):
    with self.assertRaises(TypeError):
        DataRequest.from_input()

    with self.assertRaises(TypeError):
        DataRequest.from_input(self.complete_input)

    with self.assertRaises(TypeError):
        DataRequest.from_input("test")

    with self.assertRaises(TypeError):
        DataRequest.from_input(self.input_database, version=self.vs)

    with self.assertRaises(TypeError):
        DataRequest.from_input(self.complete_input_file + "tmp", version="test")

    obj = DataRequest.from_input(json_input=self.complete_input, version="test")
    self.assertEqual(len(obj.get_experiment_groups()), 5)
    self.assertEqual(len(obj.get_variable_groups()), 11)
    self.assertEqual(len(obj.get_opportunities()), 4)

    obj = DataRequest.from_input(json_input=self.complete_input_file, version="test")
    self.assertEqual(len(obj.get_experiment_groups()), 5)
    self.assertEqual(len(obj.get_variable_groups()), 11)
    self.assertEqual(len(obj.get_opportunities()), 4)
def test_from_separated_inputs(self)
Expand source code
def test_from_separated_inputs(self):
    with self.assertRaises(TypeError):
        DataRequest.from_separated_inputs()

    with self.assertRaises(TypeError):
        DataRequest.from_separated_inputs(self.input_database)

    with self.assertRaises(TypeError):
        DataRequest.from_separated_inputs(self.vs)

    with self.assertRaises(TypeError):
        DataRequest.from_separated_inputs(DR_input=self.input_database, VS_input=self.vs_file + "tmp")

    with self.assertRaises(TypeError):
        DataRequest.from_separated_inputs(DR_input=self.input_database_file + "tmp", VS_input=self.vs_dict)

    with self.assertRaises(TypeError):
        DataRequest.from_separated_inputs(DR_input=self.input_database_file, VS_input=self.vs)

    obj = DataRequest.from_separated_inputs(DR_input=self.input_database, VS_input=self.vs_dict)
    self.assertEqual(len(obj.get_experiment_groups()), 5)
    self.assertEqual(len(obj.get_variable_groups()), 11)
    self.assertEqual(len(obj.get_opportunities()), 4)

    obj = DataRequest.from_separated_inputs(DR_input=self.input_database_file, VS_input=self.vs_dict)
    self.assertEqual(len(obj.get_experiment_groups()), 5)
    self.assertEqual(len(obj.get_variable_groups()), 11)
    self.assertEqual(len(obj.get_opportunities()), 4)

    obj = DataRequest.from_separated_inputs(DR_input=self.input_database, VS_input=self.vs_file)
    self.assertEqual(len(obj.get_experiment_groups()), 5)
    self.assertEqual(len(obj.get_variable_groups()), 11)
    self.assertEqual(len(obj.get_opportunities()), 4)

    obj = DataRequest.from_separated_inputs(DR_input=self.input_database_file, VS_input=self.vs_file)
    self.assertEqual(len(obj.get_experiment_groups()), 5)
    self.assertEqual(len(obj.get_variable_groups()), 11)
    self.assertEqual(len(obj.get_opportunities()), 4)
def test_get_experiment_group(self)
Expand source code
def test_get_experiment_group(self):
    obj = DataRequest(input_database=self.input_database, VS=self.vs)
    exp_grp = obj.get_experiment_group("link::default_285")
    self.assertEqual(exp_grp,
                     obj.find_element("experiment_groups", "link::default_285"))
    with self.assertRaises(ValueError):
        exp_grp = obj.get_experiment_group("test")
def test_get_experiment_groups(self)
Expand source code
def test_get_experiment_groups(self):
    obj = DataRequest(input_database=self.input_database, VS=self.vs)
    exp_groups = obj.get_experiment_groups()
    self.assertEqual(len(exp_groups), 5)
    self.assertListEqual(exp_groups,
                         [obj.find_element("experiment_groups", id)
                          for id in ["link::default_285", "link::default_286", "link::default_287",
                                     "link::default_288", "link::default_289"]])
def test_get_experiments(self)
Expand source code
def test_get_experiments(self):
    obj = DataRequest(input_database=self.input_database, VS=self.vs)
    experiments = obj.get_experiments()
    self.assertListEqual(experiments,
                         [obj.find_element("experiments", f"link::{nb}")
                          for nb in sorted(list(self.vs.vocabulary_server["experiments"]))])
def test_get_filtering_structure(self)
Expand source code
def test_get_filtering_structure(self):
    obj = DataRequest(input_database=self.input_database, VS=self.vs)
    self.assertSetEqual(obj.get_filtering_structure("variable_groups"), {"opportunities", })
    self.assertSetEqual(obj.get_filtering_structure("variables"), {"opportunities", "variable_groups"})
    self.assertSetEqual(obj.get_filtering_structure("physical_parameters"), {"opportunities", "variable_groups", "variables"})
    self.assertSetEqual(obj.get_filtering_structure("experiment_groups"), {"opportunities", })
    self.assertSetEqual(obj.get_filtering_structure("experiments"), {"opportunities", "experiment_groups"})
    self.assertSetEqual(obj.get_filtering_structure("test"), set())
    self.assertSetEqual(obj.get_filtering_structure("opportunities"), set())
def test_get_mips(self)
Expand source code
def test_get_mips(self):
    obj = DataRequest(input_database=self.input_database, VS=self.vs)
    mips = obj.get_mips()
    self.assertListEqual(mips,
                         [obj.find_element("mips", f"link::{nb}")
                          for nb in sorted(list(self.vs.vocabulary_server["mips"]))])
def test_get_opportunities(self)
Expand source code
def test_get_opportunities(self):
    obj = DataRequest(input_database=self.input_database, VS=self.vs)
    opportunities = obj.get_opportunities()
    self.assertEqual(len(opportunities), 4)
    self.assertListEqual(opportunities, [obj.find_element("opportunities", id)
                                         for id in ["link::default_418", "link::default_419", "link::default_420",
                                                    "link::default_421"]])
def test_get_opportunity(self)
Expand source code
def test_get_opportunity(self):
    obj = DataRequest(input_database=self.input_database, VS=self.vs)
    opportunity = obj.get_opportunity("link::default_418")
    self.assertEqual(opportunity,
                     obj.find_element("opportunities", "link::default_418"))
    with self.assertRaises(ValueError):
        op = obj.get_opportunity("test")
def test_get_themes(self)
Expand source code
def test_get_themes(self):
    obj = DataRequest(input_database=self.input_database, VS=self.vs)
    themes = obj.get_data_request_themes()
    self.assertListEqual(themes,
                         [obj.find_element("data_request_themes", f"link::{nb}")
                          for nb in sorted(list(self.vs.vocabulary_server["data_request_themes"]))])
def test_get_variable_group(self)
Expand source code
def test_get_variable_group(self):
    obj = DataRequest(input_database=self.input_database, VS=self.vs)
    var_grp = obj.get_variable_group("link::default_575")
    self.assertEqual(var_grp,
                     obj.find_element("variable_groups", "link::default_575"))
    with self.assertRaises(ValueError):
        var_grp = obj.get_variable_group("test")
def test_get_variable_groups(self)
Expand source code
def test_get_variable_groups(self):
    obj = DataRequest(input_database=self.input_database, VS=self.vs)
    var_groups = obj.get_variable_groups()
    self.assertEqual(len(var_groups), 11)
    self.assertListEqual(var_groups,
                         [obj.find_element("variable_groups", id)
                          for id in ["link::default_569", "link::default_570", "link::default_571",
                                     "link::default_572", "link::default_573", "link::default_574",
                                     "link::default_575", "link::default_576", "link::default_577",
                                     "link::default_578", "link::default_579"]])
def test_get_variables(self)
Expand source code
def test_get_variables(self):
    obj = DataRequest(input_database=self.input_database, VS=self.vs)
    variables = obj.get_variables()
    self.assertListEqual(variables,
                         [obj.find_element("variables", f"link::{nb}")
                          for nb in sorted(list(self.vs.vocabulary_server["variables"]))])
def test_init(self)
Expand source code
def test_init(self):
    with self.assertRaises(TypeError):
        DataRequest()

    with self.assertRaises(TypeError):
        DataRequest(self.vs)

    with self.assertRaises(TypeError):
        DataRequest(self.input_database)

    obj = DataRequest(input_database=self.input_database, VS=self.vs)
    self.assertEqual(len(obj.get_experiment_groups()), 5)
    self.assertEqual(len(obj.get_variable_groups()), 11)
    self.assertEqual(len(obj.get_opportunities()), 4)
def test_split_content_from_input_json(self)
Expand source code
def test_split_content_from_input_json(self):
    with self.assertRaises(TypeError):
        DataRequest._split_content_from_input_json()

    with self.assertRaises(TypeError):
        DataRequest._split_content_from_input_json(self.complete_input)

    with self.assertRaises(TypeError):
        DataRequest._split_content_from_input_json("test")

    with self.assertRaises(TypeError):
        DataRequest._split_content_from_input_json(self.input_database, version=self.vs)

    with self.assertRaises(TypeError):
        DataRequest._split_content_from_input_json(self.complete_input_file + "tmp", version="test")

    DR, VS = DataRequest._split_content_from_input_json(input_json=self.complete_input, version="test")
    self.assertDictEqual(DR, self.input_database)
    self.assertDictEqual(VS, self.vs_dict)

    DR, VS = DataRequest._split_content_from_input_json(input_json=self.complete_input_file, version="test")
    self.assertDictEqual(DR, self.input_database)
    self.assertDictEqual(VS, self.vs_dict)
def test_str(self)
Expand source code
def test_str(self):
    obj = DataRequest(input_database=self.input_database, VS=self.vs)
    with open(self.DR_dump, encoding="utf-8", newline="\n") as f:
        ref_str = f.read()
    self.assertEqual(str(obj), ref_str)
def test_version(self)
Expand source code
def test_version(self):
    obj = DataRequest(input_database=self.input_database, VS=self.vs)
    self.assertEqual(obj.software_version, version)
    self.assertEqual(obj.content_version, self.input_database["version"])
    self.assertEqual(obj.version, f"Software {version} - Content {self.input_database['version']}")
class TestDataRequestFilter (methodName='runTest')
Expand source code
class TestDataRequestFilter(unittest.TestCase):
    def setUp(self):
        self.vs_file = filepath("one_base_VS_output.json")
        self.vs = VocabularyServer.from_input(self.vs_file)
        self.input_database_file = filepath("one_base_DR_output.json")
        self.input_database = read_json_input_file_content(self.input_database_file)
        self.dr = DataRequest(input_database=self.input_database, VS=self.vs)
        self.exp_export = filepath("experiments_export.txt")
        self.exp_expgrp_summmary = filepath("exp_expgrp_summary.txt")

    def test_element_per_identifier_from_vs(self):
        id_var = "link::1aab80fc-b006-11e6-9289-ac72891c3257"
        name_var = "Omon.wo"
        target_var = self.dr.find_element("variables", id_var)
        self.assertEqual(self.dr.find_element_per_identifier_from_vs(element_type="variables", key="id", value=id_var),
                         target_var)
        self.assertEqual(self.dr.find_element_per_identifier_from_vs(element_type="variables", key="name",
                                                                     value=name_var),
                         target_var)
        with self.assertRaises(ValueError):
            self.dr.find_element_per_identifier_from_vs(element_type="variables", key="name", value="toto")
        with self.assertRaises(ValueError):
            self.dr.find_element_per_identifier_from_vs(element_type="variables", key="id", value="link::toto")
        self.assertEqual(self.dr.find_element_per_identifier_from_vs(element_type="variables", key="id",
                                                                     value="link::toto", default=None),
                         None)
        self.assertEqual(self.dr.find_element_per_identifier_from_vs(element_type="variables", key="name",
                                                                     value="toto", default=None),
                         None)
        with self.assertRaises(ValueError):
            self.dr.find_element_per_identifier_from_vs(element_type="opportunity/variable_group_comments", key="name",
                                                        value="undef")

        self.assertEqual(self.dr.find_element_per_identifier_from_vs(element_type="variable", value=None, key="id", default=None),
                         None)

    def test_element_from_vs(self):
        id_var = "link::1aab80fc-b006-11e6-9289-ac72891c3257"
        name_var = "Omon.wo"
        target_var = self.dr.find_element("variables", id_var)
        self.assertEqual(self.dr.find_element_from_vs(element_type="variables", value=id_var), target_var)
        self.assertEqual(self.dr.find_element_from_vs(element_type="variables", value=name_var), target_var)
        with self.assertRaises(ValueError):
            self.dr.find_element_from_vs(element_type="variables", value="toto")
        with self.assertRaises(ValueError):
            self.dr.find_element_from_vs(element_type="variables", value="link::toto")
        self.assertEqual(self.dr.find_element_from_vs(element_type="variables", value="link::toto", default=None), None)
        self.assertEqual(self.dr.find_element_from_vs(element_type="variables", value="toto", default=None), None)
        with self.assertRaises(ValueError):
            self.dr.find_element_from_vs(element_type="opportunity/variable_group_comments", value="undef")
        self.assertEqual(self.dr.find_element_from_vs(element_type="variables", value=id_var, key="id"), target_var)

    def test_filter_elements_per_request(self):
        with self.assertRaises(TypeError):
            self.dr.filter_elements_per_request()

        self.assertEqual(self.dr.filter_elements_per_request("opportunities"), self.dr.get_opportunities())
        self.assertEqual(self.dr.filter_elements_per_request("opportunities", request_operation="any"),
                         self.dr.get_opportunities())
        with self.assertRaises(ValueError):
            self.dr.filter_elements_per_request("opportunities", request_operation="one")

        with self.assertRaises(ValueError):
            self.dr.filter_elements_per_request("opportunities", requests=dict(variables="link::test_dummy"))
        self.assertListEqual(self.dr.filter_elements_per_request("opportunities", skip_if_missing=True,
                                                                 requests=dict(variables="link::test_dummy")),
                             self.dr.get_opportunities())

        self.assertListEqual(self.dr.filter_elements_per_request("experiment_groups",
                                                                 requests=dict(variable="1aab80fc-b006-11e6-9289-ac72891c3257")),
                             [self.dr.find_element("experiment_group", id) for id in ["default_285", "default_287",
                                                                                      "default_288", "default_289"]])
        list_var_grp = [self.dr.find_element("variable_groups", id)
                        for id in ["default_569", "default_570", "default_571", "default_572", "default_573",
                                   "default_574", "default_575", "default_576", "default_579"]]
        self.assertListEqual(self.dr.filter_elements_per_request("variable_groups",
                                                                 requests=dict(experiment="default_290")),
                             list_var_grp)
        found_vargrp_all = self.dr.filter_elements_per_request("variable_groups",
                                                               requests=dict(experiment="default_290"),
                                                               not_requests=dict(
                                                                   opportunity="default_421",
                                                                   variable=["babb20b4-e5dd-11e5-8482-ac72891c3257", "d243ba76-4a9f-11e6-b84e-ac72891c3257"]),
                                                               not_request_operation="all")
        self.assertEqual(len(found_vargrp_all), len(list_var_grp))
        self.assertListEqual(found_vargrp_all, list_var_grp)
        found_vargrp_any = self.dr.filter_elements_per_request("variable_groups",
                                                               requests=dict(experiment="default_290"),
                                                               not_requests=dict(
                                                                   opportunity="default_421",
                                                                   variable=["babb20b4-e5dd-11e5-8482-ac72891c3257", "d243ba76-4a9f-11e6-b84e-ac72891c3257"]),
                                                               not_request_operation="any")
        list_vargrp_any = [self.dr.find_element("variable_group", elt) for elt in ["default_570", "default_571", "default_572"]]
        self.assertEqual(len(found_vargrp_any), len(list_vargrp_any))
        self.assertListEqual(found_vargrp_any, list_vargrp_any)
        found_vargrp_anyofall = self.dr.filter_elements_per_request("variable_groups",
                                                                    requests=dict(experiment="default_290"),
                                                                    not_requests=dict(
                                                                        opportunity="default_421",
                                                                        variable=["babb20b4-e5dd-11e5-8482-ac72891c3257", "d243ba76-4a9f-11e6-b84e-ac72891c3257"]),
                                                                    not_request_operation="any_of_all")
        list_vargrp_anyofall = [self.dr.find_element("variable_group", elt) for elt in ["default_569", "default_570", "default_571", "default_572"]]
        self.assertEqual(len(found_vargrp_anyofall), len(list_vargrp_anyofall))
        self.assertListEqual(found_vargrp_anyofall, list_vargrp_anyofall)
        found_vargrp_allofany = self.dr.filter_elements_per_request("variable_groups",
                                                                    requests=dict(experiment="default_290"),
                                                                    not_requests=dict(
                                                                        opportunity="default_421",
                                                                        variable=["babb20b4-e5dd-11e5-8482-ac72891c3257","d243ba76-4a9f-11e6-b84e-ac72891c3257"]),
                                                                    not_request_operation="all_of_any")
        self.assertEqual(len(found_vargrp_allofany), len(list_var_grp))
        self.assertListEqual(found_vargrp_allofany, list_var_grp)
        self.assertListEqual(self.dr.filter_elements_per_request("variable_groups",
                                                                 requests=dict(experiment="default_290"),
                                                                 not_requests=dict(opportunity="default_421")),
                             [self.dr.find_element("variable_group", elt)
                              for elt in ["default_569", "default_570", "default_571", "default_572", "default_579"]])
        self.assertListEqual(self.dr.filter_elements_per_request(self.dr.get_variable_groups(),
                                                                 requests=dict(experiment="default_290")),
                             list_var_grp)
        self.assertListEqual(self.dr.filter_elements_per_request(self.dr.get_variable_group("default_569"),
                                                                 requests=dict(experiment="default_290")),
                             [self.dr.find_element("variable_group", "default_569"), ])

    def test_find_variables_per_priority(self):
        priority = "Medium"
        priority_obj = self.dr.find_element("priority_level", "link::default_482")
        target_var_list = [self.dr.find_element("variables", id)
                           for id in ["link::83bbfb6e-7f07-11ef-9308-b1dd71e64bec",
                                      "link::83bbfb71-7f07-11ef-9308-b1dd71e64bec",
                                      "link::83bbfb7c-7f07-11ef-9308-b1dd71e64bec",
                                      "link::83bbfb7f-7f07-11ef-9308-b1dd71e64bec",
                                      "link::83bbfb94-7f07-11ef-9308-b1dd71e64bec",
                                      "link::83bbfc6e-7f07-11ef-9308-b1dd71e64bec",
                                      "link::83bbfc6f-7f07-11ef-9308-b1dd71e64bec",
                                      "link::ba9f3ac0-e5dd-11e5-8482-ac72891c3257",
                                      "link::ba9f643c-e5dd-11e5-8482-ac72891c3257",
                                      "link::ba9f686a-e5dd-11e5-8482-ac72891c3257",
                                      "link::ba9f91f0-e5dd-11e5-8482-ac72891c3257",
                                      "link::baa4e07e-e5dd-11e5-8482-ac72891c3257",
                                      "link::baa720e6-e5dd-11e5-8482-ac72891c3257",
                                      "link::baa72514-e5dd-11e5-8482-ac72891c3257",
                                      "link::c9180bae-c5e8-11e6-84e6-5404a60d96b5",
                                      "link::c9181982-c5e8-11e6-84e6-5404a60d96b5"
                                      ]]
        var_list = self.dr.find_variables_per_priority(priority=priority)
        self.assertEqual(len(var_list), 16)
        self.assertListEqual(var_list, target_var_list)
        var_list = self.dr.find_variables_per_priority(priority=priority_obj)
        self.assertEqual(len(var_list), 16)
        self.assertListEqual(var_list, target_var_list)

    def test_find_opportunities_per_theme(self):
        theme_id = "link::default_115"
        theme_name = "Atmosphere"
        theme_target = self.dr.find_element("data_request_themes", theme_id)
        opportunities = [self.dr.get_opportunity(id) for id in ["link::default_418", ]]
        self.assertListEqual(self.dr.find_opportunities_per_theme(theme_id), opportunities)
        self.assertListEqual(self.dr.find_opportunities_per_theme(theme_name), opportunities)
        self.assertListEqual(self.dr.find_opportunities_per_theme(theme_target), opportunities)
        with self.assertRaises(ValueError):
            self.dr.find_opportunities_per_theme("toto")
        with self.assertRaises(ValueError):
            self.dr.find_opportunities_per_theme("link::toto")

    def test_find_experiments_per_theme(self):
        theme_id = "link::default_115"
        theme_name = "Atmosphere"
        theme_target = self.dr.find_element("data_request_themes", theme_id)
        exp = [self.dr.find_element("experiments", id) for id in ["link::default_310", "link::default_317"]]
        self.assertListEqual(self.dr.find_experiments_per_theme(theme_id), exp)
        self.assertListEqual(self.dr.find_experiments_per_theme(theme_name), exp)
        self.assertListEqual(self.dr.find_experiments_per_theme(theme_target), exp)

    def test_find_variables_per_theme(self):
        theme_id = "link::default_115"
        theme_name = "Atmosphere"
        theme_target = self.dr.find_element("data_request_themes", theme_id)
        var = [self.dr.find_element("variables", id) for id in ["link::83bbfc65-7f07-11ef-9308-b1dd71e64bec",
                                                                "link::83bbfc71-7f07-11ef-9308-b1dd71e64bec",
                                                                "link::baaefbcc-e5dd-11e5-8482-ac72891c3257",
                                                                "link::baaf8452-e5dd-11e5-8482-ac72891c3257",
                                                                "link::bab034a6-e5dd-11e5-8482-ac72891c3257",
                                                                "link::bab1c668-e5dd-11e5-8482-ac72891c3257",
                                                                "link::bab3c904-e5dd-11e5-8482-ac72891c3257",
                                                                "link::bab47354-e5dd-11e5-8482-ac72891c3257",
                                                                "link::bab52b5a-e5dd-11e5-8482-ac72891c3257",
                                                                "link::bab59202-e5dd-11e5-8482-ac72891c3257",
                                                                "link::bab5df78-e5dd-11e5-8482-ac72891c3257",
                                                                "link::bab65138-e5dd-11e5-8482-ac72891c3257",
                                                                "link::bab91b20-e5dd-11e5-8482-ac72891c3257",
                                                                "link::babb12ae-e5dd-11e5-8482-ac72891c3257"]]
        self.assertListEqual(self.dr.find_variables_per_theme(theme_id), var)
        self.assertListEqual(self.dr.find_variables_per_theme(theme_name), var)
        self.assertListEqual(self.dr.find_variables_per_theme(theme_target), var)

    def test_find_mips_per_theme(self):
        theme_id = "link::default_115"
        theme_name = "Atmosphere"
        theme_target = self.dr.find_element("data_request_themes", theme_id)
        mips = [self.dr.find_element("mips", id) for id in ["link::default_403", "link::default_409",
                                                            "link::default_411", "link::default_416"]]
        self.assertListEqual(self.dr.find_mips_per_theme(theme_id), mips)
        self.assertListEqual(self.dr.find_mips_per_theme(theme_name), mips)
        self.assertListEqual(self.dr.find_mips_per_theme(theme_target), mips)

    def test_themes_per_opportunity(self):
        op_id = "link::default_418"
        op_name = "Accurate assessment of land-atmosphere coupling"
        op_target = self.dr.find_element("opportunities", op_id)
        themes = [self.dr.find_element("data_request_themes", id) for id in ["link::default_115", "link::default_118"]]
        self.assertListEqual(self.dr.find_themes_per_opportunity(op_id), themes)
        self.assertListEqual(self.dr.find_themes_per_opportunity(op_name), themes)
        self.assertListEqual(self.dr.find_themes_per_opportunity(op_target), themes)

    def test_experiments_per_opportunity(self):
        op_id = "link::default_418"
        op_name = "Accurate assessment of land-atmosphere coupling"
        op_target = self.dr.find_element("opportunities", op_id)
        exp = [self.dr.find_element("experiments", id) for id in ["link::default_310", "link::default_317"]]
        self.assertListEqual(self.dr.find_experiments_per_opportunity(op_id), exp)
        self.assertListEqual(self.dr.find_experiments_per_opportunity(op_name), exp)
        self.assertListEqual(self.dr.find_experiments_per_opportunity(op_target), exp)

    def test_variables_per_opportunity(self):
        op_id = "link::default_418"
        op_name = "Accurate assessment of land-atmosphere coupling"
        op_target = self.dr.find_element("opportunities", op_id)
        var = [self.dr.find_element("variables", id) for id in ["link::83bbfc65-7f07-11ef-9308-b1dd71e64bec",
                                                                "link::83bbfc71-7f07-11ef-9308-b1dd71e64bec",
                                                                "link::baaefbcc-e5dd-11e5-8482-ac72891c3257",
                                                                "link::baaf8452-e5dd-11e5-8482-ac72891c3257",
                                                                "link::bab034a6-e5dd-11e5-8482-ac72891c3257",
                                                                "link::bab1c668-e5dd-11e5-8482-ac72891c3257",
                                                                "link::bab3c904-e5dd-11e5-8482-ac72891c3257",
                                                                "link::bab47354-e5dd-11e5-8482-ac72891c3257",
                                                                "link::bab52b5a-e5dd-11e5-8482-ac72891c3257",
                                                                "link::bab59202-e5dd-11e5-8482-ac72891c3257",
                                                                "link::bab5df78-e5dd-11e5-8482-ac72891c3257",
                                                                "link::bab65138-e5dd-11e5-8482-ac72891c3257",
                                                                "link::bab91b20-e5dd-11e5-8482-ac72891c3257",
                                                                "link::babb12ae-e5dd-11e5-8482-ac72891c3257"]]
        self.assertListEqual(self.dr.find_variables_per_opportunity(op_id), var)
        self.assertListEqual(self.dr.find_variables_per_opportunity(op_name), var)
        self.assertListEqual(self.dr.find_variables_per_opportunity(op_target), var)

    def test_mips_per_opportunity(self):
        op_id = "link::default_418"
        op_name = "Accurate assessment of land-atmosphere coupling"
        op_target = self.dr.find_element("opportunities", op_id)
        mips = [self.dr.find_element("mips", id) for id in ["link::default_403", "link::default_409",
                                                            "link::default_411", "link::default_416"]]
        self.assertListEqual(self.dr.find_mips_per_opportunity(op_id), mips)
        self.assertListEqual(self.dr.find_mips_per_opportunity(op_name), mips)
        self.assertListEqual(self.dr.find_mips_per_opportunity(op_target), mips)

    def test_opportunities_per_variable(self):
        var_id = "link::83bbfb69-7f07-11ef-9308-b1dd71e64bec"
        var_name = "Oday.zos"
        var_target = self.dr.find_element("variables", var_id)
        op = [self.dr.find_element("opportunities", id) for id in ["link::default_420", ]]
        self.assertListEqual(self.dr.find_opportunities_per_variable(var_id), op)
        self.assertListEqual(self.dr.find_opportunities_per_variable(var_name), op)
        self.assertListEqual(self.dr.find_opportunities_per_variable(var_target), op)

    def test_themes_per_variable(self):
        var_id = "link::83bbfb69-7f07-11ef-9308-b1dd71e64bec"
        var_name = "Oday.zos"
        var_target = self.dr.find_element("variables", var_id)
        themes = [self.dr.find_element("data_request_themes", id) for id in ["link::default_116", "link::default_117",
                                                                             "link::default_119"]]
        self.assertListEqual(self.dr.find_themes_per_variable(var_id), themes)
        self.assertListEqual(self.dr.find_themes_per_variable(var_name), themes)
        self.assertListEqual(self.dr.find_themes_per_variable(var_target), themes)

    def test_mips_per_variable(self):
        var_id = "link::83bbfb69-7f07-11ef-9308-b1dd71e64bec"
        var_name = "Oday.zos"
        var_target = self.dr.find_element("variables", var_id)
        mips = [self.dr.find_element("mips", id) for id in ["link::default_403", "link::default_407",
                                                            "link::default_408", "link::default_409",
                                                            "link::default_410", "link::default_412",
                                                            "link::default_414", "link::default_415",
                                                            "link::default_416", "link::default_417"]]
        self.assertListEqual(self.dr.find_mips_per_variable(var_id), mips)
        self.assertListEqual(self.dr.find_mips_per_variable(var_name), mips)
        self.assertListEqual(self.dr.find_mips_per_variable(var_target), mips)

    def test_opportunities_per_experiment(self):
        exp_id = "link::default_294"
        exp_name = "Initialised prediction (2025-2036)"
        exp_target = self.dr.find_element("experiments", exp_id)
        op = [self.dr.find_element("opportunities", id) for id in ["link::default_420", "link::default_421"]]
        self.assertListEqual(self.dr.find_opportunities_per_experiment(exp_id), op)
        self.assertListEqual(self.dr.find_opportunities_per_experiment(exp_name), op)
        self.assertListEqual(self.dr.find_opportunities_per_experiment(exp_target), op)

    def test_themes_per_experiment(self):
        exp_id = "link::default_294"
        exp_name = "Initialised prediction (2025-2036)"
        exp_target = self.dr.find_element("experiments", exp_id)
        themes = [self.dr.find_element("data_request_themes", id) for id in ["link::default_116", "link::default_117",
                                                                             "link::default_119"]]
        self.assertListEqual(self.dr.find_themes_per_experiment(exp_id), themes)
        self.assertListEqual(self.dr.find_themes_per_experiment(exp_name), themes)
        self.assertListEqual(self.dr.find_themes_per_experiment(exp_target), themes)

    def test_find_opportunities(self):
        theme_id = "link::default_115"
        exp_id = "link::default_294"
        list_all = list()
        list_any = [self.dr.find_element("opportunities", id) for id in ["link::default_418", "link::default_420",
                                                                         "link::default_421"]]
        self.assertListEqual(self.dr.find_opportunities(operation="all", data_request_themes=theme_id,
                                                        experiments=[exp_id, ]), list_all)
        self.assertListEqual(self.dr.find_opportunities(operation="any", data_request_themes=theme_id,
                                                        experiments=[exp_id, ]), list_any)

    def test_find_experiments(self):
        op_id = "link::default_418"
        expgrp_id = ["link::default_286", "link::default_288"]
        list_all = list()
        list_any = [self.dr.find_element("experiments", id) for id in ["link::default_294", "link::default_310",
                                                                       "link::default_317"]]
        self.assertListEqual(self.dr.find_experiments(operation="all", opportunities=op_id,
                                                      experiment_groups=expgrp_id), list_all)
        self.assertListEqual(self.dr.find_experiments(operation="any", opportunities=op_id,
                                                      experiment_groups=expgrp_id), list_any)

    def test_find_variables(self):
        table_id = "MIPtable::E1hr"
        vars_id = ["83bbfbbc-7f07-11ef-9308-b1dd71e64bec", "83bbfbbd-7f07-11ef-9308-b1dd71e64bec",
                   "83bbfbbf-7f07-11ef-9308-b1dd71e64bec", "83bbfbc0-7f07-11ef-9308-b1dd71e64bec",
                   "83bbfbc2-7f07-11ef-9308-b1dd71e64bec", "83bbfbc4-7f07-11ef-9308-b1dd71e64bec",
                   "83bbfbc5-7f07-11ef-9308-b1dd71e64bec", "83bbfbc7-7f07-11ef-9308-b1dd71e64bec",
                   "83bbfbca-7f07-11ef-9308-b1dd71e64bec", "8baebea6-4a5b-11e6-9cd2-ac72891c3257",
                   "8bb11ef8-4a5b-11e6-9cd2-ac72891c3257"]
        self.assertListEqual(self.dr.find_variables(operation="all", table_identifier=table_id),
                             [self.dr.find_element("variables", var_id) for var_id in vars_id])

        tshp_id = "7a97ae58-8042-11e6-97ee-ac72891c3257"
        vars_id = ["bab942a8-e5dd-11e5-8482-ac72891c3257", "bab955ea-e5dd-11e5-8482-ac72891c3257"]
        self.assertListEqual(self.dr.find_variables(operation="all", temporal_shape=tshp_id),
                             [self.dr.find_element("variables", var_id) for var_id in vars_id])

        sshp_id = "a6563bca-8883-11e5-b571-ac72891c3257"
        vars_id = ["f2fad86e-c38d-11e6-abc1-1b922e5e1118", ]
        self.assertListEqual(self.dr.find_variables(operation="all", spatial_shape=sshp_id),
                             [self.dr.find_element("variables", var_id) for var_id in vars_id])

        str_id = "default_487"
        vars_id = ["bab955ea-e5dd-11e5-8482-ac72891c3257", ]
        self.assertListEqual(self.dr.find_variables(operation="all", structure=str_id),
                             [self.dr.find_element("variables", var_id) for var_id in vars_id])

        param_id = "00e77372e8b909d9a827a0790e991fd9"
        vars_id = ["bab2f9d4-e5dd-11e5-8482-ac72891c3257", ]
        self.assertListEqual(self.dr.find_variables(operation="all", physical_parameter=param_id),
                             [self.dr.find_element("variables", var_id) for var_id in vars_id])

        realm_id = "ocnBgchem"
        vars_id = ["83bbfb7c-7f07-11ef-9308-b1dd71e64bec", "83bbfb7f-7f07-11ef-9308-b1dd71e64bec",
                   "83bbfb94-7f07-11ef-9308-b1dd71e64bec", "ba9f3ac0-e5dd-11e5-8482-ac72891c3257",
                   "ba9f643c-e5dd-11e5-8482-ac72891c3257", "ba9f686a-e5dd-11e5-8482-ac72891c3257",
                   "ba9f91f0-e5dd-11e5-8482-ac72891c3257", "c9180bae-c5e8-11e6-84e6-5404a60d96b5",
                   "c9181982-c5e8-11e6-84e6-5404a60d96b5"]
        self.assertListEqual(self.dr.find_variables(operation="all", modelling_realm=realm_id),
                             [self.dr.find_element("variables", var_id) for var_id in vars_id])

        bcv_id = "default_122"
        vars_id = ["bab3c904-e5dd-11e5-8482-ac72891c3257", ]
        self.assertListEqual(self.dr.find_variables(operation="all", **{"esm-bcv": bcv_id}),
                             [self.dr.find_element("variables", var_id) for var_id in vars_id])

        cf_std_id = "default_32"
        vars_id = ["baab0382-e5dd-11e5-8482-ac72891c3257", ]
        self.assertListEqual(self.dr.find_variables(operation="all", cf_standard_name=cf_std_id),
                             [self.dr.find_element("variables", var_id) for var_id in vars_id])

        cell_methods_id = "CellMethods::amla"
        vars_id = ["bab1c08c-e5dd-11e5-8482-ac72891c3257", "f2fad86e-c38d-11e6-abc1-1b922e5e1118"]
        self.assertListEqual(self.dr.find_variables(operation="all", cell_methods=cell_methods_id),
                             [self.dr.find_element("variables", var_id) for var_id in vars_id])

        cell_measure_id = "default_2"
        vars_id = ["baa3f2e0-e5dd-11e5-8482-ac72891c3257", ]
        self.assertListEqual(self.dr.find_variables(operation="all", cell_measures=cell_measure_id),
                             [self.dr.find_element("variables", var_id) for var_id in vars_id])

    def test_find_priority_per_variable(self):
        var_id = "link::babb20b4-e5dd-11e5-8482-ac72891c3257"
        var = self.dr.find_element("variable", var_id)
        self.assertEqual(self.dr.find_priority_per_variable(var), 1)

    def test_cache_issue(self):
        with tempfile.TemporaryDirectory() as output_dir:
            self.dr.find_variables_per_opportunity(self.dr.get_opportunities()[0])
            self.dr.export_summary("variables", "opportunities",
                                   os.sep.join([output_dir, "var_per_op.csv"]))

    def test_export_summary(self):
        with tempfile.TemporaryDirectory() as output_dir:
            self.dr.export_summary("opportunities", "data_request_themes",
                                   os.sep.join([output_dir, "op_per_th.csv"]))
            self.dr.export_summary("variables", "opportunities",
                                   os.sep.join([output_dir, "var_per_op.csv"]))
            self.dr.export_summary("opportunities", "variables",
                                   os.sep.join([output_dir, "op_per_var.csv"]))
            self.dr.export_summary("experiments", "opportunities",
                                   os.sep.join([output_dir, "exp_per_op.csv"]))
            self.dr.export_summary("variables", "spatial_shape",
                                   os.sep.join([output_dir, "var_per_spsh.csv"]))

    def test_export_data(self):
        with tempfile.TemporaryDirectory() as output_dir:
            self.dr.export_data("opportunities",
                                os.sep.join([output_dir, "op.csv"]),
                                export_columns_request=["name", "lead_theme", "description"])

A class whose instances are single test cases.

By default, the test code itself should be placed in a method named 'runTest'.

If the fixture may be used for many test cases, create as many test methods as are needed. When instantiating such a TestCase subclass, specify in the constructor arguments the name of the test method that the instance is to execute.

Test authors should subclass TestCase for their own tests. Construction and deconstruction of the test's environment ('fixture') can be implemented by overriding the 'setUp' and 'tearDown' methods respectively.

If it is necessary to override the init method, the base class init method must always be called. It is important that subclasses should not change the signature of their init method, since instances of the classes are instantiated automatically by parts of the framework in order to be run.

When subclassing TestCase, you can set these attributes: * failureException: determines which exception will be raised when the instance's assertion methods fail; test methods raising this exception will be deemed to have 'failed' rather than 'errored'. * longMessage: determines whether long messages (including repr of objects used in assert methods) will be printed on failure in addition to any explicit message passed. * maxDiff: sets the maximum length of a diff in failure messages by assert methods using difflib. It is looked up as an instance attribute so can be configured by individual tests if required.

Create an instance of the class that will use the named test method when executed. Raises a ValueError if the instance does not have a method with the specified name.

Ancestors

  • unittest.case.TestCase

Methods

def setUp(self)
Expand source code
def setUp(self):
    self.vs_file = filepath("one_base_VS_output.json")
    self.vs = VocabularyServer.from_input(self.vs_file)
    self.input_database_file = filepath("one_base_DR_output.json")
    self.input_database = read_json_input_file_content(self.input_database_file)
    self.dr = DataRequest(input_database=self.input_database, VS=self.vs)
    self.exp_export = filepath("experiments_export.txt")
    self.exp_expgrp_summmary = filepath("exp_expgrp_summary.txt")

Hook method for setting up the test fixture before exercising it.

def test_cache_issue(self)
Expand source code
def test_cache_issue(self):
    with tempfile.TemporaryDirectory() as output_dir:
        self.dr.find_variables_per_opportunity(self.dr.get_opportunities()[0])
        self.dr.export_summary("variables", "opportunities",
                               os.sep.join([output_dir, "var_per_op.csv"]))
def test_element_from_vs(self)
Expand source code
def test_element_from_vs(self):
    id_var = "link::1aab80fc-b006-11e6-9289-ac72891c3257"
    name_var = "Omon.wo"
    target_var = self.dr.find_element("variables", id_var)
    self.assertEqual(self.dr.find_element_from_vs(element_type="variables", value=id_var), target_var)
    self.assertEqual(self.dr.find_element_from_vs(element_type="variables", value=name_var), target_var)
    with self.assertRaises(ValueError):
        self.dr.find_element_from_vs(element_type="variables", value="toto")
    with self.assertRaises(ValueError):
        self.dr.find_element_from_vs(element_type="variables", value="link::toto")
    self.assertEqual(self.dr.find_element_from_vs(element_type="variables", value="link::toto", default=None), None)
    self.assertEqual(self.dr.find_element_from_vs(element_type="variables", value="toto", default=None), None)
    with self.assertRaises(ValueError):
        self.dr.find_element_from_vs(element_type="opportunity/variable_group_comments", value="undef")
    self.assertEqual(self.dr.find_element_from_vs(element_type="variables", value=id_var, key="id"), target_var)
def test_element_per_identifier_from_vs(self)
Expand source code
def test_element_per_identifier_from_vs(self):
    id_var = "link::1aab80fc-b006-11e6-9289-ac72891c3257"
    name_var = "Omon.wo"
    target_var = self.dr.find_element("variables", id_var)
    self.assertEqual(self.dr.find_element_per_identifier_from_vs(element_type="variables", key="id", value=id_var),
                     target_var)
    self.assertEqual(self.dr.find_element_per_identifier_from_vs(element_type="variables", key="name",
                                                                 value=name_var),
                     target_var)
    with self.assertRaises(ValueError):
        self.dr.find_element_per_identifier_from_vs(element_type="variables", key="name", value="toto")
    with self.assertRaises(ValueError):
        self.dr.find_element_per_identifier_from_vs(element_type="variables", key="id", value="link::toto")
    self.assertEqual(self.dr.find_element_per_identifier_from_vs(element_type="variables", key="id",
                                                                 value="link::toto", default=None),
                     None)
    self.assertEqual(self.dr.find_element_per_identifier_from_vs(element_type="variables", key="name",
                                                                 value="toto", default=None),
                     None)
    with self.assertRaises(ValueError):
        self.dr.find_element_per_identifier_from_vs(element_type="opportunity/variable_group_comments", key="name",
                                                    value="undef")

    self.assertEqual(self.dr.find_element_per_identifier_from_vs(element_type="variable", value=None, key="id", default=None),
                     None)
def test_experiments_per_opportunity(self)
Expand source code
def test_experiments_per_opportunity(self):
    op_id = "link::default_418"
    op_name = "Accurate assessment of land-atmosphere coupling"
    op_target = self.dr.find_element("opportunities", op_id)
    exp = [self.dr.find_element("experiments", id) for id in ["link::default_310", "link::default_317"]]
    self.assertListEqual(self.dr.find_experiments_per_opportunity(op_id), exp)
    self.assertListEqual(self.dr.find_experiments_per_opportunity(op_name), exp)
    self.assertListEqual(self.dr.find_experiments_per_opportunity(op_target), exp)
def test_export_data(self)
Expand source code
def test_export_data(self):
    with tempfile.TemporaryDirectory() as output_dir:
        self.dr.export_data("opportunities",
                            os.sep.join([output_dir, "op.csv"]),
                            export_columns_request=["name", "lead_theme", "description"])
def test_export_summary(self)
Expand source code
def test_export_summary(self):
    with tempfile.TemporaryDirectory() as output_dir:
        self.dr.export_summary("opportunities", "data_request_themes",
                               os.sep.join([output_dir, "op_per_th.csv"]))
        self.dr.export_summary("variables", "opportunities",
                               os.sep.join([output_dir, "var_per_op.csv"]))
        self.dr.export_summary("opportunities", "variables",
                               os.sep.join([output_dir, "op_per_var.csv"]))
        self.dr.export_summary("experiments", "opportunities",
                               os.sep.join([output_dir, "exp_per_op.csv"]))
        self.dr.export_summary("variables", "spatial_shape",
                               os.sep.join([output_dir, "var_per_spsh.csv"]))
def test_filter_elements_per_request(self)
Expand source code
def test_filter_elements_per_request(self):
    with self.assertRaises(TypeError):
        self.dr.filter_elements_per_request()

    self.assertEqual(self.dr.filter_elements_per_request("opportunities"), self.dr.get_opportunities())
    self.assertEqual(self.dr.filter_elements_per_request("opportunities", request_operation="any"),
                     self.dr.get_opportunities())
    with self.assertRaises(ValueError):
        self.dr.filter_elements_per_request("opportunities", request_operation="one")

    with self.assertRaises(ValueError):
        self.dr.filter_elements_per_request("opportunities", requests=dict(variables="link::test_dummy"))
    self.assertListEqual(self.dr.filter_elements_per_request("opportunities", skip_if_missing=True,
                                                             requests=dict(variables="link::test_dummy")),
                         self.dr.get_opportunities())

    self.assertListEqual(self.dr.filter_elements_per_request("experiment_groups",
                                                             requests=dict(variable="1aab80fc-b006-11e6-9289-ac72891c3257")),
                         [self.dr.find_element("experiment_group", id) for id in ["default_285", "default_287",
                                                                                  "default_288", "default_289"]])
    list_var_grp = [self.dr.find_element("variable_groups", id)
                    for id in ["default_569", "default_570", "default_571", "default_572", "default_573",
                               "default_574", "default_575", "default_576", "default_579"]]
    self.assertListEqual(self.dr.filter_elements_per_request("variable_groups",
                                                             requests=dict(experiment="default_290")),
                         list_var_grp)
    found_vargrp_all = self.dr.filter_elements_per_request("variable_groups",
                                                           requests=dict(experiment="default_290"),
                                                           not_requests=dict(
                                                               opportunity="default_421",
                                                               variable=["babb20b4-e5dd-11e5-8482-ac72891c3257", "d243ba76-4a9f-11e6-b84e-ac72891c3257"]),
                                                           not_request_operation="all")
    self.assertEqual(len(found_vargrp_all), len(list_var_grp))
    self.assertListEqual(found_vargrp_all, list_var_grp)
    found_vargrp_any = self.dr.filter_elements_per_request("variable_groups",
                                                           requests=dict(experiment="default_290"),
                                                           not_requests=dict(
                                                               opportunity="default_421",
                                                               variable=["babb20b4-e5dd-11e5-8482-ac72891c3257", "d243ba76-4a9f-11e6-b84e-ac72891c3257"]),
                                                           not_request_operation="any")
    list_vargrp_any = [self.dr.find_element("variable_group", elt) for elt in ["default_570", "default_571", "default_572"]]
    self.assertEqual(len(found_vargrp_any), len(list_vargrp_any))
    self.assertListEqual(found_vargrp_any, list_vargrp_any)
    found_vargrp_anyofall = self.dr.filter_elements_per_request("variable_groups",
                                                                requests=dict(experiment="default_290"),
                                                                not_requests=dict(
                                                                    opportunity="default_421",
                                                                    variable=["babb20b4-e5dd-11e5-8482-ac72891c3257", "d243ba76-4a9f-11e6-b84e-ac72891c3257"]),
                                                                not_request_operation="any_of_all")
    list_vargrp_anyofall = [self.dr.find_element("variable_group", elt) for elt in ["default_569", "default_570", "default_571", "default_572"]]
    self.assertEqual(len(found_vargrp_anyofall), len(list_vargrp_anyofall))
    self.assertListEqual(found_vargrp_anyofall, list_vargrp_anyofall)
    found_vargrp_allofany = self.dr.filter_elements_per_request("variable_groups",
                                                                requests=dict(experiment="default_290"),
                                                                not_requests=dict(
                                                                    opportunity="default_421",
                                                                    variable=["babb20b4-e5dd-11e5-8482-ac72891c3257","d243ba76-4a9f-11e6-b84e-ac72891c3257"]),
                                                                not_request_operation="all_of_any")
    self.assertEqual(len(found_vargrp_allofany), len(list_var_grp))
    self.assertListEqual(found_vargrp_allofany, list_var_grp)
    self.assertListEqual(self.dr.filter_elements_per_request("variable_groups",
                                                             requests=dict(experiment="default_290"),
                                                             not_requests=dict(opportunity="default_421")),
                         [self.dr.find_element("variable_group", elt)
                          for elt in ["default_569", "default_570", "default_571", "default_572", "default_579"]])
    self.assertListEqual(self.dr.filter_elements_per_request(self.dr.get_variable_groups(),
                                                             requests=dict(experiment="default_290")),
                         list_var_grp)
    self.assertListEqual(self.dr.filter_elements_per_request(self.dr.get_variable_group("default_569"),
                                                             requests=dict(experiment="default_290")),
                         [self.dr.find_element("variable_group", "default_569"), ])
def test_find_experiments(self)
Expand source code
def test_find_experiments(self):
    op_id = "link::default_418"
    expgrp_id = ["link::default_286", "link::default_288"]
    list_all = list()
    list_any = [self.dr.find_element("experiments", id) for id in ["link::default_294", "link::default_310",
                                                                   "link::default_317"]]
    self.assertListEqual(self.dr.find_experiments(operation="all", opportunities=op_id,
                                                  experiment_groups=expgrp_id), list_all)
    self.assertListEqual(self.dr.find_experiments(operation="any", opportunities=op_id,
                                                  experiment_groups=expgrp_id), list_any)
def test_find_experiments_per_theme(self)
Expand source code
def test_find_experiments_per_theme(self):
    theme_id = "link::default_115"
    theme_name = "Atmosphere"
    theme_target = self.dr.find_element("data_request_themes", theme_id)
    exp = [self.dr.find_element("experiments", id) for id in ["link::default_310", "link::default_317"]]
    self.assertListEqual(self.dr.find_experiments_per_theme(theme_id), exp)
    self.assertListEqual(self.dr.find_experiments_per_theme(theme_name), exp)
    self.assertListEqual(self.dr.find_experiments_per_theme(theme_target), exp)
def test_find_mips_per_theme(self)
Expand source code
def test_find_mips_per_theme(self):
    theme_id = "link::default_115"
    theme_name = "Atmosphere"
    theme_target = self.dr.find_element("data_request_themes", theme_id)
    mips = [self.dr.find_element("mips", id) for id in ["link::default_403", "link::default_409",
                                                        "link::default_411", "link::default_416"]]
    self.assertListEqual(self.dr.find_mips_per_theme(theme_id), mips)
    self.assertListEqual(self.dr.find_mips_per_theme(theme_name), mips)
    self.assertListEqual(self.dr.find_mips_per_theme(theme_target), mips)
def test_find_opportunities(self)
Expand source code
def test_find_opportunities(self):
    theme_id = "link::default_115"
    exp_id = "link::default_294"
    list_all = list()
    list_any = [self.dr.find_element("opportunities", id) for id in ["link::default_418", "link::default_420",
                                                                     "link::default_421"]]
    self.assertListEqual(self.dr.find_opportunities(operation="all", data_request_themes=theme_id,
                                                    experiments=[exp_id, ]), list_all)
    self.assertListEqual(self.dr.find_opportunities(operation="any", data_request_themes=theme_id,
                                                    experiments=[exp_id, ]), list_any)
def test_find_opportunities_per_theme(self)
Expand source code
def test_find_opportunities_per_theme(self):
    theme_id = "link::default_115"
    theme_name = "Atmosphere"
    theme_target = self.dr.find_element("data_request_themes", theme_id)
    opportunities = [self.dr.get_opportunity(id) for id in ["link::default_418", ]]
    self.assertListEqual(self.dr.find_opportunities_per_theme(theme_id), opportunities)
    self.assertListEqual(self.dr.find_opportunities_per_theme(theme_name), opportunities)
    self.assertListEqual(self.dr.find_opportunities_per_theme(theme_target), opportunities)
    with self.assertRaises(ValueError):
        self.dr.find_opportunities_per_theme("toto")
    with self.assertRaises(ValueError):
        self.dr.find_opportunities_per_theme("link::toto")
def test_find_priority_per_variable(self)
Expand source code
def test_find_priority_per_variable(self):
    var_id = "link::babb20b4-e5dd-11e5-8482-ac72891c3257"
    var = self.dr.find_element("variable", var_id)
    self.assertEqual(self.dr.find_priority_per_variable(var), 1)
def test_find_variables(self)
Expand source code
def test_find_variables(self):
    table_id = "MIPtable::E1hr"
    vars_id = ["83bbfbbc-7f07-11ef-9308-b1dd71e64bec", "83bbfbbd-7f07-11ef-9308-b1dd71e64bec",
               "83bbfbbf-7f07-11ef-9308-b1dd71e64bec", "83bbfbc0-7f07-11ef-9308-b1dd71e64bec",
               "83bbfbc2-7f07-11ef-9308-b1dd71e64bec", "83bbfbc4-7f07-11ef-9308-b1dd71e64bec",
               "83bbfbc5-7f07-11ef-9308-b1dd71e64bec", "83bbfbc7-7f07-11ef-9308-b1dd71e64bec",
               "83bbfbca-7f07-11ef-9308-b1dd71e64bec", "8baebea6-4a5b-11e6-9cd2-ac72891c3257",
               "8bb11ef8-4a5b-11e6-9cd2-ac72891c3257"]
    self.assertListEqual(self.dr.find_variables(operation="all", table_identifier=table_id),
                         [self.dr.find_element("variables", var_id) for var_id in vars_id])

    tshp_id = "7a97ae58-8042-11e6-97ee-ac72891c3257"
    vars_id = ["bab942a8-e5dd-11e5-8482-ac72891c3257", "bab955ea-e5dd-11e5-8482-ac72891c3257"]
    self.assertListEqual(self.dr.find_variables(operation="all", temporal_shape=tshp_id),
                         [self.dr.find_element("variables", var_id) for var_id in vars_id])

    sshp_id = "a6563bca-8883-11e5-b571-ac72891c3257"
    vars_id = ["f2fad86e-c38d-11e6-abc1-1b922e5e1118", ]
    self.assertListEqual(self.dr.find_variables(operation="all", spatial_shape=sshp_id),
                         [self.dr.find_element("variables", var_id) for var_id in vars_id])

    str_id = "default_487"
    vars_id = ["bab955ea-e5dd-11e5-8482-ac72891c3257", ]
    self.assertListEqual(self.dr.find_variables(operation="all", structure=str_id),
                         [self.dr.find_element("variables", var_id) for var_id in vars_id])

    param_id = "00e77372e8b909d9a827a0790e991fd9"
    vars_id = ["bab2f9d4-e5dd-11e5-8482-ac72891c3257", ]
    self.assertListEqual(self.dr.find_variables(operation="all", physical_parameter=param_id),
                         [self.dr.find_element("variables", var_id) for var_id in vars_id])

    realm_id = "ocnBgchem"
    vars_id = ["83bbfb7c-7f07-11ef-9308-b1dd71e64bec", "83bbfb7f-7f07-11ef-9308-b1dd71e64bec",
               "83bbfb94-7f07-11ef-9308-b1dd71e64bec", "ba9f3ac0-e5dd-11e5-8482-ac72891c3257",
               "ba9f643c-e5dd-11e5-8482-ac72891c3257", "ba9f686a-e5dd-11e5-8482-ac72891c3257",
               "ba9f91f0-e5dd-11e5-8482-ac72891c3257", "c9180bae-c5e8-11e6-84e6-5404a60d96b5",
               "c9181982-c5e8-11e6-84e6-5404a60d96b5"]
    self.assertListEqual(self.dr.find_variables(operation="all", modelling_realm=realm_id),
                         [self.dr.find_element("variables", var_id) for var_id in vars_id])

    bcv_id = "default_122"
    vars_id = ["bab3c904-e5dd-11e5-8482-ac72891c3257", ]
    self.assertListEqual(self.dr.find_variables(operation="all", **{"esm-bcv": bcv_id}),
                         [self.dr.find_element("variables", var_id) for var_id in vars_id])

    cf_std_id = "default_32"
    vars_id = ["baab0382-e5dd-11e5-8482-ac72891c3257", ]
    self.assertListEqual(self.dr.find_variables(operation="all", cf_standard_name=cf_std_id),
                         [self.dr.find_element("variables", var_id) for var_id in vars_id])

    cell_methods_id = "CellMethods::amla"
    vars_id = ["bab1c08c-e5dd-11e5-8482-ac72891c3257", "f2fad86e-c38d-11e6-abc1-1b922e5e1118"]
    self.assertListEqual(self.dr.find_variables(operation="all", cell_methods=cell_methods_id),
                         [self.dr.find_element("variables", var_id) for var_id in vars_id])

    cell_measure_id = "default_2"
    vars_id = ["baa3f2e0-e5dd-11e5-8482-ac72891c3257", ]
    self.assertListEqual(self.dr.find_variables(operation="all", cell_measures=cell_measure_id),
                         [self.dr.find_element("variables", var_id) for var_id in vars_id])
def test_find_variables_per_priority(self)
Expand source code
def test_find_variables_per_priority(self):
    priority = "Medium"
    priority_obj = self.dr.find_element("priority_level", "link::default_482")
    target_var_list = [self.dr.find_element("variables", id)
                       for id in ["link::83bbfb6e-7f07-11ef-9308-b1dd71e64bec",
                                  "link::83bbfb71-7f07-11ef-9308-b1dd71e64bec",
                                  "link::83bbfb7c-7f07-11ef-9308-b1dd71e64bec",
                                  "link::83bbfb7f-7f07-11ef-9308-b1dd71e64bec",
                                  "link::83bbfb94-7f07-11ef-9308-b1dd71e64bec",
                                  "link::83bbfc6e-7f07-11ef-9308-b1dd71e64bec",
                                  "link::83bbfc6f-7f07-11ef-9308-b1dd71e64bec",
                                  "link::ba9f3ac0-e5dd-11e5-8482-ac72891c3257",
                                  "link::ba9f643c-e5dd-11e5-8482-ac72891c3257",
                                  "link::ba9f686a-e5dd-11e5-8482-ac72891c3257",
                                  "link::ba9f91f0-e5dd-11e5-8482-ac72891c3257",
                                  "link::baa4e07e-e5dd-11e5-8482-ac72891c3257",
                                  "link::baa720e6-e5dd-11e5-8482-ac72891c3257",
                                  "link::baa72514-e5dd-11e5-8482-ac72891c3257",
                                  "link::c9180bae-c5e8-11e6-84e6-5404a60d96b5",
                                  "link::c9181982-c5e8-11e6-84e6-5404a60d96b5"
                                  ]]
    var_list = self.dr.find_variables_per_priority(priority=priority)
    self.assertEqual(len(var_list), 16)
    self.assertListEqual(var_list, target_var_list)
    var_list = self.dr.find_variables_per_priority(priority=priority_obj)
    self.assertEqual(len(var_list), 16)
    self.assertListEqual(var_list, target_var_list)
def test_find_variables_per_theme(self)
Expand source code
def test_find_variables_per_theme(self):
    theme_id = "link::default_115"
    theme_name = "Atmosphere"
    theme_target = self.dr.find_element("data_request_themes", theme_id)
    var = [self.dr.find_element("variables", id) for id in ["link::83bbfc65-7f07-11ef-9308-b1dd71e64bec",
                                                            "link::83bbfc71-7f07-11ef-9308-b1dd71e64bec",
                                                            "link::baaefbcc-e5dd-11e5-8482-ac72891c3257",
                                                            "link::baaf8452-e5dd-11e5-8482-ac72891c3257",
                                                            "link::bab034a6-e5dd-11e5-8482-ac72891c3257",
                                                            "link::bab1c668-e5dd-11e5-8482-ac72891c3257",
                                                            "link::bab3c904-e5dd-11e5-8482-ac72891c3257",
                                                            "link::bab47354-e5dd-11e5-8482-ac72891c3257",
                                                            "link::bab52b5a-e5dd-11e5-8482-ac72891c3257",
                                                            "link::bab59202-e5dd-11e5-8482-ac72891c3257",
                                                            "link::bab5df78-e5dd-11e5-8482-ac72891c3257",
                                                            "link::bab65138-e5dd-11e5-8482-ac72891c3257",
                                                            "link::bab91b20-e5dd-11e5-8482-ac72891c3257",
                                                            "link::babb12ae-e5dd-11e5-8482-ac72891c3257"]]
    self.assertListEqual(self.dr.find_variables_per_theme(theme_id), var)
    self.assertListEqual(self.dr.find_variables_per_theme(theme_name), var)
    self.assertListEqual(self.dr.find_variables_per_theme(theme_target), var)
def test_mips_per_opportunity(self)
Expand source code
def test_mips_per_opportunity(self):
    op_id = "link::default_418"
    op_name = "Accurate assessment of land-atmosphere coupling"
    op_target = self.dr.find_element("opportunities", op_id)
    mips = [self.dr.find_element("mips", id) for id in ["link::default_403", "link::default_409",
                                                        "link::default_411", "link::default_416"]]
    self.assertListEqual(self.dr.find_mips_per_opportunity(op_id), mips)
    self.assertListEqual(self.dr.find_mips_per_opportunity(op_name), mips)
    self.assertListEqual(self.dr.find_mips_per_opportunity(op_target), mips)
def test_mips_per_variable(self)
Expand source code
def test_mips_per_variable(self):
    var_id = "link::83bbfb69-7f07-11ef-9308-b1dd71e64bec"
    var_name = "Oday.zos"
    var_target = self.dr.find_element("variables", var_id)
    mips = [self.dr.find_element("mips", id) for id in ["link::default_403", "link::default_407",
                                                        "link::default_408", "link::default_409",
                                                        "link::default_410", "link::default_412",
                                                        "link::default_414", "link::default_415",
                                                        "link::default_416", "link::default_417"]]
    self.assertListEqual(self.dr.find_mips_per_variable(var_id), mips)
    self.assertListEqual(self.dr.find_mips_per_variable(var_name), mips)
    self.assertListEqual(self.dr.find_mips_per_variable(var_target), mips)
def test_opportunities_per_experiment(self)
Expand source code
def test_opportunities_per_experiment(self):
    exp_id = "link::default_294"
    exp_name = "Initialised prediction (2025-2036)"
    exp_target = self.dr.find_element("experiments", exp_id)
    op = [self.dr.find_element("opportunities", id) for id in ["link::default_420", "link::default_421"]]
    self.assertListEqual(self.dr.find_opportunities_per_experiment(exp_id), op)
    self.assertListEqual(self.dr.find_opportunities_per_experiment(exp_name), op)
    self.assertListEqual(self.dr.find_opportunities_per_experiment(exp_target), op)
def test_opportunities_per_variable(self)
Expand source code
def test_opportunities_per_variable(self):
    var_id = "link::83bbfb69-7f07-11ef-9308-b1dd71e64bec"
    var_name = "Oday.zos"
    var_target = self.dr.find_element("variables", var_id)
    op = [self.dr.find_element("opportunities", id) for id in ["link::default_420", ]]
    self.assertListEqual(self.dr.find_opportunities_per_variable(var_id), op)
    self.assertListEqual(self.dr.find_opportunities_per_variable(var_name), op)
    self.assertListEqual(self.dr.find_opportunities_per_variable(var_target), op)
def test_themes_per_experiment(self)
Expand source code
def test_themes_per_experiment(self):
    exp_id = "link::default_294"
    exp_name = "Initialised prediction (2025-2036)"
    exp_target = self.dr.find_element("experiments", exp_id)
    themes = [self.dr.find_element("data_request_themes", id) for id in ["link::default_116", "link::default_117",
                                                                         "link::default_119"]]
    self.assertListEqual(self.dr.find_themes_per_experiment(exp_id), themes)
    self.assertListEqual(self.dr.find_themes_per_experiment(exp_name), themes)
    self.assertListEqual(self.dr.find_themes_per_experiment(exp_target), themes)
def test_themes_per_opportunity(self)
Expand source code
def test_themes_per_opportunity(self):
    op_id = "link::default_418"
    op_name = "Accurate assessment of land-atmosphere coupling"
    op_target = self.dr.find_element("opportunities", op_id)
    themes = [self.dr.find_element("data_request_themes", id) for id in ["link::default_115", "link::default_118"]]
    self.assertListEqual(self.dr.find_themes_per_opportunity(op_id), themes)
    self.assertListEqual(self.dr.find_themes_per_opportunity(op_name), themes)
    self.assertListEqual(self.dr.find_themes_per_opportunity(op_target), themes)
def test_themes_per_variable(self)
Expand source code
def test_themes_per_variable(self):
    var_id = "link::83bbfb69-7f07-11ef-9308-b1dd71e64bec"
    var_name = "Oday.zos"
    var_target = self.dr.find_element("variables", var_id)
    themes = [self.dr.find_element("data_request_themes", id) for id in ["link::default_116", "link::default_117",
                                                                         "link::default_119"]]
    self.assertListEqual(self.dr.find_themes_per_variable(var_id), themes)
    self.assertListEqual(self.dr.find_themes_per_variable(var_name), themes)
    self.assertListEqual(self.dr.find_themes_per_variable(var_target), themes)
def test_variables_per_opportunity(self)
Expand source code
def test_variables_per_opportunity(self):
    op_id = "link::default_418"
    op_name = "Accurate assessment of land-atmosphere coupling"
    op_target = self.dr.find_element("opportunities", op_id)
    var = [self.dr.find_element("variables", id) for id in ["link::83bbfc65-7f07-11ef-9308-b1dd71e64bec",
                                                            "link::83bbfc71-7f07-11ef-9308-b1dd71e64bec",
                                                            "link::baaefbcc-e5dd-11e5-8482-ac72891c3257",
                                                            "link::baaf8452-e5dd-11e5-8482-ac72891c3257",
                                                            "link::bab034a6-e5dd-11e5-8482-ac72891c3257",
                                                            "link::bab1c668-e5dd-11e5-8482-ac72891c3257",
                                                            "link::bab3c904-e5dd-11e5-8482-ac72891c3257",
                                                            "link::bab47354-e5dd-11e5-8482-ac72891c3257",
                                                            "link::bab52b5a-e5dd-11e5-8482-ac72891c3257",
                                                            "link::bab59202-e5dd-11e5-8482-ac72891c3257",
                                                            "link::bab5df78-e5dd-11e5-8482-ac72891c3257",
                                                            "link::bab65138-e5dd-11e5-8482-ac72891c3257",
                                                            "link::bab91b20-e5dd-11e5-8482-ac72891c3257",
                                                            "link::babb12ae-e5dd-11e5-8482-ac72891c3257"]]
    self.assertListEqual(self.dr.find_variables_per_opportunity(op_id), var)
    self.assertListEqual(self.dr.find_variables_per_opportunity(op_name), var)
    self.assertListEqual(self.dr.find_variables_per_opportunity(op_target), var)
class TestExperimentsGroup (methodName='runTest')
Expand source code
class TestExperimentsGroup(unittest.TestCase):
    def setUp(self):
        self.dr = DataRequest.from_separated_inputs(VS_input=filepath("one_base_VS_output.json"),
                                                    DR_input=filepath("one_base_DR_output.json"))

    def test_init(self):
        with self.assertRaises(TypeError):
            ExperimentsGroup()

        with self.assertRaises(TypeError):
            ExperimentsGroup("link::my_id")

        with self.assertRaises(TypeError):
            ExperimentsGroup(self.dr)

        obj = ExperimentsGroup("link::my_id", self.dr)

        obj = ExperimentsGroup(id="link::my_id", dr=self.dr, name="test")
        self.assertEqual(obj.DR_type, "experiment_groups")

    def test_from_input(self):
        with self.assertRaises(TypeError):
            ExperimentsGroup.from_input()

        with self.assertRaises(TypeError):
            ExperimentsGroup.from_input("link::my_id")

        with self.assertRaises(TypeError):
            ExperimentsGroup.from_input(self.dr)

        obj = ExperimentsGroup.from_input(id="link::my_id", dr=self.dr)

        with self.assertRaises(ValueError):
            obj = ExperimentsGroup.from_input(id="link::my_id", dr=self.dr, experiments=["link::test", ])

        obj = ExperimentsGroup.from_input(id="link::my_id", dr=self.dr,
                                          experiments=["link::default_291", "link::default_292"])

    def test_check(self):
        obj = ExperimentsGroup(id="link::my_id", dr=self.dr)
        obj.check()

        obj = ExperimentsGroup(id="link::my_id", dr=self.dr, experiments=["link::default_291", "link::default_292"])
        obj.check()

    def test_methods(self):
        obj = ExperimentsGroup(id="link::my_id", dr=self.dr)
        self.assertEqual(obj.count(), 0)
        self.assertEqual(obj.get_experiments(), list())

        obj = ExperimentsGroup.from_input(id="link::default_276", dr=self.dr,
                                          experiments=["link::default_291", "link::default_292"])
        self.assertEqual(obj.count(), 2)
        self.assertListEqual(obj.get_experiments(),
                             [self.dr.find_element("experiments", "link::default_291"),
                              self.dr.find_element("experiments", "link::default_292")])
        self.assertEqual(obj.get_experiments()[0].DR_type, "experiments")

    def test_print(self):
        obj = ExperimentsGroup.from_input(id="link::default_288", dr=self.dr,
                                          experiments=["link::default_317", "link::default_310"], name="historical")
        ref_str = "experiment_group: historical (id: default_288)"
        ref_str_2 = [
            ref_str,
            "    Experiments included:",
            "        experiment: historical (id: default_317)",
            "        experiment: esm-hist (id: default_310)"
        ]
        self.assertEqual(obj.print_content(add_content=False), [ref_str, ])
        self.assertEqual(obj.print_content(level=1, add_content=False), ["    " + ref_str, ])
        self.assertEqual(obj.print_content(), ref_str_2)
        self.assertEqual(obj.print_content(level=1), ["    " + elt for elt in ref_str_2])
        self.assertEqual(str(obj), os.linesep.join(ref_str_2))

    def test_eq(self):
        obj = ExperimentsGroup(id="link::my_id", dr=self.dr)
        obj2 = copy.deepcopy(obj)
        self.assertEqual(obj, obj2)

        obj3 = ExperimentsGroup(id="link::my_id_2", dr=self.dr)
        self.assertNotEqual(obj, obj3)

        obj4 = ExperimentsGroup(id="link::my_id", dr=self.dr, experiments=["link::default_292", "link::default_301"])
        self.assertNotEqual(obj, obj4)

        obj5 = DRObjects(id="link::my_id", dr=self.dr)
        self.assertNotEqual(obj, obj5)

    def test_filter_on_request(self):
        exp_grp1 = self.dr.find_element("experiment_groups", "link::default_286")
        exp_grp2 = copy.deepcopy(exp_grp1)
        exp_grp3 = self.dr.find_element("experiment_groups", "link::default_287")
        exp_1 = self.dr.find_element("experiments", "link::default_294")
        exp_2 = self.dr.find_element("experiments", "link::default_310")
        obj = DRObjects(id="link::my_id", dr=self.dr)
        self.assertEqual(exp_grp1.filter_on_request(exp_grp2), (True, True))
        self.assertEqual(exp_grp1.filter_on_request(exp_grp3), (True, False))
        self.assertEqual(exp_grp1.filter_on_request(exp_1), (True, True))
        self.assertEqual(exp_grp1.filter_on_request(exp_2), (True, False))
        self.assertEqual(exp_grp1.filter_on_request(obj), (False, False))

A class whose instances are single test cases.

By default, the test code itself should be placed in a method named 'runTest'.

If the fixture may be used for many test cases, create as many test methods as are needed. When instantiating such a TestCase subclass, specify in the constructor arguments the name of the test method that the instance is to execute.

Test authors should subclass TestCase for their own tests. Construction and deconstruction of the test's environment ('fixture') can be implemented by overriding the 'setUp' and 'tearDown' methods respectively.

If it is necessary to override the init method, the base class init method must always be called. It is important that subclasses should not change the signature of their init method, since instances of the classes are instantiated automatically by parts of the framework in order to be run.

When subclassing TestCase, you can set these attributes: * failureException: determines which exception will be raised when the instance's assertion methods fail; test methods raising this exception will be deemed to have 'failed' rather than 'errored'. * longMessage: determines whether long messages (including repr of objects used in assert methods) will be printed on failure in addition to any explicit message passed. * maxDiff: sets the maximum length of a diff in failure messages by assert methods using difflib. It is looked up as an instance attribute so can be configured by individual tests if required.

Create an instance of the class that will use the named test method when executed. Raises a ValueError if the instance does not have a method with the specified name.

Ancestors

  • unittest.case.TestCase

Methods

def setUp(self)
Expand source code
def setUp(self):
    self.dr = DataRequest.from_separated_inputs(VS_input=filepath("one_base_VS_output.json"),
                                                DR_input=filepath("one_base_DR_output.json"))

Hook method for setting up the test fixture before exercising it.

def test_check(self)
Expand source code
def test_check(self):
    obj = ExperimentsGroup(id="link::my_id", dr=self.dr)
    obj.check()

    obj = ExperimentsGroup(id="link::my_id", dr=self.dr, experiments=["link::default_291", "link::default_292"])
    obj.check()
def test_eq(self)
Expand source code
def test_eq(self):
    obj = ExperimentsGroup(id="link::my_id", dr=self.dr)
    obj2 = copy.deepcopy(obj)
    self.assertEqual(obj, obj2)

    obj3 = ExperimentsGroup(id="link::my_id_2", dr=self.dr)
    self.assertNotEqual(obj, obj3)

    obj4 = ExperimentsGroup(id="link::my_id", dr=self.dr, experiments=["link::default_292", "link::default_301"])
    self.assertNotEqual(obj, obj4)

    obj5 = DRObjects(id="link::my_id", dr=self.dr)
    self.assertNotEqual(obj, obj5)
def test_filter_on_request(self)
Expand source code
def test_filter_on_request(self):
    exp_grp1 = self.dr.find_element("experiment_groups", "link::default_286")
    exp_grp2 = copy.deepcopy(exp_grp1)
    exp_grp3 = self.dr.find_element("experiment_groups", "link::default_287")
    exp_1 = self.dr.find_element("experiments", "link::default_294")
    exp_2 = self.dr.find_element("experiments", "link::default_310")
    obj = DRObjects(id="link::my_id", dr=self.dr)
    self.assertEqual(exp_grp1.filter_on_request(exp_grp2), (True, True))
    self.assertEqual(exp_grp1.filter_on_request(exp_grp3), (True, False))
    self.assertEqual(exp_grp1.filter_on_request(exp_1), (True, True))
    self.assertEqual(exp_grp1.filter_on_request(exp_2), (True, False))
    self.assertEqual(exp_grp1.filter_on_request(obj), (False, False))
def test_from_input(self)
Expand source code
def test_from_input(self):
    with self.assertRaises(TypeError):
        ExperimentsGroup.from_input()

    with self.assertRaises(TypeError):
        ExperimentsGroup.from_input("link::my_id")

    with self.assertRaises(TypeError):
        ExperimentsGroup.from_input(self.dr)

    obj = ExperimentsGroup.from_input(id="link::my_id", dr=self.dr)

    with self.assertRaises(ValueError):
        obj = ExperimentsGroup.from_input(id="link::my_id", dr=self.dr, experiments=["link::test", ])

    obj = ExperimentsGroup.from_input(id="link::my_id", dr=self.dr,
                                      experiments=["link::default_291", "link::default_292"])
def test_init(self)
Expand source code
def test_init(self):
    with self.assertRaises(TypeError):
        ExperimentsGroup()

    with self.assertRaises(TypeError):
        ExperimentsGroup("link::my_id")

    with self.assertRaises(TypeError):
        ExperimentsGroup(self.dr)

    obj = ExperimentsGroup("link::my_id", self.dr)

    obj = ExperimentsGroup(id="link::my_id", dr=self.dr, name="test")
    self.assertEqual(obj.DR_type, "experiment_groups")
def test_methods(self)
Expand source code
def test_methods(self):
    obj = ExperimentsGroup(id="link::my_id", dr=self.dr)
    self.assertEqual(obj.count(), 0)
    self.assertEqual(obj.get_experiments(), list())

    obj = ExperimentsGroup.from_input(id="link::default_276", dr=self.dr,
                                      experiments=["link::default_291", "link::default_292"])
    self.assertEqual(obj.count(), 2)
    self.assertListEqual(obj.get_experiments(),
                         [self.dr.find_element("experiments", "link::default_291"),
                          self.dr.find_element("experiments", "link::default_292")])
    self.assertEqual(obj.get_experiments()[0].DR_type, "experiments")
def test_print(self)
Expand source code
def test_print(self):
    obj = ExperimentsGroup.from_input(id="link::default_288", dr=self.dr,
                                      experiments=["link::default_317", "link::default_310"], name="historical")
    ref_str = "experiment_group: historical (id: default_288)"
    ref_str_2 = [
        ref_str,
        "    Experiments included:",
        "        experiment: historical (id: default_317)",
        "        experiment: esm-hist (id: default_310)"
    ]
    self.assertEqual(obj.print_content(add_content=False), [ref_str, ])
    self.assertEqual(obj.print_content(level=1, add_content=False), ["    " + ref_str, ])
    self.assertEqual(obj.print_content(), ref_str_2)
    self.assertEqual(obj.print_content(level=1), ["    " + elt for elt in ref_str_2])
    self.assertEqual(str(obj), os.linesep.join(ref_str_2))
class TestOpportunity (methodName='runTest')
Expand source code
class TestOpportunity(unittest.TestCase):
    def setUp(self):
        self.dr = DataRequest.from_separated_inputs(DR_input=filepath("one_base_DR_output.json"),
                                                    VS_input=filepath("one_base_VS_output.json"))

    def test_init(self):
        with self.assertRaises(TypeError):
            Opportunity()

        with self.assertRaises(TypeError):
            Opportunity("my_id")

        with self.assertRaises(TypeError):
            Opportunity(self.dr)

        obj = Opportunity("my_id", self.dr)

        obj = Opportunity(id="my_id", dr=self.dr, variables_groups=["test1", "test2"],
                          experiments_groups=["test3", "test4"], themes=["theme1", "theme2"])
        self.assertEqual(obj.DR_type, "opportunities")

    def test_from_input(self):
        with self.assertRaises(TypeError):
            Opportunity.from_input()

        with self.assertRaises(TypeError):
            Opportunity.from_input("my_id")

        with self.assertRaises(TypeError):
            Opportunity.from_input(self.dr)

        obj = Opportunity.from_input("my_id", self.dr)

        obj = Opportunity.from_input(id="my_id", dr=self.dr)

        with self.assertRaises(ValueError):
            obj = Opportunity.from_input(id="my_id", dr=self.dr, variable_groups=["test", ])

        obj = Opportunity.from_input(id="my_id", dr=self.dr,
                                     variable_groups=["link::default_577", "link::default_578"],
                                     experiment_groups=["link::default_285", ],
                                     data_request_themes=["link::default_115", "link::default_116",
                                                          "link::default_117"])

    def test_check(self):
        obj = Opportunity(id="my_id", dr=self.dr)
        obj.check()

        obj = Opportunity(id="my_id", dr=self.dr, variables_groups=["default_733", "default_734"])
        obj.check()

    def test_methods(self):
        obj = Opportunity(id="my_id", dr=self.dr)
        self.assertEqual(obj.get_experiment_groups(), list())
        self.assertEqual(obj.get_variable_groups(), list())
        self.assertEqual(obj.get_themes(), list())

        obj = Opportunity.from_input(id="link::default_425", dr=self.dr,
                                     variable_groups=["link::default_577", "link::default_578"],
                                     experiment_groups=["link::default_285", ],
                                     data_request_themes=["link::default_116", "link::default_117",
                                                          "link::default_119"])
        self.assertListEqual(obj.get_experiment_groups(), [self.dr.find_element("experiment_groups", "default_285")])
        self.assertListEqual(obj.get_variable_groups(),
                             [self.dr.find_element("variable_groups", "link::default_577"),
                              self.dr.find_element("variable_groups", "link::default_578")])
        self.assertListEqual(obj.get_themes(),
                             [self.dr.find_element("data_request_themes", "link::default_116"),
                              self.dr.find_element("data_request_themes", "link::default_117"),
                              self.dr.find_element("data_request_themes", "link::default_119")
                              ])

    def test_print(self):
        obj = Opportunity.from_input(id="link::default_420", dr=self.dr, name="Ocean Extremes",
                                     variable_groups=["link::default_575", "link::default_576"],
                                     experiment_groups=["link::default_285", ],
                                     data_request_themes=["link::default_115", "link::default_117",
                                                          "link::default_118"])
        ref_str = "opportunity: Ocean Extremes (id: default_420)"
        ref_str_2 = [
            ref_str,
            "    Experiments groups included:",
            "        experiment_group: ar7-fast-track (id: default_285)",
            "    Variables groups included:",
            "        variable_group: baseline_monthly (id: default_575)",
            "        variable_group: baseline_subdaily (id: default_576)",
            "    Themes included:",
            "        data_request_theme: Atmosphere (id: default_115)",
            "        data_request_theme: Impacts & Adaptation (id: default_117)",
            "        data_request_theme: Land & Land-Ice (id: default_118)",
            "    Time subsets included:"
        ]
        self.assertEqual(obj.print_content(add_content=False), [ref_str, ])
        self.assertEqual(obj.print_content(level=1, add_content=False), ["    " + ref_str, ])
        self.assertEqual(obj.print_content(), ref_str_2)
        self.assertEqual(obj.print_content(level=1), ["    " + elt for elt in ref_str_2])
        self.assertEqual(str(obj), os.linesep.join(ref_str_2))

    def test_eq(self):
        obj = Opportunity(id="my_id", dr=self.dr)
        obj2 = copy.deepcopy(obj)
        self.assertEqual(obj, obj2)

        obj3 = Opportunity(id="my_id_2", dr=self.dr)
        self.assertNotEqual(obj, obj3)

        obj4 = Opportunity(id="my_id", dr=self.dr, experiments_groups=["default_285", ])
        self.assertNotEqual(obj, obj4)

        obj5 = Opportunity(id="my_id", dr=self.dr, variables_groups=["default_733", "default_734"])
        self.assertNotEqual(obj, obj5)

        obj6 = Opportunity(id="my_id", dr=self.dr, themes=["default_104", "default_105", "default_106"])
        self.assertNotEqual(obj, obj6)

        obj7 = DRObjects(id="my_id", dr=self.dr)
        self.assertNotEqual(obj, obj7)

    def test_filter_on_request(self):
        op_1 = self.dr.find_element("opportunities", "default_420")
        op_2 = copy.deepcopy(op_1)
        op_3 = self.dr.find_element("opportunities", "default_418")
        theme_1 = self.dr.find_element("data_request_theme", "default_115")
        theme_2 = self.dr.find_element("data_request_theme", "default_116")
        var_grp_1 = self.dr.find_element("variable_group", "default_579")
        var_grp_2 = self.dr.find_element("variable_group", "default_578")
        exp_grp_1 = self.dr.find_element("experiment_group", "default_288")
        exp_grp_2 = self.dr.find_element("experiment_group", "default_285")
        exp_1 = self.dr.find_element("experiment", "default_310")
        exp_2 = self.dr.find_element("experiment", "default_320")
        time_1 = self.dr.find_element("time_subset", "link::_slice_hist20")
        var_2 = self.dr.find_element("variable", "5a070350-c77d-11e6-8a33-5404a60d96b5")
        var_1 = self.dr.find_element("variable", "83bbfc6e-7f07-11ef-9308-b1dd71e64bec")
        mip_2 = self.dr.find_element("mips", "default_411")
        mip_1 = self.dr.find_element("mips", "default_417")
        prio_2 = self.dr.find_element("priority_level", "default_481")
        prio_1 = self.dr.find_element("priority_level", "default_482")
        max_prio_1 = self.dr.find_element("max_priority_level", "default_482")
        max_prio_2 = self.dr.find_element("max_priority_level", "default_481")
        table_1 = self.dr.find_element("table_identifier", "MIPtable::Oday")
        table_2 = self.dr.find_element("table_identifier", "MIPtable::CFday")
        tshp_1 = self.dr.find_element("temporal_shape", "cf34c974-80be-11e6-97ee-ac72891c3257")
        tshp_2 = self.dr.find_element("temporal_shape", "7a97ae58-8042-11e6-97ee-ac72891c3257")
        sshp_1 = self.dr.find_element("spatial_shape", "a656047a-8883-11e5-b571-ac72891c3257")
        sshp_2 = self.dr.find_element("spatial_shape", "a65615fa-8883-11e5-b571-ac72891c3257")
        str_1 = self.dr.find_element("structure", "link::default_504")
        str_2 = self.dr.find_element("structure", "link::default_513")
        param_1 = self.dr.find_element("physical_parameter", "3e3ddc77800e7d421834b9cb808602d7")
        param_2 = self.dr.find_element("physical_parameter", "00e77372e8b909d9a827a0790e991fd9")
        realm_1 = self.dr.find_element("modelling_realm", "ocean")
        realm_2 = self.dr.find_element("modelling_realm", "land")
        bcv_2 = self.dr.find_element("esm-bcv", "link::default_121")
        cf_std_1 = self.dr.find_element("cf_standard_name", "default_65")
        cf_std_2 = self.dr.find_element("cf_standard_name", "default_101")
        cell_method_1 = self.dr.find_element("cell_methods", "CellMethods::amns-fx")
        cell_method_2 = self.dr.find_element("cell_methods", "CellMethods::amla")
        cell_measure_1 = self.dr.find_element("cell_measure", "link::default_5")
        cell_measure_2 = self.dr.find_element("cell_measure", "link::default_1")
        obj = DRObjects(id="link::my_id", dr=self.dr)
        self.assertEqual(op_1.filter_on_request(op_2), (True, True))
        self.assertEqual(op_1.filter_on_request(op_3), (True, False))
        self.assertEqual(op_3.filter_on_request(theme_1), (True, True))
        self.assertEqual(op_3.filter_on_request(theme_2), (True, False))
        self.assertEqual(op_3.filter_on_request(exp_1), (True, True))
        self.assertEqual(op_3.filter_on_request(exp_2), (True, False))
        self.assertEqual(op_3.filter_on_request(time_1), (True, True))
        self.assertEqual(op_1.filter_on_request(time_1), (True, False))
        self.assertEqual(op_3.filter_on_request(exp_grp_1), (True, True))
        self.assertEqual(op_3.filter_on_request(exp_grp_2), (True, False))
        self.assertEqual(op_1.filter_on_request(var_grp_1), (True, True))
        self.assertEqual(op_1.filter_on_request(var_grp_2), (True, False))
        self.assertEqual(op_1.filter_on_request(var_1), (True, True))
        self.assertEqual(op_1.filter_on_request(var_2), (True, False))
        self.assertEqual(op_1.filter_on_request(mip_1), (True, True))
        self.assertEqual(op_1.filter_on_request(mip_2), (True, False))
        self.assertEqual(op_1.filter_on_request(prio_1), (True, True))
        self.assertEqual(op_1.filter_on_request(prio_2), (True, True))
        self.assertEqual(op_1.filter_on_request(max_prio_1), (True, True))
        self.assertEqual(op_1.filter_on_request(max_prio_2), (True, True))
        self.assertEqual(op_1.filter_on_request(table_1), (True, True))
        self.assertEqual(op_1.filter_on_request(table_2), (True, False))
        self.assertEqual(op_1.filter_on_request(tshp_1), (True, True))
        self.assertEqual(op_1.filter_on_request(tshp_2), (True, False))
        self.assertEqual(op_1.filter_on_request(sshp_1), (True, True))
        self.assertEqual(op_1.filter_on_request(sshp_2), (True, False))
        self.assertEqual(op_1.filter_on_request(str_1), (True, True))
        self.assertEqual(op_1.filter_on_request(str_2), (True, False))
        self.assertEqual(op_1.filter_on_request(param_1), (True, True))
        self.assertEqual(op_1.filter_on_request(param_2), (True, False))
        self.assertEqual(op_1.filter_on_request(realm_1), (True, True))
        self.assertEqual(op_1.filter_on_request(realm_2), (True, False))
        self.assertEqual(op_1.filter_on_request(bcv_2), (True, False))
        self.assertEqual(op_1.filter_on_request(cf_std_1), (True, True))
        self.assertEqual(op_1.filter_on_request(cf_std_2), (True, False))
        self.assertEqual(op_1.filter_on_request(cell_method_1), (True, True))
        self.assertEqual(op_1.filter_on_request(cell_method_2), (True, False))
        self.assertEqual(op_1.filter_on_request(cell_measure_1), (True, True))
        self.assertEqual(op_1.filter_on_request(cell_measure_2), (True, False))
        self.assertEqual(op_1.filter_on_request(obj), (False, False))

A class whose instances are single test cases.

By default, the test code itself should be placed in a method named 'runTest'.

If the fixture may be used for many test cases, create as many test methods as are needed. When instantiating such a TestCase subclass, specify in the constructor arguments the name of the test method that the instance is to execute.

Test authors should subclass TestCase for their own tests. Construction and deconstruction of the test's environment ('fixture') can be implemented by overriding the 'setUp' and 'tearDown' methods respectively.

If it is necessary to override the init method, the base class init method must always be called. It is important that subclasses should not change the signature of their init method, since instances of the classes are instantiated automatically by parts of the framework in order to be run.

When subclassing TestCase, you can set these attributes: * failureException: determines which exception will be raised when the instance's assertion methods fail; test methods raising this exception will be deemed to have 'failed' rather than 'errored'. * longMessage: determines whether long messages (including repr of objects used in assert methods) will be printed on failure in addition to any explicit message passed. * maxDiff: sets the maximum length of a diff in failure messages by assert methods using difflib. It is looked up as an instance attribute so can be configured by individual tests if required.

Create an instance of the class that will use the named test method when executed. Raises a ValueError if the instance does not have a method with the specified name.

Ancestors

  • unittest.case.TestCase

Methods

def setUp(self)
Expand source code
def setUp(self):
    self.dr = DataRequest.from_separated_inputs(DR_input=filepath("one_base_DR_output.json"),
                                                VS_input=filepath("one_base_VS_output.json"))

Hook method for setting up the test fixture before exercising it.

def test_check(self)
Expand source code
def test_check(self):
    obj = Opportunity(id="my_id", dr=self.dr)
    obj.check()

    obj = Opportunity(id="my_id", dr=self.dr, variables_groups=["default_733", "default_734"])
    obj.check()
def test_eq(self)
Expand source code
def test_eq(self):
    obj = Opportunity(id="my_id", dr=self.dr)
    obj2 = copy.deepcopy(obj)
    self.assertEqual(obj, obj2)

    obj3 = Opportunity(id="my_id_2", dr=self.dr)
    self.assertNotEqual(obj, obj3)

    obj4 = Opportunity(id="my_id", dr=self.dr, experiments_groups=["default_285", ])
    self.assertNotEqual(obj, obj4)

    obj5 = Opportunity(id="my_id", dr=self.dr, variables_groups=["default_733", "default_734"])
    self.assertNotEqual(obj, obj5)

    obj6 = Opportunity(id="my_id", dr=self.dr, themes=["default_104", "default_105", "default_106"])
    self.assertNotEqual(obj, obj6)

    obj7 = DRObjects(id="my_id", dr=self.dr)
    self.assertNotEqual(obj, obj7)
def test_filter_on_request(self)
Expand source code
def test_filter_on_request(self):
    op_1 = self.dr.find_element("opportunities", "default_420")
    op_2 = copy.deepcopy(op_1)
    op_3 = self.dr.find_element("opportunities", "default_418")
    theme_1 = self.dr.find_element("data_request_theme", "default_115")
    theme_2 = self.dr.find_element("data_request_theme", "default_116")
    var_grp_1 = self.dr.find_element("variable_group", "default_579")
    var_grp_2 = self.dr.find_element("variable_group", "default_578")
    exp_grp_1 = self.dr.find_element("experiment_group", "default_288")
    exp_grp_2 = self.dr.find_element("experiment_group", "default_285")
    exp_1 = self.dr.find_element("experiment", "default_310")
    exp_2 = self.dr.find_element("experiment", "default_320")
    time_1 = self.dr.find_element("time_subset", "link::_slice_hist20")
    var_2 = self.dr.find_element("variable", "5a070350-c77d-11e6-8a33-5404a60d96b5")
    var_1 = self.dr.find_element("variable", "83bbfc6e-7f07-11ef-9308-b1dd71e64bec")
    mip_2 = self.dr.find_element("mips", "default_411")
    mip_1 = self.dr.find_element("mips", "default_417")
    prio_2 = self.dr.find_element("priority_level", "default_481")
    prio_1 = self.dr.find_element("priority_level", "default_482")
    max_prio_1 = self.dr.find_element("max_priority_level", "default_482")
    max_prio_2 = self.dr.find_element("max_priority_level", "default_481")
    table_1 = self.dr.find_element("table_identifier", "MIPtable::Oday")
    table_2 = self.dr.find_element("table_identifier", "MIPtable::CFday")
    tshp_1 = self.dr.find_element("temporal_shape", "cf34c974-80be-11e6-97ee-ac72891c3257")
    tshp_2 = self.dr.find_element("temporal_shape", "7a97ae58-8042-11e6-97ee-ac72891c3257")
    sshp_1 = self.dr.find_element("spatial_shape", "a656047a-8883-11e5-b571-ac72891c3257")
    sshp_2 = self.dr.find_element("spatial_shape", "a65615fa-8883-11e5-b571-ac72891c3257")
    str_1 = self.dr.find_element("structure", "link::default_504")
    str_2 = self.dr.find_element("structure", "link::default_513")
    param_1 = self.dr.find_element("physical_parameter", "3e3ddc77800e7d421834b9cb808602d7")
    param_2 = self.dr.find_element("physical_parameter", "00e77372e8b909d9a827a0790e991fd9")
    realm_1 = self.dr.find_element("modelling_realm", "ocean")
    realm_2 = self.dr.find_element("modelling_realm", "land")
    bcv_2 = self.dr.find_element("esm-bcv", "link::default_121")
    cf_std_1 = self.dr.find_element("cf_standard_name", "default_65")
    cf_std_2 = self.dr.find_element("cf_standard_name", "default_101")
    cell_method_1 = self.dr.find_element("cell_methods", "CellMethods::amns-fx")
    cell_method_2 = self.dr.find_element("cell_methods", "CellMethods::amla")
    cell_measure_1 = self.dr.find_element("cell_measure", "link::default_5")
    cell_measure_2 = self.dr.find_element("cell_measure", "link::default_1")
    obj = DRObjects(id="link::my_id", dr=self.dr)
    self.assertEqual(op_1.filter_on_request(op_2), (True, True))
    self.assertEqual(op_1.filter_on_request(op_3), (True, False))
    self.assertEqual(op_3.filter_on_request(theme_1), (True, True))
    self.assertEqual(op_3.filter_on_request(theme_2), (True, False))
    self.assertEqual(op_3.filter_on_request(exp_1), (True, True))
    self.assertEqual(op_3.filter_on_request(exp_2), (True, False))
    self.assertEqual(op_3.filter_on_request(time_1), (True, True))
    self.assertEqual(op_1.filter_on_request(time_1), (True, False))
    self.assertEqual(op_3.filter_on_request(exp_grp_1), (True, True))
    self.assertEqual(op_3.filter_on_request(exp_grp_2), (True, False))
    self.assertEqual(op_1.filter_on_request(var_grp_1), (True, True))
    self.assertEqual(op_1.filter_on_request(var_grp_2), (True, False))
    self.assertEqual(op_1.filter_on_request(var_1), (True, True))
    self.assertEqual(op_1.filter_on_request(var_2), (True, False))
    self.assertEqual(op_1.filter_on_request(mip_1), (True, True))
    self.assertEqual(op_1.filter_on_request(mip_2), (True, False))
    self.assertEqual(op_1.filter_on_request(prio_1), (True, True))
    self.assertEqual(op_1.filter_on_request(prio_2), (True, True))
    self.assertEqual(op_1.filter_on_request(max_prio_1), (True, True))
    self.assertEqual(op_1.filter_on_request(max_prio_2), (True, True))
    self.assertEqual(op_1.filter_on_request(table_1), (True, True))
    self.assertEqual(op_1.filter_on_request(table_2), (True, False))
    self.assertEqual(op_1.filter_on_request(tshp_1), (True, True))
    self.assertEqual(op_1.filter_on_request(tshp_2), (True, False))
    self.assertEqual(op_1.filter_on_request(sshp_1), (True, True))
    self.assertEqual(op_1.filter_on_request(sshp_2), (True, False))
    self.assertEqual(op_1.filter_on_request(str_1), (True, True))
    self.assertEqual(op_1.filter_on_request(str_2), (True, False))
    self.assertEqual(op_1.filter_on_request(param_1), (True, True))
    self.assertEqual(op_1.filter_on_request(param_2), (True, False))
    self.assertEqual(op_1.filter_on_request(realm_1), (True, True))
    self.assertEqual(op_1.filter_on_request(realm_2), (True, False))
    self.assertEqual(op_1.filter_on_request(bcv_2), (True, False))
    self.assertEqual(op_1.filter_on_request(cf_std_1), (True, True))
    self.assertEqual(op_1.filter_on_request(cf_std_2), (True, False))
    self.assertEqual(op_1.filter_on_request(cell_method_1), (True, True))
    self.assertEqual(op_1.filter_on_request(cell_method_2), (True, False))
    self.assertEqual(op_1.filter_on_request(cell_measure_1), (True, True))
    self.assertEqual(op_1.filter_on_request(cell_measure_2), (True, False))
    self.assertEqual(op_1.filter_on_request(obj), (False, False))
def test_from_input(self)
Expand source code
def test_from_input(self):
    with self.assertRaises(TypeError):
        Opportunity.from_input()

    with self.assertRaises(TypeError):
        Opportunity.from_input("my_id")

    with self.assertRaises(TypeError):
        Opportunity.from_input(self.dr)

    obj = Opportunity.from_input("my_id", self.dr)

    obj = Opportunity.from_input(id="my_id", dr=self.dr)

    with self.assertRaises(ValueError):
        obj = Opportunity.from_input(id="my_id", dr=self.dr, variable_groups=["test", ])

    obj = Opportunity.from_input(id="my_id", dr=self.dr,
                                 variable_groups=["link::default_577", "link::default_578"],
                                 experiment_groups=["link::default_285", ],
                                 data_request_themes=["link::default_115", "link::default_116",
                                                      "link::default_117"])
def test_init(self)
Expand source code
def test_init(self):
    with self.assertRaises(TypeError):
        Opportunity()

    with self.assertRaises(TypeError):
        Opportunity("my_id")

    with self.assertRaises(TypeError):
        Opportunity(self.dr)

    obj = Opportunity("my_id", self.dr)

    obj = Opportunity(id="my_id", dr=self.dr, variables_groups=["test1", "test2"],
                      experiments_groups=["test3", "test4"], themes=["theme1", "theme2"])
    self.assertEqual(obj.DR_type, "opportunities")
def test_methods(self)
Expand source code
def test_methods(self):
    obj = Opportunity(id="my_id", dr=self.dr)
    self.assertEqual(obj.get_experiment_groups(), list())
    self.assertEqual(obj.get_variable_groups(), list())
    self.assertEqual(obj.get_themes(), list())

    obj = Opportunity.from_input(id="link::default_425", dr=self.dr,
                                 variable_groups=["link::default_577", "link::default_578"],
                                 experiment_groups=["link::default_285", ],
                                 data_request_themes=["link::default_116", "link::default_117",
                                                      "link::default_119"])
    self.assertListEqual(obj.get_experiment_groups(), [self.dr.find_element("experiment_groups", "default_285")])
    self.assertListEqual(obj.get_variable_groups(),
                         [self.dr.find_element("variable_groups", "link::default_577"),
                          self.dr.find_element("variable_groups", "link::default_578")])
    self.assertListEqual(obj.get_themes(),
                         [self.dr.find_element("data_request_themes", "link::default_116"),
                          self.dr.find_element("data_request_themes", "link::default_117"),
                          self.dr.find_element("data_request_themes", "link::default_119")
                          ])
def test_print(self)
Expand source code
def test_print(self):
    obj = Opportunity.from_input(id="link::default_420", dr=self.dr, name="Ocean Extremes",
                                 variable_groups=["link::default_575", "link::default_576"],
                                 experiment_groups=["link::default_285", ],
                                 data_request_themes=["link::default_115", "link::default_117",
                                                      "link::default_118"])
    ref_str = "opportunity: Ocean Extremes (id: default_420)"
    ref_str_2 = [
        ref_str,
        "    Experiments groups included:",
        "        experiment_group: ar7-fast-track (id: default_285)",
        "    Variables groups included:",
        "        variable_group: baseline_monthly (id: default_575)",
        "        variable_group: baseline_subdaily (id: default_576)",
        "    Themes included:",
        "        data_request_theme: Atmosphere (id: default_115)",
        "        data_request_theme: Impacts & Adaptation (id: default_117)",
        "        data_request_theme: Land & Land-Ice (id: default_118)",
        "    Time subsets included:"
    ]
    self.assertEqual(obj.print_content(add_content=False), [ref_str, ])
    self.assertEqual(obj.print_content(level=1, add_content=False), ["    " + ref_str, ])
    self.assertEqual(obj.print_content(), ref_str_2)
    self.assertEqual(obj.print_content(level=1), ["    " + elt for elt in ref_str_2])
    self.assertEqual(str(obj), os.linesep.join(ref_str_2))
class TestVariables (methodName='runTest')
Expand source code
class TestVariables(unittest.TestCase):
    def setUp(self):
        self.dr = DataRequest.from_separated_inputs(VS_input=filepath("one_base_VS_output.json"),
                                                    DR_input=filepath("one_base_DR_output.json"))

    def test_print(self):
        obj = self.dr.find_element("variable", "1aab80fc-b006-11e6-9289-ac72891c3257")
        ref_str = 'variable: wo at frequency mon (id: 1aab80fc-b006-11e6-9289-ac72891c3257, title: Sea Water Vertical Velocity)'
        ref_str_2 = [
            ref_str,
        ]
        self.assertEqual(obj.print_content(add_content=False), [ref_str, ])
        self.assertEqual(obj.print_content(level=1, add_content=False), ["    " + ref_str, ])
        self.assertEqual(obj.print_content(), ref_str_2)
        self.assertEqual(obj.print_content(level=1), ["    " + elt for elt in ref_str_2])
        self.assertEqual(str(obj), os.linesep.join(ref_str_2))

    def test_filter_on_request(self):
        var_1 = self.dr.find_element("variable", "1aab80fc-b006-11e6-9289-ac72891c3257")
        var_2 = copy.deepcopy(var_1)
        var_3 = self.dr.find_element("variable", "5a070350-c77d-11e6-8a33-5404a60d96b5")
        table_1 = self.dr.find_element("table_identifier", "MIPtable::Omon")
        table_2 = self.dr.find_element("table_identifier", "MIPtable::Oday")
        tshp_1 = self.dr.find_element("temporal_shape", "cf34c974-80be-11e6-97ee-ac72891c3257")
        tshp_2 = self.dr.find_element("temporal_shape", "7a97ae58-8042-11e6-97ee-ac72891c3257")
        sshp_1 = self.dr.find_element("spatial_shape", "a6562c2a-8883-11e5-b571-ac72891c3257")
        sshp_2 = self.dr.find_element("spatial_shape", "a6562a9a-8883-11e5-b571-ac72891c3257")
        str_1 = self.dr.find_element("structure", "default_492")
        str_2 = self.dr.find_element("structure", "default_493")
        param_1 = self.dr.find_element("physical_parameter", "d476e6113f5c466d27fd3aa9e9c35411")
        param_2 = self.dr.find_element("physical_parameter", "d76ba4c5868a0a9a02f433dc3c86d5d2")
        realm_1 = self.dr.find_element("modelling_realm", "ocean")
        realm_2 = self.dr.find_element("modelling_realm", "atmos")
        bcv_1 = self.dr.find_element("esm-bcv", "default_240")
        bcv_2 = self.dr.find_element("esm-bcv", "default_241")
        cf_1 = self.dr.find_element("cf_standard_name", "default_99")
        cf_2 = self.dr.find_element("cf_standard_name", "default_100")
        cell_method_1 = self.dr.find_element("cell_method", "CellMethods::amse-tmn")
        cell_method_2 = self.dr.find_element("cell_method", "CellMethods::amse-tpt")
        cell_measure_1 = self.dr.find_element("cell_measure", "default_4")
        cell_measure_2 = self.dr.find_element("cell_measure", "default_3")
        obj = DRObjects(id="link::my_id", dr=self.dr)
        self.assertEqual(var_1.filter_on_request(var_2), (True, True))
        self.assertEqual(var_1.filter_on_request(var_3), (True, False))
        self.assertEqual(var_1.filter_on_request(table_1), (True, True))
        self.assertEqual(var_1.filter_on_request(table_2), (True, False))
        self.assertEqual(var_1.filter_on_request(tshp_1), (True, True))
        self.assertEqual(var_1.filter_on_request(tshp_2), (True, False))
        self.assertEqual(var_1.filter_on_request(sshp_1), (True, True))
        self.assertEqual(var_1.filter_on_request(sshp_2), (True, False))
        self.assertEqual(var_1.filter_on_request(str_1), (True, True))
        self.assertEqual(var_1.filter_on_request(str_2), (True, False))
        self.assertEqual(var_1.filter_on_request(param_1), (True, True))
        self.assertEqual(var_1.filter_on_request(param_2), (True, False))
        self.assertEqual(var_1.filter_on_request(realm_1), (True, True))
        self.assertEqual(var_1.filter_on_request(realm_2), (True, False))
        self.assertEqual(var_1.filter_on_request(bcv_1), (True, True))
        self.assertEqual(var_1.filter_on_request(bcv_2), (True, False))
        self.assertEqual(var_1.filter_on_request(cf_1), (True, True))
        self.assertEqual(var_1.filter_on_request(cf_2), (True, False))
        self.assertEqual(var_1.filter_on_request(cell_method_1), (True, True))
        self.assertEqual(var_1.filter_on_request(cell_method_2), (True, False))
        self.assertEqual(var_1.filter_on_request(cell_measure_1), (True, True))
        self.assertEqual(var_1.filter_on_request(cell_measure_2), (True, False))
        self.assertEqual(var_1.filter_on_request(obj), (False, False))

A class whose instances are single test cases.

By default, the test code itself should be placed in a method named 'runTest'.

If the fixture may be used for many test cases, create as many test methods as are needed. When instantiating such a TestCase subclass, specify in the constructor arguments the name of the test method that the instance is to execute.

Test authors should subclass TestCase for their own tests. Construction and deconstruction of the test's environment ('fixture') can be implemented by overriding the 'setUp' and 'tearDown' methods respectively.

If it is necessary to override the init method, the base class init method must always be called. It is important that subclasses should not change the signature of their init method, since instances of the classes are instantiated automatically by parts of the framework in order to be run.

When subclassing TestCase, you can set these attributes: * failureException: determines which exception will be raised when the instance's assertion methods fail; test methods raising this exception will be deemed to have 'failed' rather than 'errored'. * longMessage: determines whether long messages (including repr of objects used in assert methods) will be printed on failure in addition to any explicit message passed. * maxDiff: sets the maximum length of a diff in failure messages by assert methods using difflib. It is looked up as an instance attribute so can be configured by individual tests if required.

Create an instance of the class that will use the named test method when executed. Raises a ValueError if the instance does not have a method with the specified name.

Ancestors

  • unittest.case.TestCase

Methods

def setUp(self)
Expand source code
def setUp(self):
    self.dr = DataRequest.from_separated_inputs(VS_input=filepath("one_base_VS_output.json"),
                                                DR_input=filepath("one_base_DR_output.json"))

Hook method for setting up the test fixture before exercising it.

def test_filter_on_request(self)
Expand source code
def test_filter_on_request(self):
    var_1 = self.dr.find_element("variable", "1aab80fc-b006-11e6-9289-ac72891c3257")
    var_2 = copy.deepcopy(var_1)
    var_3 = self.dr.find_element("variable", "5a070350-c77d-11e6-8a33-5404a60d96b5")
    table_1 = self.dr.find_element("table_identifier", "MIPtable::Omon")
    table_2 = self.dr.find_element("table_identifier", "MIPtable::Oday")
    tshp_1 = self.dr.find_element("temporal_shape", "cf34c974-80be-11e6-97ee-ac72891c3257")
    tshp_2 = self.dr.find_element("temporal_shape", "7a97ae58-8042-11e6-97ee-ac72891c3257")
    sshp_1 = self.dr.find_element("spatial_shape", "a6562c2a-8883-11e5-b571-ac72891c3257")
    sshp_2 = self.dr.find_element("spatial_shape", "a6562a9a-8883-11e5-b571-ac72891c3257")
    str_1 = self.dr.find_element("structure", "default_492")
    str_2 = self.dr.find_element("structure", "default_493")
    param_1 = self.dr.find_element("physical_parameter", "d476e6113f5c466d27fd3aa9e9c35411")
    param_2 = self.dr.find_element("physical_parameter", "d76ba4c5868a0a9a02f433dc3c86d5d2")
    realm_1 = self.dr.find_element("modelling_realm", "ocean")
    realm_2 = self.dr.find_element("modelling_realm", "atmos")
    bcv_1 = self.dr.find_element("esm-bcv", "default_240")
    bcv_2 = self.dr.find_element("esm-bcv", "default_241")
    cf_1 = self.dr.find_element("cf_standard_name", "default_99")
    cf_2 = self.dr.find_element("cf_standard_name", "default_100")
    cell_method_1 = self.dr.find_element("cell_method", "CellMethods::amse-tmn")
    cell_method_2 = self.dr.find_element("cell_method", "CellMethods::amse-tpt")
    cell_measure_1 = self.dr.find_element("cell_measure", "default_4")
    cell_measure_2 = self.dr.find_element("cell_measure", "default_3")
    obj = DRObjects(id="link::my_id", dr=self.dr)
    self.assertEqual(var_1.filter_on_request(var_2), (True, True))
    self.assertEqual(var_1.filter_on_request(var_3), (True, False))
    self.assertEqual(var_1.filter_on_request(table_1), (True, True))
    self.assertEqual(var_1.filter_on_request(table_2), (True, False))
    self.assertEqual(var_1.filter_on_request(tshp_1), (True, True))
    self.assertEqual(var_1.filter_on_request(tshp_2), (True, False))
    self.assertEqual(var_1.filter_on_request(sshp_1), (True, True))
    self.assertEqual(var_1.filter_on_request(sshp_2), (True, False))
    self.assertEqual(var_1.filter_on_request(str_1), (True, True))
    self.assertEqual(var_1.filter_on_request(str_2), (True, False))
    self.assertEqual(var_1.filter_on_request(param_1), (True, True))
    self.assertEqual(var_1.filter_on_request(param_2), (True, False))
    self.assertEqual(var_1.filter_on_request(realm_1), (True, True))
    self.assertEqual(var_1.filter_on_request(realm_2), (True, False))
    self.assertEqual(var_1.filter_on_request(bcv_1), (True, True))
    self.assertEqual(var_1.filter_on_request(bcv_2), (True, False))
    self.assertEqual(var_1.filter_on_request(cf_1), (True, True))
    self.assertEqual(var_1.filter_on_request(cf_2), (True, False))
    self.assertEqual(var_1.filter_on_request(cell_method_1), (True, True))
    self.assertEqual(var_1.filter_on_request(cell_method_2), (True, False))
    self.assertEqual(var_1.filter_on_request(cell_measure_1), (True, True))
    self.assertEqual(var_1.filter_on_request(cell_measure_2), (True, False))
    self.assertEqual(var_1.filter_on_request(obj), (False, False))
def test_print(self)
Expand source code
def test_print(self):
    obj = self.dr.find_element("variable", "1aab80fc-b006-11e6-9289-ac72891c3257")
    ref_str = 'variable: wo at frequency mon (id: 1aab80fc-b006-11e6-9289-ac72891c3257, title: Sea Water Vertical Velocity)'
    ref_str_2 = [
        ref_str,
    ]
    self.assertEqual(obj.print_content(add_content=False), [ref_str, ])
    self.assertEqual(obj.print_content(level=1, add_content=False), ["    " + ref_str, ])
    self.assertEqual(obj.print_content(), ref_str_2)
    self.assertEqual(obj.print_content(level=1), ["    " + elt for elt in ref_str_2])
    self.assertEqual(str(obj), os.linesep.join(ref_str_2))
class TestVariablesGroup (methodName='runTest')
Expand source code
class TestVariablesGroup(unittest.TestCase):
    def setUp(self):
        self.dr = DataRequest.from_separated_inputs(DR_input=filepath("one_base_DR_output.json"),
                                                    VS_input=filepath("one_base_VS_output.json"))

    def test_init(self):
        with self.assertRaises(TypeError):
            VariablesGroup()

        with self.assertRaises(TypeError):
            VariablesGroup("link::my_id")

        with self.assertRaises(TypeError):
            VariablesGroup(self.dr)

        obj = VariablesGroup("link::my_id", self.dr)
        self.assertEqual(obj.DR_type, "variable_groups")

        with self.assertRaises(ValueError):
            VariablesGroup("link::my_id", self.dr, name="test", physical_parameter="link::my_link")

    def test_from_input(self):
        with self.assertRaises(TypeError):
            VariablesGroup.from_input()

        with self.assertRaises(TypeError):
            VariablesGroup.from_input("link::my_id")

        with self.assertRaises(TypeError):
            VariablesGroup.from_input(self.dr)

        obj = VariablesGroup.from_input(id="link::my_id", dr=self.dr)

        with self.assertRaises(ValueError):
            obj = VariablesGroup.from_input(id="link:my_id", dr=self.dr, variables=["link::test", ])

        obj = VariablesGroup.from_input(id="link::my_id", dr=self.dr,
                                        variables=["link::bab3cb52-e5dd-11e5-8482-ac72891c3257",
                                                   "link::bab48ce0-e5dd-11e5-8482-ac72891c3257"])

    def test_check(self):
        obj = VariablesGroup(id="link::my_id", dr=self.dr)
        obj.check()

        obj = VariablesGroup(id="link::my_id", dr=self.dr,
                             variables=["link::bab3cb52-e5dd-11e5-8482-ac72891c3257",
                                        "link::bab48ce0-e5dd-11e5-8482-ac72891c3257"])
        obj.check()

    def test_methods(self):
        obj = VariablesGroup.from_input(id="link::my_id", dr=self.dr, priority_level="High")
        self.assertEqual(obj.count(), 0)
        self.assertEqual(obj.get_variables(), list())
        self.assertEqual(obj.get_mips(), list())
        self.assertEqual(obj.get_priority_level(), self.dr.find_element("priority_level", "High"))

        obj = VariablesGroup.from_input(id="link::dafc7484-8c95-11ef-944e-41a8eb05f654", dr=self.dr,
                                        variables=["link::bab3cb52-e5dd-11e5-8482-ac72891c3257",
                                                   "link::bab48ce0-e5dd-11e5-8482-ac72891c3257"],
                                        mips=["link::default_401", ], priority_level="High")
        self.assertEqual(obj.count(), 2)
        self.assertListEqual(obj.get_variables(),
                             [self.dr.find_element("variables", "link::bab3cb52-e5dd-11e5-8482-ac72891c3257"),
                              self.dr.find_element("variables", "link::bab48ce0-e5dd-11e5-8482-ac72891c3257")])
        self.assertEqual(obj.get_mips(), [self.dr.find_element("mips", "link::default_401")])
        self.assertDictEqual(obj.get_priority_level().attributes,
                             {'name': "High", "notes": "High priority should be used sparingly", "value": 1,
                              'id': "default_481"})

    def test_filter_on_request(self):
        var_grp1 = self.dr.find_element("variable_groups", "default_570")
        var_grp2 = copy.deepcopy(var_grp1)
        var_grp3 = self.dr.find_element("variable_groups", "default_569")
        var_2 = self.dr.find_element("variable", "baa71c7c-e5dd-11e5-8482-ac72891c3257")
        var_1 = self.dr.find_element("variable", "83bbfc6e-7f07-11ef-9308-b1dd71e64bec")
        mip_2 = self.dr.find_element("mips", "default_404")
        mip_1 = self.dr.find_element("mips", "default_417")
        prio_2 = self.dr.find_element("priority_level", "default_481")
        prio_1 = self.dr.find_element("priority_level", "default_482")
        max_prio_1 = self.dr.find_element("max_priority_level", "default_482")
        max_prio_2 = self.dr.find_element("max_priority_level", "default_481")
        table_1 = self.dr.find_element("table_identifier", "MIPtable::Oday")
        table_2 = self.dr.find_element("table_identifier", "MIPtable::Omon")
        tshp_1 = self.dr.find_element("temporal_shape", "cf34c974-80be-11e6-97ee-ac72891c3257")
        tshp_2 = self.dr.find_element("temporal_shape", "7a97ae58-8042-11e6-97ee-ac72891c3257")
        sshp_1 = self.dr.find_element("spatial_shape", "a656047a-8883-11e5-b571-ac72891c3257")
        sshp_2 = self.dr.find_element("spatial_shape", "a65615fa-8883-11e5-b571-ac72891c3257")
        str_1 = self.dr.find_element("structure", "link::default_504")
        str_2 = self.dr.find_element("structure", "link::default_513")
        param_1 = self.dr.find_element("physical_parameter", "3e3ddc77800e7d421834b9cb808602d7")
        param_2 = self.dr.find_element("physical_parameter", "00e77372e8b909d9a827a0790e991fd9")
        realm_1 = self.dr.find_element("modelling_realm", "ocean")
        realm_2 = self.dr.find_element("modelling_realm", "atmos")
        bcv_2 = self.dr.find_element("esm-bcv", "link::default_121")
        cf_std_1 = self.dr.find_element("cf_standard_name", "default_65")
        cf_std_2 = self.dr.find_element("cf_standard_name", "default_101")
        cell_method_1 = self.dr.find_element("cell_methods", "CellMethods::amns-fx")
        cell_method_2 = self.dr.find_element("cell_methods", "CellMethods::amnsi-twm")
        cell_measure_1 = self.dr.find_element("cell_measure", "link::default_5")
        cell_measure_2 = self.dr.find_element("cell_measure", "link::default_1")
        obj = DRObjects(id="link::my_id", dr=self.dr)
        self.assertEqual(var_grp1.filter_on_request(var_grp2), (True, True))
        self.assertEqual(var_grp1.filter_on_request(var_grp3), (True, False))
        self.assertEqual(var_grp1.filter_on_request(var_1), (True, True))
        self.assertEqual(var_grp1.filter_on_request(var_2), (True, False))
        self.assertEqual(var_grp1.filter_on_request(mip_1), (True, True))
        self.assertEqual(var_grp1.filter_on_request(mip_2), (True, False))
        self.assertEqual(var_grp1.filter_on_request(prio_1), (True, True))
        self.assertEqual(var_grp1.filter_on_request(prio_2), (True, False))
        self.assertEqual(var_grp1.filter_on_request(max_prio_1), (True, True))
        self.assertEqual(var_grp1.filter_on_request(max_prio_2), (True, False))
        self.assertEqual(var_grp1.filter_on_request(table_1), (True, True))
        self.assertEqual(var_grp1.filter_on_request(table_2), (True, False))
        self.assertEqual(var_grp1.filter_on_request(tshp_1), (True, True))
        self.assertEqual(var_grp1.filter_on_request(tshp_2), (True, False))
        self.assertEqual(var_grp1.filter_on_request(sshp_1), (True, True))
        self.assertEqual(var_grp1.filter_on_request(sshp_2), (True, False))
        self.assertEqual(var_grp1.filter_on_request(str_1), (True, True))
        self.assertEqual(var_grp1.filter_on_request(str_2), (True, False))
        self.assertEqual(var_grp1.filter_on_request(param_1), (True, True))
        self.assertEqual(var_grp1.filter_on_request(param_2), (True, False))
        self.assertEqual(var_grp1.filter_on_request(realm_1), (True, True))
        self.assertEqual(var_grp1.filter_on_request(realm_2), (True, False))
        self.assertEqual(var_grp1.filter_on_request(bcv_2), (True, False))
        self.assertEqual(var_grp1.filter_on_request(cf_std_1), (True, True))
        self.assertEqual(var_grp1.filter_on_request(cf_std_2), (True, False))
        self.assertEqual(var_grp1.filter_on_request(cell_method_1), (True, True))
        self.assertEqual(var_grp1.filter_on_request(cell_method_2), (True, False))
        self.assertEqual(var_grp1.filter_on_request(cell_measure_1), (True, True))
        self.assertEqual(var_grp1.filter_on_request(cell_measure_2), (True, False))
        self.assertEqual(var_grp1.filter_on_request(obj), (False, False))

    def test_print(self):
        obj = VariablesGroup.from_input(id="link::default_575", dr=self.dr, priority_level="Medium",
                                        name="baseline_monthly",
                                        variables=["link::bab3cb52-e5dd-11e5-8482-ac72891c3257",
                                                   "link::bab48ce0-e5dd-11e5-8482-ac72891c3257"])
        ref_str = "variable_group: baseline_monthly (id: default_575)"
        ref_str_2 = [
            ref_str,
            "    Variables included:",
            "        variable: pr at frequency mon (id: bab3cb52-e5dd-11e5-8482-ac72891c3257, title: Precipitation)",
            "        variable: psl at frequency mon (id: bab48ce0-e5dd-11e5-8482-ac72891c3257, "
            "title: Sea Level Pressure)"
        ]
        self.assertEqual(obj.print_content(add_content=False), [ref_str, ])
        self.assertEqual(obj.print_content(level=1, add_content=False), ["    " + ref_str, ])
        self.assertEqual(obj.print_content(), ref_str_2)
        self.assertEqual(obj.print_content(level=1), ["    " + elt for elt in ref_str_2])
        self.assertEqual(str(obj), os.linesep.join(ref_str_2))

    def test_eq(self):
        obj = VariablesGroup(id="link::my_id", dr=self.dr)
        obj2 = copy.deepcopy(obj)
        self.assertEqual(obj, obj2)

        obj3 = VariablesGroup(id="link::my_id_2", dr=self.dr)
        self.assertNotEqual(obj, obj3)

        obj4 = VariablesGroup(id="link::my_id", dr=self.dr, variables=["link::bab3cb52-e5dd-11e5-8482-ac72891c3257",
                                                                       "link::bab48ce0-e5dd-11e5-8482-ac72891c3257"])
        self.assertNotEqual(obj, obj4)

        obj5 = VariablesGroup(id="link::my_id", dr=self.dr, mips=["link::default_401", ])
        self.assertNotEqual(obj, obj5)

        obj6 = VariablesGroup(id="link::my_id", dr=self.dr, priority="Medium")
        self.assertNotEqual(obj, obj6)

        obj7 = DRObjects(id="link::my_id", dr=self.dr)
        self.assertNotEqual(obj, obj7)

A class whose instances are single test cases.

By default, the test code itself should be placed in a method named 'runTest'.

If the fixture may be used for many test cases, create as many test methods as are needed. When instantiating such a TestCase subclass, specify in the constructor arguments the name of the test method that the instance is to execute.

Test authors should subclass TestCase for their own tests. Construction and deconstruction of the test's environment ('fixture') can be implemented by overriding the 'setUp' and 'tearDown' methods respectively.

If it is necessary to override the init method, the base class init method must always be called. It is important that subclasses should not change the signature of their init method, since instances of the classes are instantiated automatically by parts of the framework in order to be run.

When subclassing TestCase, you can set these attributes: * failureException: determines which exception will be raised when the instance's assertion methods fail; test methods raising this exception will be deemed to have 'failed' rather than 'errored'. * longMessage: determines whether long messages (including repr of objects used in assert methods) will be printed on failure in addition to any explicit message passed. * maxDiff: sets the maximum length of a diff in failure messages by assert methods using difflib. It is looked up as an instance attribute so can be configured by individual tests if required.

Create an instance of the class that will use the named test method when executed. Raises a ValueError if the instance does not have a method with the specified name.

Ancestors

  • unittest.case.TestCase

Methods

def setUp(self)
Expand source code
def setUp(self):
    self.dr = DataRequest.from_separated_inputs(DR_input=filepath("one_base_DR_output.json"),
                                                VS_input=filepath("one_base_VS_output.json"))

Hook method for setting up the test fixture before exercising it.

def test_check(self)
Expand source code
def test_check(self):
    obj = VariablesGroup(id="link::my_id", dr=self.dr)
    obj.check()

    obj = VariablesGroup(id="link::my_id", dr=self.dr,
                         variables=["link::bab3cb52-e5dd-11e5-8482-ac72891c3257",
                                    "link::bab48ce0-e5dd-11e5-8482-ac72891c3257"])
    obj.check()
def test_eq(self)
Expand source code
def test_eq(self):
    obj = VariablesGroup(id="link::my_id", dr=self.dr)
    obj2 = copy.deepcopy(obj)
    self.assertEqual(obj, obj2)

    obj3 = VariablesGroup(id="link::my_id_2", dr=self.dr)
    self.assertNotEqual(obj, obj3)

    obj4 = VariablesGroup(id="link::my_id", dr=self.dr, variables=["link::bab3cb52-e5dd-11e5-8482-ac72891c3257",
                                                                   "link::bab48ce0-e5dd-11e5-8482-ac72891c3257"])
    self.assertNotEqual(obj, obj4)

    obj5 = VariablesGroup(id="link::my_id", dr=self.dr, mips=["link::default_401", ])
    self.assertNotEqual(obj, obj5)

    obj6 = VariablesGroup(id="link::my_id", dr=self.dr, priority="Medium")
    self.assertNotEqual(obj, obj6)

    obj7 = DRObjects(id="link::my_id", dr=self.dr)
    self.assertNotEqual(obj, obj7)
def test_filter_on_request(self)
Expand source code
def test_filter_on_request(self):
    var_grp1 = self.dr.find_element("variable_groups", "default_570")
    var_grp2 = copy.deepcopy(var_grp1)
    var_grp3 = self.dr.find_element("variable_groups", "default_569")
    var_2 = self.dr.find_element("variable", "baa71c7c-e5dd-11e5-8482-ac72891c3257")
    var_1 = self.dr.find_element("variable", "83bbfc6e-7f07-11ef-9308-b1dd71e64bec")
    mip_2 = self.dr.find_element("mips", "default_404")
    mip_1 = self.dr.find_element("mips", "default_417")
    prio_2 = self.dr.find_element("priority_level", "default_481")
    prio_1 = self.dr.find_element("priority_level", "default_482")
    max_prio_1 = self.dr.find_element("max_priority_level", "default_482")
    max_prio_2 = self.dr.find_element("max_priority_level", "default_481")
    table_1 = self.dr.find_element("table_identifier", "MIPtable::Oday")
    table_2 = self.dr.find_element("table_identifier", "MIPtable::Omon")
    tshp_1 = self.dr.find_element("temporal_shape", "cf34c974-80be-11e6-97ee-ac72891c3257")
    tshp_2 = self.dr.find_element("temporal_shape", "7a97ae58-8042-11e6-97ee-ac72891c3257")
    sshp_1 = self.dr.find_element("spatial_shape", "a656047a-8883-11e5-b571-ac72891c3257")
    sshp_2 = self.dr.find_element("spatial_shape", "a65615fa-8883-11e5-b571-ac72891c3257")
    str_1 = self.dr.find_element("structure", "link::default_504")
    str_2 = self.dr.find_element("structure", "link::default_513")
    param_1 = self.dr.find_element("physical_parameter", "3e3ddc77800e7d421834b9cb808602d7")
    param_2 = self.dr.find_element("physical_parameter", "00e77372e8b909d9a827a0790e991fd9")
    realm_1 = self.dr.find_element("modelling_realm", "ocean")
    realm_2 = self.dr.find_element("modelling_realm", "atmos")
    bcv_2 = self.dr.find_element("esm-bcv", "link::default_121")
    cf_std_1 = self.dr.find_element("cf_standard_name", "default_65")
    cf_std_2 = self.dr.find_element("cf_standard_name", "default_101")
    cell_method_1 = self.dr.find_element("cell_methods", "CellMethods::amns-fx")
    cell_method_2 = self.dr.find_element("cell_methods", "CellMethods::amnsi-twm")
    cell_measure_1 = self.dr.find_element("cell_measure", "link::default_5")
    cell_measure_2 = self.dr.find_element("cell_measure", "link::default_1")
    obj = DRObjects(id="link::my_id", dr=self.dr)
    self.assertEqual(var_grp1.filter_on_request(var_grp2), (True, True))
    self.assertEqual(var_grp1.filter_on_request(var_grp3), (True, False))
    self.assertEqual(var_grp1.filter_on_request(var_1), (True, True))
    self.assertEqual(var_grp1.filter_on_request(var_2), (True, False))
    self.assertEqual(var_grp1.filter_on_request(mip_1), (True, True))
    self.assertEqual(var_grp1.filter_on_request(mip_2), (True, False))
    self.assertEqual(var_grp1.filter_on_request(prio_1), (True, True))
    self.assertEqual(var_grp1.filter_on_request(prio_2), (True, False))
    self.assertEqual(var_grp1.filter_on_request(max_prio_1), (True, True))
    self.assertEqual(var_grp1.filter_on_request(max_prio_2), (True, False))
    self.assertEqual(var_grp1.filter_on_request(table_1), (True, True))
    self.assertEqual(var_grp1.filter_on_request(table_2), (True, False))
    self.assertEqual(var_grp1.filter_on_request(tshp_1), (True, True))
    self.assertEqual(var_grp1.filter_on_request(tshp_2), (True, False))
    self.assertEqual(var_grp1.filter_on_request(sshp_1), (True, True))
    self.assertEqual(var_grp1.filter_on_request(sshp_2), (True, False))
    self.assertEqual(var_grp1.filter_on_request(str_1), (True, True))
    self.assertEqual(var_grp1.filter_on_request(str_2), (True, False))
    self.assertEqual(var_grp1.filter_on_request(param_1), (True, True))
    self.assertEqual(var_grp1.filter_on_request(param_2), (True, False))
    self.assertEqual(var_grp1.filter_on_request(realm_1), (True, True))
    self.assertEqual(var_grp1.filter_on_request(realm_2), (True, False))
    self.assertEqual(var_grp1.filter_on_request(bcv_2), (True, False))
    self.assertEqual(var_grp1.filter_on_request(cf_std_1), (True, True))
    self.assertEqual(var_grp1.filter_on_request(cf_std_2), (True, False))
    self.assertEqual(var_grp1.filter_on_request(cell_method_1), (True, True))
    self.assertEqual(var_grp1.filter_on_request(cell_method_2), (True, False))
    self.assertEqual(var_grp1.filter_on_request(cell_measure_1), (True, True))
    self.assertEqual(var_grp1.filter_on_request(cell_measure_2), (True, False))
    self.assertEqual(var_grp1.filter_on_request(obj), (False, False))
def test_from_input(self)
Expand source code
def test_from_input(self):
    with self.assertRaises(TypeError):
        VariablesGroup.from_input()

    with self.assertRaises(TypeError):
        VariablesGroup.from_input("link::my_id")

    with self.assertRaises(TypeError):
        VariablesGroup.from_input(self.dr)

    obj = VariablesGroup.from_input(id="link::my_id", dr=self.dr)

    with self.assertRaises(ValueError):
        obj = VariablesGroup.from_input(id="link:my_id", dr=self.dr, variables=["link::test", ])

    obj = VariablesGroup.from_input(id="link::my_id", dr=self.dr,
                                    variables=["link::bab3cb52-e5dd-11e5-8482-ac72891c3257",
                                               "link::bab48ce0-e5dd-11e5-8482-ac72891c3257"])
def test_init(self)
Expand source code
def test_init(self):
    with self.assertRaises(TypeError):
        VariablesGroup()

    with self.assertRaises(TypeError):
        VariablesGroup("link::my_id")

    with self.assertRaises(TypeError):
        VariablesGroup(self.dr)

    obj = VariablesGroup("link::my_id", self.dr)
    self.assertEqual(obj.DR_type, "variable_groups")

    with self.assertRaises(ValueError):
        VariablesGroup("link::my_id", self.dr, name="test", physical_parameter="link::my_link")
def test_methods(self)
Expand source code
def test_methods(self):
    obj = VariablesGroup.from_input(id="link::my_id", dr=self.dr, priority_level="High")
    self.assertEqual(obj.count(), 0)
    self.assertEqual(obj.get_variables(), list())
    self.assertEqual(obj.get_mips(), list())
    self.assertEqual(obj.get_priority_level(), self.dr.find_element("priority_level", "High"))

    obj = VariablesGroup.from_input(id="link::dafc7484-8c95-11ef-944e-41a8eb05f654", dr=self.dr,
                                    variables=["link::bab3cb52-e5dd-11e5-8482-ac72891c3257",
                                               "link::bab48ce0-e5dd-11e5-8482-ac72891c3257"],
                                    mips=["link::default_401", ], priority_level="High")
    self.assertEqual(obj.count(), 2)
    self.assertListEqual(obj.get_variables(),
                         [self.dr.find_element("variables", "link::bab3cb52-e5dd-11e5-8482-ac72891c3257"),
                          self.dr.find_element("variables", "link::bab48ce0-e5dd-11e5-8482-ac72891c3257")])
    self.assertEqual(obj.get_mips(), [self.dr.find_element("mips", "link::default_401")])
    self.assertDictEqual(obj.get_priority_level().attributes,
                         {'name': "High", "notes": "High priority should be used sparingly", "value": 1,
                          'id': "default_481"})
def test_print(self)
Expand source code
def test_print(self):
    obj = VariablesGroup.from_input(id="link::default_575", dr=self.dr, priority_level="Medium",
                                    name="baseline_monthly",
                                    variables=["link::bab3cb52-e5dd-11e5-8482-ac72891c3257",
                                               "link::bab48ce0-e5dd-11e5-8482-ac72891c3257"])
    ref_str = "variable_group: baseline_monthly (id: default_575)"
    ref_str_2 = [
        ref_str,
        "    Variables included:",
        "        variable: pr at frequency mon (id: bab3cb52-e5dd-11e5-8482-ac72891c3257, title: Precipitation)",
        "        variable: psl at frequency mon (id: bab48ce0-e5dd-11e5-8482-ac72891c3257, "
        "title: Sea Level Pressure)"
    ]
    self.assertEqual(obj.print_content(add_content=False), [ref_str, ])
    self.assertEqual(obj.print_content(level=1, add_content=False), ["    " + ref_str, ])
    self.assertEqual(obj.print_content(), ref_str_2)
    self.assertEqual(obj.print_content(level=1), ["    " + elt for elt in ref_str_2])
    self.assertEqual(str(obj), os.linesep.join(ref_str_2))