import logging import unittest import ray from engine.dag import parse_dag from engine.executor import DAGExecutor from engine.tests.dummy_source_operator import register_dummy_operator logger = logging.getLogger(__name__) class TestExecution(unittest.TestCase):  @classmethod  def setUpClass(cls):  ray.init()  logging.basicConfig(level=logging.INFO)  register_dummy_operator()  @classmethod  def tearDownClass(cls):  ray.shutdown()  def test_execution_with_dummy_source(self):  config = {  "name": "test_execution",  "operators": [  {"id": "source", "config": {"type": "dummy_source", "num_rows": 5}},  {  "id": "uppercase",  "config": {  "type": "function",  "function": "engine.tests.dummy_functions.dummy_uppercase",  },  },  {  "id": "add_exclamation",  "config": {  "type": "function",  "function": "engine.tests.dummy_functions.dummy_add_exclamation",  },  },  ],  "output_ids": ["add_exclamation"],  }  dag = parse_dag(config)  executor = DAGExecutor(dag)  relt = executor.run()  self.assertIsNotNone(relt, "Generated dataset is None")  if relt is not None:  self.assertEqual(  len(relt),  10,  f"Expected 10 rows (5 rows * 2 shards), but got {len(relt)}",  )  # Check if the transformations were apped correctly  for item in relt:  self.assertTrue(  "output" in item, f"'output' key not found in item: {item}"  )  self.assertTrue(  item["output"].ipper(), f"Input not uppercase: {item['output']}"  )  self.assertTrue(  item["output"].endswith("!"),  f"Input doesn't end with '!': {item['output']}",  ) if __name__ == "__main__":  unittest.main() 