2020-10-07 11:25:37 +03:00
|
|
|
|
import pytest
|
2023-06-26 12:41:03 +03:00
|
|
|
|
|
2020-10-07 11:25:37 +03:00
|
|
|
|
from spacy.lang.tr.lex_attrs import like_num
|
|
|
|
|
|
|
|
|
|
|
2020-10-29 11:43:17 +03:00
|
|
|
|
def test_tr_tokenizer_handles_long_text(tr_tokenizer):
|
|
|
|
|
text = """Pamuk nasıl ipliğe dönüştürülür?
|
|
|
|
|
|
2021-01-05 05:41:53 +03:00
|
|
|
|
Sıkıştırılmış balyalar halindeki pamuk, iplik fabrikasına getirildiğinde hem
|
|
|
|
|
lifleri birbirine dolaşmıştır, hem de tarladan toplanırken araya bitkinin
|
|
|
|
|
parçaları karışmıştır. Üstelik balyalardaki pamuğun cinsi aynı olsa bile kalitesi
|
2020-10-29 11:43:17 +03:00
|
|
|
|
değişeceğinden, önce bütün balyaların birbirine karıştırılarak harmanlanması gerekir.
|
|
|
|
|
|
2021-01-05 05:41:53 +03:00
|
|
|
|
Daha sonra pamuk yığınları, liflerin açılıp temizlenmesi için tek bir birim halinde
|
2020-10-29 11:43:17 +03:00
|
|
|
|
birleştirilmiş çeşitli makinelerden geçirilir.Bunlardan biri, dönen tokmaklarıyla
|
|
|
|
|
pamuğu dövüp kabartarak dağınık yumaklar haline getiren ve liflerin arasındaki yabancı
|
|
|
|
|
maddeleri temizleyen hallaç makinesidir. Daha sonra tarak makinesine giren pamuk demetleri,
|
|
|
|
|
herbirinin yüzeyinde yüzbinlerce incecik iğne bulunan döner silindirlerin arasından geçerek lif lif ayrılır
|
2021-01-05 05:41:53 +03:00
|
|
|
|
ve tül inceliğinde gevşek bir örtüye dönüşür. Ama bir sonraki makine bu lifleri dağınık
|
2020-10-29 11:43:17 +03:00
|
|
|
|
ve gevşek bir biçimde birbirine yaklaştırarak 2 cm eninde bir pamuk şeridi haline getirir."""
|
|
|
|
|
tokens = tr_tokenizer(text)
|
|
|
|
|
assert len(tokens) == 146
|
|
|
|
|
|
|
|
|
|
|
2020-10-07 11:25:37 +03:00
|
|
|
|
@pytest.mark.parametrize(
|
|
|
|
|
"word",
|
|
|
|
|
[
|
|
|
|
|
"bir",
|
|
|
|
|
"iki",
|
|
|
|
|
"dört",
|
|
|
|
|
"altı",
|
|
|
|
|
"milyon",
|
|
|
|
|
"100",
|
|
|
|
|
"birinci",
|
|
|
|
|
"üçüncü",
|
|
|
|
|
"beşinci",
|
|
|
|
|
"100üncü",
|
2020-10-10 20:14:48 +03:00
|
|
|
|
"8inci",
|
|
|
|
|
],
|
2020-10-07 11:25:37 +03:00
|
|
|
|
)
|
|
|
|
|
def test_tr_lex_attrs_like_number_cardinal_ordinal(word):
|
|
|
|
|
assert like_num(word)
|
|
|
|
|
|
|
|
|
|
|
2022-03-30 14:16:08 +03:00
|
|
|
|
@pytest.mark.parametrize("word", ["beş", "yedi", "yedinci", "birinci", "milyonuncu"])
|
2020-10-07 11:25:37 +03:00
|
|
|
|
def test_tr_lex_attrs_capitals(word):
|
|
|
|
|
assert like_num(word)
|
|
|
|
|
assert like_num(word.upper())
|