|
2 | 2 | Tests for LLMEnsemble in openevolve.llm.ensemble |
3 | 3 | """ |
4 | 4 |
|
| 5 | +from typing import Any, Dict, List |
5 | 6 | import unittest |
6 | 7 | from openevolve.llm.ensemble import LLMEnsemble |
7 | 8 | from openevolve.config import LLMModelConfig |
8 | | - |
| 9 | +from openevolve.llm.base import LLMInterface |
9 | 10 |
|
10 | 11 | class TestLLMEnsemble(unittest.TestCase): |
11 | 12 | def test_weighted_sampling(self): |
@@ -34,5 +35,32 @@ def test_weighted_sampling(self): |
34 | 35 | self.assertEqual(len(sampled_models), len(models)) |
35 | 36 |
|
36 | 37 |
|
| 38 | + |
| 39 | +class TestEnsembleInit(unittest.TestCase): |
| 40 | + class MyCustomLLM(LLMInterface): |
| 41 | + def __init__(self, model, some_field): |
| 42 | + self.model = model |
| 43 | + self.some_field = some_field |
| 44 | + |
| 45 | + async def generate(self, prompt: str, **kwargs) -> str: |
| 46 | + return "custom-generate" |
| 47 | + |
| 48 | + async def generate_with_context(self, system_message: str, messages: List[Dict[str, str]], **kwargs) -> str: |
| 49 | + return "custom-generate-with-context" |
| 50 | + |
| 51 | + def init_custom_llm(self, model_cfg): |
| 52 | + return self.MyCustomLLM(model=model_cfg.name, some_field="value") |
| 53 | + |
| 54 | + def test_ensemble_initialization(self): |
| 55 | + models = [ |
| 56 | + LLMModelConfig(name="a"), |
| 57 | + LLMModelConfig(name="b", init_client=self.init_custom_llm), |
| 58 | + ] |
| 59 | + ensemble = LLMEnsemble(models) |
| 60 | + self.assertEqual(len(ensemble.models), len(models)) |
| 61 | + self.assertEqual(ensemble.models[0].model, "a") |
| 62 | + self.assertEqual(ensemble.models[1].model, "b") |
| 63 | + self.assertEqual(ensemble.models[1].some_field, "value") |
| 64 | + |
37 | 65 | if __name__ == "__main__": |
38 | 66 | unittest.main() |
0 commit comments