X-Git-Url: http://git.veekun.com/zzz-pokedex.git/blobdiff_plain/586edf1bf1859d42b77cca0979aa69df20e14e5e..f271c863f37e549efe264c1cc03a6bbb5c6c7a1d:/pokedex/tests/test_strings.py diff --git a/pokedex/tests/test_strings.py b/pokedex/tests/test_strings.py index 065b0ed..8d0fa06 100644 --- a/pokedex/tests/test_strings.py +++ b/pokedex/tests/test_strings.py @@ -8,21 +8,14 @@ class TestStrings(object): def setup(self): self.connection = connect() + def teardown(self): + self.connection.rollback() + def test_filter(self): q = self.connection.query(tables.Pokemon).filter( tables.Pokemon.name == u"Marowak") assert q.one().identifier == 'marowak' - def test_gt(self): - # Assuming that the identifiers are just lowercase names - q1 = self.connection.query(tables.Pokemon).filter( - tables.Pokemon.name > u"Xatu").order_by( - tables.Pokemon.id) - q2 = self.connection.query(tables.Pokemon).filter( - tables.Pokemon.identifier > u"xatu").order_by( - tables.Pokemon.id) - assert q1.all() == q2.all() - def test_languages(self): q = self.connection.query(tables.Pokemon).filter( tables.Pokemon.name == u"Mightyena") @@ -33,7 +26,9 @@ class TestStrings(object): ('roomaji', u'Guraena'), ('fr', u'Grahyèna'), ): - assert pkmn.names[lang] == name + language = self.connection.query(tables.Language).filter_by( + identifier=lang).one() + assert pkmn.name_map[language] == name @raises(KeyError) def test_bad_lang(self): @@ -41,3 +36,52 @@ class TestStrings(object): tables.Pokemon.name == u"Mightyena") pkmn = q.one() pkmn.names["identifier of a language that doesn't exist"] + + def test_mutating(self): + item = self.connection.query(tables.Item).filter_by( + identifier=u"jade-orb").one() + language = self.connection.query(tables.Language).filter_by( + identifier=u"de").one() + item.name_map[language] = u"foo" + assert item.name_map[language] == "foo" + item.name_map[language] = u"xyzzy" + assert item.name_map[language] == "xyzzy" + + def test_mutating_default(self): + item = self.connection.query(tables.Item).filter_by( + identifier=u"jade-orb").one() + item.name = u"foo" + assert item.name == "foo" + + def test_string_mapping(self): + item = self.connection.query(tables.Item).filter_by( + identifier=u"jade-orb").one() + assert len(item.name_map) == len(item.names) + for lang in item.names: + assert item.name_map[lang] == item.names[lang].name + assert lang in item.name_map + assert "language that doesn't exist" not in item.name_map + assert tables.Language() not in item.name_map + + def test_new_language(self): + item = self.connection.query(tables.Item).filter_by( + identifier=u"jade-orb").one() + language = tables.Language() + language.id = -1 + language.identifier = u'test' + language.iso639 = language.iso3166 = u'--' + language.official = False + self.connection.add(language) + item.name_map[language] = u"foo" + assert item.name_map[language] == "foo" + assert language in item.name_map + item.name_map[language] = u"xyzzy" + assert item.name_map[language] == "xyzzy" + + def test_markdown(self): + move = self.connection.query(tables.Move).filter_by( + identifier=u"thunderbolt").one() + language = self.connection.query(tables.Language).filter_by( + identifier=u"en").one() + assert '10%' in move.effect.as_text + assert '10%' in move.effect_map[language].as_text