diff options
author | abc <98614666+xtekky@users.noreply.github.com> | 2023-10-16 01:49:30 +0200 |
---|---|---|
committer | abc <98614666+xtekky@users.noreply.github.com> | 2023-10-16 01:49:30 +0200 |
commit | 8bce9ace2d9ffc4212869865b951d1c78e5ecbf4 (patch) | |
tree | bc81172d3823ce91824ce16d9a2022d0047bd380 /etc/testing/test_providers.py | |
parent | ~ (diff) | |
download | gpt4free-0.1.6.5.tar gpt4free-0.1.6.5.tar.gz gpt4free-0.1.6.5.tar.bz2 gpt4free-0.1.6.5.tar.lz gpt4free-0.1.6.5.tar.xz gpt4free-0.1.6.5.tar.zst gpt4free-0.1.6.5.zip |
Diffstat (limited to 'etc/testing/test_providers.py')
-rw-r--r-- | etc/testing/test_providers.py | 127 |
1 files changed, 30 insertions, 97 deletions
diff --git a/etc/testing/test_providers.py b/etc/testing/test_providers.py index 4ba3a5b4..0eaad3e8 100644 --- a/etc/testing/test_providers.py +++ b/etc/testing/test_providers.py @@ -1,99 +1,32 @@ -# from g4f.Provider import __all__, ProviderUtils -# from g4f import ChatCompletion -# import concurrent.futures - -# _ = [ -# 'BaseProvider', -# 'AsyncProvider', -# 'AsyncGeneratorProvider', -# 'RetryProvider' -# ] - -# def test_provider(provider): -# try: -# provider = (ProviderUtils.convert[provider]) -# if provider.working and not provider.needs_auth: -# print('testing', provider.__name__) -# completion = ChatCompletion.create(model='gpt-3.5-turbo', -# messages=[{"role": "user", "content": "hello"}], provider=provider) -# return completion, provider.__name__ -# except Exception as e: -# #print(f'Failed to test provider: {provider} | {e}') -# return None - -# with concurrent.futures.ThreadPoolExecutor() as executor: -# futures = [] -# for provider in __all__: -# if provider not in _: -# futures.append(executor.submit(test_provider, provider)) -# for future in concurrent.futures.as_completed(futures): -# result = future.result() -# if result: -# print(f'{result[1]} | {result[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: +from g4f.Provider import __all__, ProviderUtils +from g4f import ChatCompletion +import concurrent.futures + +_ = [ + 'BaseProvider', + 'AsyncProvider', + 'AsyncGeneratorProvider', + 'RetryProvider' +] + +def test_provider(provider): try: - response = create_response(_provider) - assert type(response) is str - assert len(response) > 0 - return response + provider = (ProviderUtils.convert[provider]) + if provider.working and not provider.needs_auth: + print('testing', provider.__name__) + completion = ChatCompletion.create(model='gpt-3.5-turbo', + messages=[{"role": "user", "content": "hello"}], provider=provider) + return completion, provider.__name__ except Exception as e: - if logging: - print(e) - return False - - -if __name__ == "__main__": - main() -
\ No newline at end of file + #print(f'Failed to test provider: {provider} | {e}') + return None + +with concurrent.futures.ThreadPoolExecutor() as executor: + futures = [] + for provider in __all__: + if provider not in _: + futures.append(executor.submit(test_provider, provider)) + for future in concurrent.futures.as_completed(futures): + result = future.result() + if result: + print(f'{result[1]} | {result[0]}')
\ No newline at end of file |