2011-05-02 07:20:28 +00:00
|
|
|
|
|
|
|
import pytest
|
|
|
|
|
2013-10-29 09:54:36 +00:00
|
|
|
from sqlalchemy.orm import aliased, joinedload, lazyload
|
2011-04-19 09:24:40 +00:00
|
|
|
from sqlalchemy.orm.exc import NoResultFound
|
2013-10-29 09:54:36 +00:00
|
|
|
from sqlalchemy.sql import func
|
2011-01-27 05:33:03 +00:00
|
|
|
|
2011-04-19 09:24:40 +00:00
|
|
|
from pokedex.db import connect, tables, util
|
2011-01-27 05:33:03 +00:00
|
|
|
|
|
|
|
def test_encounter_slots():
|
|
|
|
# Encounters have a version, which has a version group; encounters also
|
|
|
|
# have an encounter_slot, which has a version group. The two version
|
|
|
|
# groups should match, universally.
|
|
|
|
session = connect()
|
|
|
|
|
|
|
|
version_group_a = aliased(tables.VersionGroup)
|
|
|
|
version_group_b = aliased(tables.VersionGroup)
|
|
|
|
|
|
|
|
sanity_q = session.query(tables.Encounter) \
|
|
|
|
.join((tables.EncounterSlot, tables.Encounter.slot)) \
|
|
|
|
.join((version_group_a, tables.EncounterSlot.version_group)) \
|
|
|
|
.join((tables.Version, tables.Encounter.version)) \
|
|
|
|
.join((version_group_b, tables.Version.version_group)) \
|
|
|
|
.filter(version_group_a.id != version_group_b.id)
|
|
|
|
|
2011-05-02 07:20:28 +00:00
|
|
|
# Encounter slots all match the encounters they belong to
|
|
|
|
assert sanity_q.count() == 0
|
2011-04-19 09:24:40 +00:00
|
|
|
|
|
|
|
def test_nonzero_autoincrement_ids():
|
|
|
|
"""Check that autoincrementing ids don't contain zeroes
|
|
|
|
|
|
|
|
MySQL doesn't like these, see e.g. bug #580
|
|
|
|
"""
|
|
|
|
|
|
|
|
session = connect()
|
|
|
|
for cls in tables.mapped_classes:
|
|
|
|
if 'id' in cls.__table__.c:
|
|
|
|
if cls.__table__.c.id.autoincrement:
|
|
|
|
def nonzero_id(cls):
|
2011-05-02 07:20:28 +00:00
|
|
|
with pytest.raises(NoResultFound):
|
|
|
|
util.get(session, cls, id=0)
|
2011-04-19 09:24:40 +00:00
|
|
|
nonzero_id.description = "No zero id in %s" % cls.__name__
|
|
|
|
yield nonzero_id, cls
|
2011-09-05 08:20:16 +00:00
|
|
|
|
|
|
|
def test_unique_form_order():
|
|
|
|
"""Check that tone PokemonForm.order value isn't used for more species
|
|
|
|
"""
|
|
|
|
|
|
|
|
session = connect()
|
|
|
|
|
|
|
|
species_by_form_order = {}
|
|
|
|
|
|
|
|
query = session.query(tables.PokemonForm)
|
|
|
|
query = query.options(joinedload('pokemon.species'))
|
|
|
|
|
|
|
|
for form in query:
|
|
|
|
print form.name
|
|
|
|
try:
|
|
|
|
previous_species = species_by_form_order[form.order]
|
|
|
|
except KeyError:
|
|
|
|
species_by_form_order[form.order] = form.species
|
|
|
|
else:
|
|
|
|
assert previous_species == form.species, (
|
|
|
|
"PokemonForm.order == %s is used for %s and %s" % (
|
|
|
|
form.order,
|
|
|
|
species_by_form_order[form.order].name,
|
|
|
|
form.species.name))
|
2013-10-29 09:54:36 +00:00
|
|
|
|
|
|
|
def test_default_forms():
|
|
|
|
"""Check that each pokemon has one default form and each species has one
|
|
|
|
default pokemon."""
|
|
|
|
|
|
|
|
session = connect()
|
|
|
|
|
|
|
|
q = session.query(tables.Pokemon)
|
|
|
|
q = q.join(tables.PokemonForm)
|
|
|
|
q = q.filter(tables.PokemonForm.is_default==True)
|
|
|
|
q = q.options(lazyload('*'))
|
|
|
|
q = q.group_by(tables.Pokemon)
|
|
|
|
q = q.add_columns(func.count(tables.PokemonForm.id))
|
|
|
|
|
|
|
|
for pokemon, num_default_forms in q:
|
|
|
|
if num_default_forms == 0:
|
|
|
|
raise AssertionError("pokemon %s has no default forms" % pokemon.name)
|
|
|
|
elif num_default_forms > 1:
|
|
|
|
raise AssertionError("pokemon %s has %d default forms" % (pokemon.name, num_default_forms))
|
|
|
|
|
|
|
|
q = session.query(tables.PokemonSpecies)
|
|
|
|
q = q.join(tables.Pokemon)
|
|
|
|
q = q.filter(tables.Pokemon.is_default==True)
|
|
|
|
q = q.options(lazyload('*'))
|
|
|
|
q = q.group_by(tables.PokemonSpecies)
|
|
|
|
q = q.add_columns(func.count(tables.Pokemon.id))
|
|
|
|
|
|
|
|
for species, num_default_pokemon in q:
|
|
|
|
if num_default_pokemon == 0:
|
|
|
|
raise AssertionError("species %s has no default pokemon" % species.name)
|
|
|
|
elif num_default_pokemon > 1:
|
|
|
|
raise AssertionError("species %s has %d default pokemon" % (species.name, num_default_pokemon))
|