summaryrefslogtreecommitdiffstats
path: root/testing/test_providers.py
diff options
context:
space:
mode:
authorabc <98614666+xtekky@users.noreply.github.com>2023-10-06 20:51:36 +0200
committerabc <98614666+xtekky@users.noreply.github.com>2023-10-06 20:51:36 +0200
commitfdd8ef1fc3741ac9472b3f9f6e46cf65827566aa (patch)
treeff5efeecf9dd91e1b74b98ca21671e315cf61979 /testing/test_providers.py
parent~ | Merge pull request #997 from hlohaus/all (diff)
downloadgpt4free-fdd8ef1fc3741ac9472b3f9f6e46cf65827566aa.tar
gpt4free-fdd8ef1fc3741ac9472b3f9f6e46cf65827566aa.tar.gz
gpt4free-fdd8ef1fc3741ac9472b3f9f6e46cf65827566aa.tar.bz2
gpt4free-fdd8ef1fc3741ac9472b3f9f6e46cf65827566aa.tar.lz
gpt4free-fdd8ef1fc3741ac9472b3f9f6e46cf65827566aa.tar.xz
gpt4free-fdd8ef1fc3741ac9472b3f9f6e46cf65827566aa.tar.zst
gpt4free-fdd8ef1fc3741ac9472b3f9f6e46cf65827566aa.zip
Diffstat (limited to 'testing/test_providers.py')
-rw-r--r--testing/test_providers.py66
1 files changed, 0 insertions, 66 deletions
diff --git a/testing/test_providers.py b/testing/test_providers.py
deleted file mode 100644
index ec0e0271..00000000
--- a/testing/test_providers.py
+++ /dev/null
@@ -1,66 +0,0 @@
-import sys
-from pathlib import Path
-from colorama import Fore, Style
-
-sys.path.append(str(Path(__file__).parent.parent))
-
-from g4f import BaseProvider, models, Provider
-
-logging = False
-
-
-def main():
- providers = get_providers()
- failed_providers = []
-
- for _provider in providers:
- if _provider.needs_auth:
- continue
- print("Provider:", _provider.__name__)
- result = test(_provider)
- print("Result:", result)
- if _provider.working and not result:
- failed_providers.append(_provider)
-
- print()
-
- if failed_providers:
- print(f"{Fore.RED + Style.BRIGHT}Failed providers:{Style.RESET_ALL}")
- for _provider in failed_providers:
- print(f"{Fore.RED}{_provider.__name__}")
- else:
- print(f"{Fore.GREEN + Style.BRIGHT}All providers are working")
-
-
-def get_providers() -> list[type[BaseProvider]]:
- providers = dir(Provider)
- providers = [getattr(Provider, provider) for provider in providers if provider != "RetryProvider"]
- providers = [provider for provider in providers if isinstance(provider, type)]
- return [provider for provider in providers if issubclass(provider, BaseProvider)]
-
-
-def create_response(_provider: type[BaseProvider]) -> str:
- model = models.gpt_35_turbo.name if _provider.supports_gpt_35_turbo else models.default.name
- response = _provider.create_completion(
- model=model,
- messages=[{"role": "user", "content": "Hello, who are you? Answer in detail much as possible."}],
- stream=False,
- )
- return "".join(response)
-
-
-def test(_provider: type[BaseProvider]) -> bool:
- try:
- response = create_response(_provider)
- assert type(response) is str
- assert len(response) > 0
- return response
- except Exception as e:
- if logging:
- print(e)
- return False
-
-
-if __name__ == "__main__":
- main()
- \ No newline at end of file