test_openai_whisper.py 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. import json
  2. import os
  3. from unittest.mock import patch
  4. from core.model_providers.models.speech2text.openai_whisper import OpenAIWhisper
  5. from core.model_providers.providers.openai_provider import OpenAIProvider
  6. from models.provider import Provider, ProviderType
  7. def get_mock_provider(valid_openai_api_key):
  8. return Provider(
  9. id='provider_id',
  10. tenant_id='tenant_id',
  11. provider_name='openai',
  12. provider_type=ProviderType.CUSTOM.value,
  13. encrypted_config=json.dumps({'openai_api_key': valid_openai_api_key}),
  14. is_valid=True,
  15. )
  16. def get_mock_openai_whisper_model():
  17. model_name = 'whisper-1'
  18. valid_openai_api_key = os.environ['OPENAI_API_KEY']
  19. openai_provider = OpenAIProvider(provider=get_mock_provider(valid_openai_api_key))
  20. return OpenAIWhisper(
  21. model_provider=openai_provider,
  22. name=model_name
  23. )
  24. def decrypt_side_effect(tenant_id, encrypted_openai_api_key):
  25. return encrypted_openai_api_key
  26. @patch('core.helper.encrypter.decrypt_token', side_effect=decrypt_side_effect)
  27. def test_run(mock_decrypt):
  28. # Get the directory of the current file
  29. current_dir = os.path.dirname(os.path.abspath(__file__))
  30. # Construct the path to the audio file
  31. audio_file_path = os.path.join(current_dir, 'audio.mp3')
  32. model = get_mock_openai_whisper_model()
  33. # Open the file and get the file object
  34. with open(audio_file_path, 'rb') as audio_file:
  35. rst = model.run(audio_file)
  36. assert isinstance(rst, dict)
  37. assert rst['text'] == '1, 2, 3, 4, 5, 6, 7, 8, 9, 10'