2012-06-18 17:32:03 +01:00
|
|
|
from django.db import models
|
2013-05-09 15:16:43 +01:00
|
|
|
from django.db.models.loading import BaseAppCache
|
2012-06-18 17:32:03 +01:00
|
|
|
|
|
|
|
# Because we want to test creation and deletion of these as separate things,
|
2013-05-09 15:16:43 +01:00
|
|
|
# these models are all inserted into a separate AppCache so the main test
|
|
|
|
# runner doesn't syncdb them.
|
|
|
|
|
|
|
|
new_app_cache = BaseAppCache()
|
2012-06-18 17:32:03 +01:00
|
|
|
|
|
|
|
|
|
|
|
class Author(models.Model):
|
|
|
|
name = models.CharField(max_length=255)
|
2012-09-07 15:40:59 -04:00
|
|
|
height = models.PositiveIntegerField(null=True, blank=True)
|
2012-06-18 17:32:03 +01:00
|
|
|
|
|
|
|
class Meta:
|
2013-05-09 15:16:43 +01:00
|
|
|
app_cache = new_app_cache
|
2012-06-18 17:32:03 +01:00
|
|
|
|
|
|
|
|
2012-08-02 15:08:39 +01:00
|
|
|
class AuthorWithM2M(models.Model):
|
|
|
|
name = models.CharField(max_length=255)
|
|
|
|
|
|
|
|
class Meta:
|
2013-05-09 15:16:43 +01:00
|
|
|
app_cache = new_app_cache
|
2012-08-02 15:08:39 +01:00
|
|
|
|
|
|
|
|
2012-06-18 17:32:03 +01:00
|
|
|
class Book(models.Model):
|
|
|
|
author = models.ForeignKey(Author)
|
2012-08-30 23:11:56 +01:00
|
|
|
title = models.CharField(max_length=100, db_index=True)
|
2012-06-18 17:32:03 +01:00
|
|
|
pub_date = models.DateTimeField()
|
2013-05-09 15:16:43 +01:00
|
|
|
# tags = models.ManyToManyField("Tag", related_name="books")
|
2012-06-18 17:32:03 +01:00
|
|
|
|
|
|
|
class Meta:
|
2013-05-09 15:16:43 +01:00
|
|
|
app_cache = new_app_cache
|
2012-08-02 15:08:39 +01:00
|
|
|
|
|
|
|
|
2012-09-07 14:39:22 -04:00
|
|
|
class BookWithM2M(models.Model):
|
|
|
|
author = models.ForeignKey(Author)
|
|
|
|
title = models.CharField(max_length=100, db_index=True)
|
|
|
|
pub_date = models.DateTimeField()
|
|
|
|
tags = models.ManyToManyField("Tag", related_name="books")
|
|
|
|
|
|
|
|
class Meta:
|
2013-05-09 15:16:43 +01:00
|
|
|
app_cache = new_app_cache
|
2012-09-07 14:39:22 -04:00
|
|
|
|
|
|
|
|
2012-09-07 12:51:11 -04:00
|
|
|
class BookWithSlug(models.Model):
|
|
|
|
author = models.ForeignKey(Author)
|
|
|
|
title = models.CharField(max_length=100, db_index=True)
|
|
|
|
pub_date = models.DateTimeField()
|
|
|
|
slug = models.CharField(max_length=20, unique=True)
|
|
|
|
|
|
|
|
class Meta:
|
2013-05-09 15:16:43 +01:00
|
|
|
app_cache = new_app_cache
|
2012-09-07 12:51:11 -04:00
|
|
|
db_table = "schema_book"
|
|
|
|
|
|
|
|
|
2012-08-02 15:08:39 +01:00
|
|
|
class Tag(models.Model):
|
|
|
|
title = models.CharField(max_length=255)
|
|
|
|
slug = models.SlugField(unique=True)
|
2012-08-10 12:38:18 +01:00
|
|
|
|
|
|
|
class Meta:
|
2013-05-09 15:16:43 +01:00
|
|
|
app_cache = new_app_cache
|
2012-08-10 12:38:18 +01:00
|
|
|
|
|
|
|
|
2012-08-18 14:00:42 +01:00
|
|
|
class TagUniqueRename(models.Model):
|
|
|
|
title = models.CharField(max_length=255)
|
|
|
|
slug2 = models.SlugField(unique=True)
|
|
|
|
|
|
|
|
class Meta:
|
2013-05-09 15:16:43 +01:00
|
|
|
app_cache = new_app_cache
|
2012-08-18 14:00:42 +01:00
|
|
|
db_table = "schema_tag"
|
|
|
|
|
|
|
|
|
2012-08-10 12:38:18 +01:00
|
|
|
class UniqueTest(models.Model):
|
|
|
|
year = models.IntegerField()
|
|
|
|
slug = models.SlugField(unique=False)
|
|
|
|
|
|
|
|
class Meta:
|
2013-05-09 15:16:43 +01:00
|
|
|
app_cache = new_app_cache
|
2012-08-10 12:38:18 +01:00
|
|
|
unique_together = ["year", "slug"]
|