from compass.io import symlink, package_path
from compass.validate import compare_variables
from compass.landice.tests.enthalpy_benchmark.setup_mesh import SetupMesh
from compass.landice.tests.enthalpy_benchmark.run_model import RunModel
from compass.landice.tests.enthalpy_benchmark.A.visualize import Visualize
from compass.testcase import TestCase
[docs]class A(TestCase):
    """
    The Kleiner enthalpy benchmark test case A
    Attributes
    ----------
    """
[docs]    def __init__(self, test_group):
        """
        Create the test case
        Parameters
        ----------
        test_group : compass.landice.tests.enthalpy_benchmark.EnthalpyBenchmark
            The test group that this test case belongs to
        """
        super().__init__(test_group=test_group, name='A')
        module = self.__module__
        self.add_step(
            SetupMesh(test_case=self))
        restart_filenames = ['../setup_mesh/landice_grid.nc',
                             '../phase1/restart.100000.nc',
                             '../phase2/restart.150000.nc']
        for index, restart_filename in enumerate(restart_filenames):
            name = 'phase{}'.format(index+1)
            step = RunModel(test_case=self, ntasks=1, openmp_threads=1,
                            name=name, subdir=name,
                            restart_filename=restart_filename)
            suffix = 'landice{}'.format(index+1)
            step.add_namelist_file(module, 'namelist.{}'.format(suffix))
            step.add_streams_file(module, 'streams.{}'.format(suffix))
            self.add_step(step)
        self.add_step(
            Visualize(test_case=self)) 
    # no run() method is needed
    def validate(self):
        """
        Test cases can override this method to perform validation of variables
        and timers
        """
        variables = ['temperature', 'basalWaterThickness',
                     'groundedBasalMassBal']
        compare_variables(test_case=self, variables=variables,
                          filename1='phase3/output.nc')