Domanda

Ho un metodo molto semplice:

Class Team(models.Model):
    def sides(self):
      return SideNames.objects.filter(team=self)

SideNames è un altro modello definito nello stesso file come Team,

Il che quando provo e test:

self.assertEquals(len(t.sides()), 2)

ottengo il seguente errore:

return SideNames.objects.filter(team=self)
     

AttributeError: oggetto 'NoneType' non ci sono 'oggetti' attributo

ma se cambio il test per essere

self.assertEquals(len(SideNames.objects.filter(team=t)), 2)

Poi non capisco l'errore. Qual è la differenza tra chiamare SideNames.objects.filter dalla prova stessa e chiamando il metodo effettivo?

Per riferimento, qui 2 classi nella loro interezza.

class Team(models.Model):
    """The model for a football team."""

    class Admin:
            pass

    def __unicode__(self):
            return u'%s' % self.name

    def is_player(self, player):
            """Checks to see if 'player' is a member if this team. Returns True if they are, or False otherwise."""

            try:
                    teamPlayer = TeamPlayers.objects.get(player=player, team=self)
                    return True
            except ObjectDoesNotExist:
                    return False

    def sides(self):
            """Return the side names for this team"""
            return SideNames.objects.filter(team=self)

    def updateSides(self, side_a, side_b):
            """Update the side names"""
            names = SideNames.objects.filter(team=self);

            a = SideNames.objects.get(name = names[0].name)
            a.name = side_a
            a.save()

            b = SideNames.objects.get(name = names[1].name)
            b.name = side_b
            b.save()

    name = models.CharField("Team Name", max_length=255)
    organiser = models.ForeignKey(User)

class SideNames(models.Model):
    """Holds the names of the sides for each team"""

    class Admin:
            pass

    def __unicode__(self):
            """Pretty print the SideNames object"""
            return self.name

    team = models.ForeignKey(Team)
    name = models.CharField(max_length=128)
È stato utile?

Soluzione

Per caso, fa il test di fare qualcosa di simile a questo:

from myapp import models

...

models.SideNames = None

dato che è l'unica spiegazione che posso pensare sul perché SideNames dovrebbero essere None, nel contesto di tale metodo.

Per inciso, il metodo in sé è inutile, come a ritroso i rapporti vengono automaticamente forniti da Django, quindi si può solo chiamare t.sidenames_set.all().

Altri suggerimenti

Nel modulo che definisce il test, si sta importando il nome SideNames da qualche altro modulo. Nel modulo in cui tale metodo sides è definito, il nome SideNames non è definito o importato.

Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a StackOverflow
scroll top