from __future__ import unicode_literals import pytest from spacy.en import English @pytest.fixture def EN(): return English() def test_tweebo_challenge(EN): text = u""":o :/ :'( >:o (: :) >.< XD -__- o.O ;D :-) @_@ :P 8D :1 >:( :D =| ") :> ....""" tokens = EN(text, parse=False, tag=False) assert tokens[0].orth_ == ":o" assert tokens[1].orth_ == ":/" assert tokens[2].orth_ == ":'(" assert tokens[3].orth_ == ">:o" assert tokens[4].orth_ == "(:" assert tokens[5].orth_ == ":)" assert tokens[6].orth_ == ">.<" assert tokens[7].orth_ == "XD" assert tokens[8].orth_ == "-__-" assert tokens[9].orth_ == "o.O" assert tokens[10].orth_ == ";D" assert tokens[11].orth_ == ":-)" assert tokens[12].orth_ == "@_@" assert tokens[13].orth_ == ":P" assert tokens[14].orth_ == "8D" assert tokens[15].orth_ == ":1" assert tokens[16].orth_ == ">:(" assert tokens[17].orth_ == ":D" assert tokens[18].orth_ == "=|" assert tokens[19].orth_ == '")' assert tokens[20].orth_ == ':>' assert tokens[21].orth_ == '....' def test_false_positive(EN): text = "example:)" tokens = EN(text, parse=False, tag=False) assert len(tokens) == 3