|
|
|
from unittest.mock import patch
|
|
|
|
|
|
|
|
from swarms.models.mistral import Mistral
|
|
|
|
|
|
|
|
|
|
|
|
def test_mistral_initialization():
|
|
|
|
mistral = Mistral(device="cpu")
|
|
|
|
assert isinstance(mistral, Mistral)
|
|
|
|
assert mistral.ai_name == "Node Model Agent"
|
|
|
|
assert mistral.system_prompt is None
|
|
|
|
assert mistral.model_name == "mistralai/Mistral-7B-v0.1"
|
|
|
|
assert mistral.device == "cpu"
|
|
|
|
assert mistral.use_flash_attention is False
|
|
|
|
assert mistral.temperature == 1.0
|
|
|
|
assert mistral.max_length == 100
|
|
|
|
assert mistral.history == []
|
|
|
|
|
|
|
|
|
|
|
|
@patch("your_module.AutoModelForCausalLM.from_pretrained")
|
|
|
|
@patch("your_module.AutoTokenizer.from_pretrained")
|
|
|
|
def test_mistral_load_model(mock_tokenizer, mock_model):
|
|
|
|
mistral = Mistral(device="cpu")
|
|
|
|
mistral.load_model()
|
|
|
|
mock_model.assert_called_once()
|
|
|
|
mock_tokenizer.assert_called_once()
|
|
|
|
|
|
|
|
|
|
|
|
@patch("your_module.Mistral.load_model")
|
|
|
|
def test_mistral_run(mock_load_model):
|
|
|
|
mistral = Mistral(device="cpu")
|
|
|
|
mistral.run("What's the weather in miami")
|
|
|
|
mock_load_model.assert_called_once()
|
|
|
|
|
|
|
|
|
|
|
|
@patch("your_module.Mistral.run")
|
|
|
|
def test_mistral_chat(mock_run):
|
|
|
|
mistral = Mistral(device="cpu")
|
|
|
|
mistral.chat("What's the weather in miami")
|
|
|
|
mock_run.assert_called_once()
|
|
|
|
|
|
|
|
|
|
|
|
def test_mistral__stream_response():
|
|
|
|
mistral = Mistral(device="cpu")
|
|
|
|
response = "It's sunny in Miami."
|
|
|
|
tokens = list(mistral._stream_response(response))
|
|
|
|
assert tokens == ["It's", "sunny", "in", "Miami."]
|