import unittest from typing import Any, Union, Tuple, Dict, List from meow_base.core.base_conductor import BaseConductor from meow_base.core.base_handler import BaseHandler from meow_base.core.base_monitor import BaseMonitor from meow_base.core.base_pattern import BasePattern from meow_base.core.base_recipe import BaseRecipe from meow_base.core.vars import SWEEP_STOP, SWEEP_JUMP, SWEEP_START from meow_base.patterns.file_event_pattern import FileEventPattern from shared import setup, teardown class BaseRecipeTests(unittest.TestCase): def setUp(self)->None: super().setUp() setup() def tearDown(self)->None: super().tearDown() teardown() # Test that BaseRecipe instantiation def testBaseRecipe(self)->None: with self.assertRaises(TypeError): BaseRecipe("name", "") class NewRecipe(BaseRecipe): pass with self.assertRaises(NotImplementedError): NewRecipe("name", "") class FullRecipe(BaseRecipe): def _is_valid_recipe(self, recipe:Any)->None: pass def _is_valid_parameters(self, parameters:Any)->None: pass def _is_valid_requirements(self, requirements:Any)->None: pass FullRecipe("name", "") class BasePatternTests(unittest.TestCase): def setUp(self)->None: super().setUp() setup() def tearDown(self)->None: super().tearDown() teardown() # Test that BaseRecipe instantiation def testBasePattern(self)->None: with self.assertRaises(TypeError): BasePattern("name", "", "", "") class NewPattern(BasePattern): pass with self.assertRaises(NotImplementedError): NewPattern("name", "", "", "") class FullPattern(BasePattern): def _is_valid_recipe(self, recipe:Any)->None: pass def _is_valid_parameters(self, parameters:Any)->None: pass def _is_valid_output(self, outputs:Any)->None: pass def _is_valid_sweep(self, sweep:Dict[str,Union[int,float,complex]])->None: pass FullPattern("name", "", "", "", "") # Test expansion of parameter sweeps def testBasePatternExpandSweeps(self)->None: pattern_one = FileEventPattern( "pattern_one", "A", "recipe_one", "file_one", sweep={ "s1":{ SWEEP_START: 10, SWEEP_STOP: 20, SWEEP_JUMP:5 } }) es = pattern_one.expand_sweeps() self.assertIsInstance(es, list) self.assertEqual(len(es), 3) values = [ "s1-10", "s1-15", "s1-20", ] for sweep_vals in es: self.assertIsInstance(sweep_vals, tuple) self.assertEqual(len(sweep_vals), 1) val1 = None for sweep_val in sweep_vals: self.assertIsInstance(sweep_val, tuple) self.assertEqual(len(sweep_val), 2) if sweep_val[0] == "s1": val1 = f"s1-{sweep_val[1]}" if val1: values.remove(val1) self.assertEqual(len(values), 0) pattern_one = FileEventPattern( "pattern_one", "A", "recipe_one", "file_one", sweep={ "s1":{ SWEEP_START: 0, SWEEP_STOP: 2, SWEEP_JUMP:1 }, "s2":{ SWEEP_START: 20, SWEEP_STOP: 80, SWEEP_JUMP:15 } }) es = pattern_one.expand_sweeps() self.assertIsInstance(es, list) self.assertEqual(len(es), 15) values = [ "s1-0/s2-20", "s1-1/s2-20", "s1-2/s2-20", "s1-0/s2-35", "s1-1/s2-35", "s1-2/s2-35", "s1-0/s2-50", "s1-1/s2-50", "s1-2/s2-50", "s1-0/s2-65", "s1-1/s2-65", "s1-2/s2-65", "s1-0/s2-80", "s1-1/s2-80", "s1-2/s2-80", ] for sweep_vals in es: self.assertIsInstance(sweep_vals, tuple) self.assertEqual(len(sweep_vals), 2) val1 = None val2 = None for sweep_val in sweep_vals: self.assertIsInstance(sweep_val, tuple) self.assertEqual(len(sweep_val), 2) if sweep_val[0] == "s1": val1 = f"s1-{sweep_val[1]}" if sweep_val[0] == "s2": val2 = f"s2-{sweep_val[1]}" if val1 and val2: values.remove(f"{val1}/{val2}") self.assertEqual(len(values), 0) # TODO test for base functions class BaseMonitorTests(unittest.TestCase): def setUp(self)->None: super().setUp() setup() def tearDown(self)->None: super().tearDown() teardown() # Test that BaseMonitor instantiation def testBaseMonitor(self)->None: with self.assertRaises(TypeError): BaseMonitor({}, {}) class TestMonitor(BaseMonitor): pass with self.assertRaises(NotImplementedError): TestMonitor({}, {}) class FullTestMonitor(BaseMonitor): def start(self): pass def stop(self): pass def _get_valid_pattern_types(self)->List[type]: return [BasePattern] def _get_valid_recipe_types(self)->List[type]: return [BaseRecipe] FullTestMonitor({}, {}) # TODO test for base functions class BaseHandleTests(unittest.TestCase): def setUp(self)->None: super().setUp() setup() def tearDown(self)->None: super().tearDown() teardown() # Test that BaseHandler instantiation def testBaseHandler(self)->None: with self.assertRaises(TypeError): BaseHandler() class TestHandler(BaseHandler): pass with self.assertRaises(NotImplementedError): TestHandler() class FullTestHandler(BaseHandler): def valid_handle_criteria(self, event:Dict[str,Any] )->Tuple[bool,str]: pass def get_created_job_type(self)->str: pass def create_job_recipe_file(self, job_dir:str, event:Dict[str,Any], params_dict:Dict[str,Any])->str: pass FullTestHandler() # TODO test for base functions class BaseConductorTests(unittest.TestCase): def setUp(self)->None: super().setUp() setup() def tearDown(self)->None: super().tearDown() teardown() # Test that BaseConductor instantiation def testBaseConductor(self)->None: with self.assertRaises(TypeError): BaseConductor() class TestConductor(BaseConductor): pass with self.assertRaises(NotImplementedError): TestConductor() class FullTestConductor(BaseConductor): def valid_execute_criteria(self, job:Dict[str,Any] )->Tuple[bool,str]: pass FullTestConductor()