|
|
|
import pytest
|
|
|
|
import torch
|
|
|
|
from transformers import AutoTokenizer
|
|
|
|
|
|
|
|
from swarms.models.yi_200k import Yi34B200k
|
|
|
|
|
|
|
|
|
|
|
|
# Create fixtures if needed
|
|
|
|
@pytest.fixture
|
|
|
|
def yi34b_model():
|
|
|
|
return Yi34B200k()
|
|
|
|
|
|
|
|
|
|
|
|
# Test cases for the Yi34B200k class
|
|
|
|
def test_yi34b_init(yi34b_model):
|
|
|
|
assert isinstance(yi34b_model.model, torch.nn.Module)
|
|
|
|
assert isinstance(yi34b_model.tokenizer, AutoTokenizer)
|
|
|
|
|
|
|
|
|
|
|
|
def test_yi34b_generate_text(yi34b_model):
|
|
|
|
prompt = "There's a place where time stands still."
|
|
|
|
generated_text = yi34b_model(prompt)
|
|
|
|
assert isinstance(generated_text, str)
|
|
|
|
assert len(generated_text) > 0
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.parametrize("max_length", [64, 128, 256, 512])
|
|
|
|
def test_yi34b_generate_text_with_length(yi34b_model, max_length):
|
|
|
|
prompt = "There's a place where time stands still."
|
|
|
|
generated_text = yi34b_model(prompt, max_length=max_length)
|
|
|
|
assert len(generated_text) <= max_length
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.parametrize("temperature", [0.5, 1.0, 1.5])
|
|
|
|
def test_yi34b_generate_text_with_temperature(yi34b_model, temperature):
|
|
|
|
prompt = "There's a place where time stands still."
|
|
|
|
generated_text = yi34b_model(prompt, temperature=temperature)
|
|
|
|
assert isinstance(generated_text, str)
|
|
|
|
|
|
|
|
|
|
|
|
def test_yi34b_generate_text_with_invalid_prompt(yi34b_model):
|
|
|
|
prompt = None # Invalid prompt
|
|
|
|
with pytest.raises(
|
|
|
|
ValueError, match="Input prompt must be a non-empty string"
|
|
|
|
):
|
|
|
|
yi34b_model(prompt)
|
|
|
|
|
|
|
|
|
|
|
|
def test_yi34b_generate_text_with_invalid_max_length(yi34b_model):
|
|
|
|
prompt = "There's a place where time stands still."
|
|
|
|
max_length = -1 # Invalid max_length
|
|
|
|
with pytest.raises(
|
|
|
|
ValueError, match="max_length must be a positive integer"
|
|
|
|
):
|
|
|
|
yi34b_model(prompt, max_length=max_length)
|
|
|
|
|
|
|
|
|
|
|
|
def test_yi34b_generate_text_with_invalid_temperature(yi34b_model):
|
|
|
|
prompt = "There's a place where time stands still."
|
|
|
|
temperature = 2.0 # Invalid temperature
|
|
|
|
with pytest.raises(
|
|
|
|
ValueError, match="temperature must be between 0.01 and 1.0"
|
|
|
|
):
|
|
|
|
yi34b_model(prompt, temperature=temperature)
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.parametrize("top_k", [20, 30, 50])
|
|
|
|
def test_yi34b_generate_text_with_top_k(yi34b_model, top_k):
|
|
|
|
prompt = "There's a place where time stands still."
|
|
|
|
generated_text = yi34b_model(prompt, top_k=top_k)
|
|
|
|
assert isinstance(generated_text, str)
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.parametrize("top_p", [0.5, 0.7, 0.9])
|
|
|
|
def test_yi34b_generate_text_with_top_p(yi34b_model, top_p):
|
|
|
|
prompt = "There's a place where time stands still."
|
|
|
|
generated_text = yi34b_model(prompt, top_p=top_p)
|
|
|
|
assert isinstance(generated_text, str)
|
|
|
|
|
|
|
|
|
|
|
|
def test_yi34b_generate_text_with_invalid_top_k(yi34b_model):
|
|
|
|
prompt = "There's a place where time stands still."
|
|
|
|
top_k = -1 # Invalid top_k
|
|
|
|
with pytest.raises(
|
|
|
|
ValueError, match="top_k must be a non-negative integer"
|
|
|
|
):
|
|
|
|
yi34b_model(prompt, top_k=top_k)
|
|
|
|
|
|
|
|
|
|
|
|
def test_yi34b_generate_text_with_invalid_top_p(yi34b_model):
|
|
|
|
prompt = "There's a place where time stands still."
|
|
|
|
top_p = 1.5 # Invalid top_p
|
|
|
|
with pytest.raises(
|
|
|
|
ValueError, match="top_p must be between 0.0 and 1.0"
|
|
|
|
):
|
|
|
|
yi34b_model(prompt, top_p=top_p)
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.parametrize("repitition_penalty", [1.0, 1.2, 1.5])
|
|
|
|
def test_yi34b_generate_text_with_repitition_penalty(
|
|
|
|
yi34b_model, repitition_penalty
|
|
|
|
):
|
|
|
|
prompt = "There's a place where time stands still."
|
|
|
|
generated_text = yi34b_model(
|
|
|
|
prompt, repitition_penalty=repitition_penalty
|
|
|
|
)
|
|
|
|
assert isinstance(generated_text, str)
|
|
|
|
|
|
|
|
|
|
|
|
def test_yi34b_generate_text_with_invalid_repitition_penalty(
|
|
|
|
yi34b_model,
|
|
|
|
):
|
|
|
|
prompt = "There's a place where time stands still."
|
|
|
|
repitition_penalty = 0.0 # Invalid repitition_penalty
|
|
|
|
with pytest.raises(
|
|
|
|
ValueError,
|
|
|
|
match="repitition_penalty must be a positive float",
|
|
|
|
):
|
|
|
|
yi34b_model(prompt, repitition_penalty=repitition_penalty)
|
|
|
|
|
|
|
|
|
|
|
|
def test_yi34b_generate_text_with_invalid_device(yi34b_model):
|
|
|
|
prompt = "There's a place where time stands still."
|
|
|
|
device_map = "invalid_device" # Invalid device_map
|
|
|
|
with pytest.raises(ValueError, match="Invalid device_map"):
|
|
|
|
yi34b_model(prompt, device_map=device_map)
|