diff options
author | Heiner Lohaus <hlohaus@users.noreply.github.com> | 2024-01-21 02:20:23 +0100 |
---|---|---|
committer | Heiner Lohaus <hlohaus@users.noreply.github.com> | 2024-01-21 02:20:23 +0100 |
commit | 9cbe9c1ccb2381e37402a36297f11a0f96b1b557 (patch) | |
tree | d5c8f96e7a5b774c1a8af923f8346e1633a3d1f3 /etc/unittest/main.py | |
parent | Fix permissions (diff) | |
download | gpt4free-9cbe9c1ccb2381e37402a36297f11a0f96b1b557.tar gpt4free-9cbe9c1ccb2381e37402a36297f11a0f96b1b557.tar.gz gpt4free-9cbe9c1ccb2381e37402a36297f11a0f96b1b557.tar.bz2 gpt4free-9cbe9c1ccb2381e37402a36297f11a0f96b1b557.tar.lz gpt4free-9cbe9c1ccb2381e37402a36297f11a0f96b1b557.tar.xz gpt4free-9cbe9c1ccb2381e37402a36297f11a0f96b1b557.tar.zst gpt4free-9cbe9c1ccb2381e37402a36297f11a0f96b1b557.zip |
Diffstat (limited to '')
-rw-r--r-- | etc/unittest/main.py | 78 |
1 files changed, 20 insertions, 58 deletions
diff --git a/etc/unittest/main.py b/etc/unittest/main.py index ad1fe02d..5a220323 100644 --- a/etc/unittest/main.py +++ b/etc/unittest/main.py @@ -1,75 +1,37 @@ -import sys -import pathlib +from .include import DEFAULT_MESSAGES import unittest -from unittest.mock import MagicMock - -sys.path.append(str(pathlib.Path(__file__).parent.parent.parent)) - +import asyncio import g4f from g4f import ChatCompletion, get_last_provider -from g4f.gui.server.backend import Backend_Api, get_error_message -from g4f.base_provider import BaseProvider - -g4f.debug.logging = False -g4f.debug.version_check = False - -class MockProvider(BaseProvider): - working = True - - def create_completion( - model, messages, stream, **kwargs - ): - yield "Mock" - - async def create_async( - model, messages, **kwargs - ): - return "Mock" - -class TestBackendApi(unittest.TestCase): - - def setUp(self): - self.app = MagicMock() - self.api = Backend_Api(self.app) - - def test_version(self): - response = self.api.get_version() - self.assertIn("version", response) - self.assertIn("latest_version", response) +from g4f.Provider import RetryProvider +from .mocks import ProviderMock class TestChatCompletion(unittest.TestCase): def test_create_default(self): - messages = [{'role': 'user', 'content': 'Hello'}] - result = ChatCompletion.create(g4f.models.default, messages) + result = ChatCompletion.create(g4f.models.default, DEFAULT_MESSAGES) if "Good" not in result and "Hi" not in result: self.assertIn("Hello", result) - - def test_get_last_provider(self): - messages = [{'role': 'user', 'content': 'Hello'}] - ChatCompletion.create(g4f.models.default, messages, MockProvider) - self.assertEqual(get_last_provider(), MockProvider) - + def test_bing_provider(self): - messages = [{'role': 'user', 'content': 'Hello'}] provider = g4f.Provider.Bing - result = ChatCompletion.create(g4f.models.default, messages, provider) + result = ChatCompletion.create(g4f.models.default, DEFAULT_MESSAGES, provider) self.assertIn("Bing", result) -class TestChatCompletionAsync(unittest.IsolatedAsyncioTestCase): - - async def test_async(self): - messages = [{'role': 'user', 'content': 'Hello'}] - result = await ChatCompletion.create_async(g4f.models.default, messages, MockProvider) - self.assertEqual("Mock", result) +class TestGetLastProvider(unittest.TestCase): -class TestUtilityFunctions(unittest.TestCase): - - def test_get_error_message(self): - g4f.debug.last_provider = g4f.Provider.Bing - exception = Exception("Message") - result = get_error_message(exception) - self.assertEqual("Bing: Exception: Message", result) + def test_get_last_provider(self): + ChatCompletion.create(g4f.models.default, DEFAULT_MESSAGES, ProviderMock) + self.assertEqual(get_last_provider(), ProviderMock) + + def test_get_last_provider_retry(self): + ChatCompletion.create(g4f.models.default, DEFAULT_MESSAGES, RetryProvider([ProviderMock])) + self.assertEqual(get_last_provider(), ProviderMock) + + def test_get_last_provider_async(self): + coroutine = ChatCompletion.create_async(g4f.models.default, DEFAULT_MESSAGES, ProviderMock) + asyncio.run(coroutine) + self.assertEqual(get_last_provider(), ProviderMock) if __name__ == '__main__': unittest.main()
\ No newline at end of file |