| 
									
										
										
										
											2024-08-12 21:38:59 +08:00
										 |  |  | import os | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import pytest | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | from core.model_runtime.errors.validate import CredentialsValidateFailedError | 
					
						
							|  |  |  | from core.model_runtime.model_providers.siliconflow.speech2text.speech2text import SiliconflowSpeech2TextModel | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def test_validate_credentials(): | 
					
						
							|  |  |  |     model = SiliconflowSpeech2TextModel() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     with pytest.raises(CredentialsValidateFailedError): | 
					
						
							|  |  |  |         model.validate_credentials( | 
					
						
							|  |  |  |             model="iic/SenseVoiceSmall", | 
					
						
							| 
									
										
										
										
											2024-08-23 23:52:25 +08:00
										 |  |  |             credentials={"api_key": "invalid_key"}, | 
					
						
							| 
									
										
										
										
											2024-08-12 21:38:59 +08:00
										 |  |  |         ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     model.validate_credentials( | 
					
						
							|  |  |  |         model="iic/SenseVoiceSmall", | 
					
						
							| 
									
										
										
										
											2024-08-23 23:52:25 +08:00
										 |  |  |         credentials={"api_key": os.environ.get("API_KEY")}, | 
					
						
							| 
									
										
										
										
											2024-08-12 21:38:59 +08:00
										 |  |  |     ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def test_invoke_model(): | 
					
						
							|  |  |  |     model = SiliconflowSpeech2TextModel() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     # Get the directory of the current file | 
					
						
							|  |  |  |     current_dir = os.path.dirname(os.path.abspath(__file__)) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     # Get assets directory | 
					
						
							|  |  |  |     assets_dir = os.path.join(os.path.dirname(current_dir), "assets") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     # Construct the path to the audio file | 
					
						
							|  |  |  |     audio_file_path = os.path.join(assets_dir, "audio.mp3") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     # Open the file and get the file object | 
					
						
							|  |  |  |     with open(audio_file_path, "rb") as audio_file: | 
					
						
							|  |  |  |         file = audio_file | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         result = model.invoke( | 
					
						
							| 
									
										
										
										
											2024-08-23 23:52:25 +08:00
										 |  |  |             model="iic/SenseVoiceSmall", credentials={"api_key": os.environ.get("API_KEY")}, file=file | 
					
						
							| 
									
										
										
										
											2024-08-12 21:38:59 +08:00
										 |  |  |         ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         assert isinstance(result, str) | 
					
						
							| 
									
										
										
										
											2024-08-23 23:52:25 +08:00
										 |  |  |         assert result == "1,2,3,4,5,6,7,8,9,10." |