Source

djangoappengine / tests / testmodels.py

Full commit
from django.db import models
from ..db.db_settings import get_indexes
from djangotoolbox.fields import BlobField

class EmailModel(models.Model):
    email = models.EmailField()

class DateTimeModel(models.Model):
    datetime = models.DateTimeField()
    datetime_auto_now = models.DateTimeField(auto_now=True)
    datetime_auto_now_add = models.DateTimeField(auto_now_add=True)

class FieldsWithoutOptionsModel(models.Model):
    datetime = models.DateTimeField()
    date = models.DateField()
    time = models.TimeField()
    floating_point = models.FloatField()
    boolean = models.BooleanField()
    null_boolean = models.NullBooleanField()
    text = models.CharField(max_length=32)
    email = models.EmailField()
    comma_seperated_integer = models.CommaSeparatedIntegerField(max_length=10)
    ip_address = models.IPAddressField()
    slug = models.SlugField()
    url = models.URLField()
#    file = models.FileField()
#    file_path = models.FilePathField()
    long_text = models.TextField()
    indexed_text = models.TextField()
    xml = models.XMLField()
    integer = models.IntegerField()
    small_integer = models.SmallIntegerField()
    positiv_integer = models.PositiveIntegerField()
    positiv_small_integer = models.PositiveSmallIntegerField()
#    foreign_key = models.ForeignKey('FieldsWithOptionsModel')
#    foreign_key = models.ForeignKey('OrderedModel')
#    one_to_one = models.OneToOneField()
#    decimal = models.DecimalField() # can be None
#    image = models.ImageField()

get_indexes()[FieldsWithoutOptionsModel] = {'indexed': ('indexed_text',)}

class FieldsWithOptionsModel(models.Model):
    # any type of unique (unique_data, ...) is not supported on GAE, instead you
    # can use primary_key=True for some special cases. But be carefull: changing
    # the  primary_key of an entity will not result in an updated entity,
    # instead a new entity will be putted into the datastore. The old one will
    # not be deleted and all references pointing to the old entitiy will not
    # point to the new one either
    datetime = models.DateTimeField(auto_now=True, db_column="birthday")
    date = models.DateField(auto_now_add=True)
    time = models.TimeField()
    floating_point = models.FloatField(null=True)
    boolean = models.BooleanField() # default is False
    null_boolean = models.NullBooleanField(default=True)
    text = models.CharField(default='Hallo', max_length=10)
    email = models.EmailField(default='app-engine@scholardocs.com', primary_key=True)
    comma_seperated_integer = models.CommaSeparatedIntegerField(max_length=10)
    ip_address = models.IPAddressField(default="192.168.0.2")
    slug = models.SlugField(default="GAGAA", null=True)
    url = models.URLField(default='http://www.scholardocs.com')
#    file = FileField()
#    file_path = FilePathField()
    long_text = models.TextField(default=1000*'A')
    xml = models.XMLField(default=2000*'B')
    integer = models.IntegerField(default=100)
    small_integer = models.SmallIntegerField(default=-5)
    positiv_integer = models.PositiveIntegerField(default=80)
    positiv_small_integer = models.PositiveSmallIntegerField(default=3, null=True)
    foreign_key = models.ForeignKey('OrderedModel', null=True, related_name='keys')
#    one_to_one = OneToOneField()
#    decimal = DecimalField()
#    image = ImageField()

class OrderedModel(models.Model):
    id = models.IntegerField(primary_key=True)
    priority = models.IntegerField()

    class Meta:
        ordering = ('-priority',)

class BlobModel(models.Model):
    data = BlobField()

class DecimalModel(models.Model):
    decimal = models.DecimalField(max_digits=9, decimal_places=2)

class SelfReferenceModel(models.Model):
    ref = models.ForeignKey('self', null=True)

class Parent(models.Model):
    foo = models.IntegerField()

class Mti(Parent):
    bar = models.IntegerField()