You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
82 lines
2.3 KiB
82 lines
2.3 KiB
1 year ago
|
# Tokenizer
|
||
|
|
||
|
from swarms.tokenizers.r_tokenizers import Tokenizer
|
||
|
from unittest.mock import patch
|
||
|
|
||
|
|
||
|
def test_initializer_existing_model_file():
|
||
|
with patch("os.path.exists", return_value=True):
|
||
|
with patch(
|
||
|
"swarms.tokenizers.SentencePieceTokenizer"
|
||
|
) as mock_model:
|
||
|
tokenizer = Tokenizer("tokenizers/my_model.model")
|
||
|
mock_model.assert_called_with("tokenizers/my_model.model")
|
||
|
assert tokenizer.model == mock_model.return_value
|
||
|
|
||
|
|
||
|
def test_initializer_model_folder():
|
||
|
with patch("os.path.exists", side_effect=[False, True]):
|
||
|
with patch(
|
||
|
"swarms.tokenizers.HuggingFaceTokenizer"
|
||
|
) as mock_model:
|
||
|
tokenizer = Tokenizer("my_model_directory")
|
||
|
mock_model.assert_called_with("my_model_directory")
|
||
|
assert tokenizer.model == mock_model.return_value
|
||
|
|
||
|
|
||
|
def test_vocab_size():
|
||
|
with patch(
|
||
|
"swarms.tokenizers.SentencePieceTokenizer"
|
||
|
) as mock_model:
|
||
|
tokenizer = Tokenizer("tokenizers/my_model.model")
|
||
|
assert (
|
||
|
tokenizer.vocab_size == mock_model.return_value.vocab_size
|
||
|
)
|
||
|
|
||
|
|
||
|
def test_bos_token_id():
|
||
|
with patch(
|
||
|
"swarms.tokenizers.SentencePieceTokenizer"
|
||
|
) as mock_model:
|
||
|
tokenizer = Tokenizer("tokenizers/my_model.model")
|
||
|
assert (
|
||
|
tokenizer.bos_token_id
|
||
|
== mock_model.return_value.bos_token_id
|
||
|
)
|
||
|
|
||
|
|
||
|
def test_encode():
|
||
|
with patch(
|
||
|
"swarms.tokenizers.SentencePieceTokenizer"
|
||
|
) as mock_model:
|
||
|
tokenizer = Tokenizer("tokenizers/my_model.model")
|
||
|
assert (
|
||
|
tokenizer.encode("hello")
|
||
|
== mock_model.return_value.encode.return_value
|
||
|
)
|
||
|
|
||
|
|
||
|
def test_decode():
|
||
|
with patch(
|
||
|
"swarms.tokenizers.SentencePieceTokenizer"
|
||
|
) as mock_model:
|
||
|
tokenizer = Tokenizer("tokenizers/my_model.model")
|
||
|
assert (
|
||
|
tokenizer.decode([1, 2, 3])
|
||
|
== mock_model.return_value.decode.return_value
|
||
|
)
|
||
|
|
||
|
|
||
|
def test_call():
|
||
|
with patch(
|
||
|
"swarms.tokenizers.SentencePieceTokenizer"
|
||
|
) as mock_model:
|
||
|
tokenizer = Tokenizer("tokenizers/my_model.model")
|
||
|
assert (
|
||
|
tokenizer("hello")
|
||
|
== mock_model.return_value.__call__.return_value
|
||
|
)
|
||
|
|
||
|
|
||
|
# More tests can be added here
|