1. """
    
  2. Tests for F() query expression syntax.
    
  3. """
    
  4. import uuid
    
  5. 
    
  6. from django.db import models
    
  7. 
    
  8. 
    
  9. class Manager(models.Model):
    
  10.     name = models.CharField(max_length=50)
    
  11. 
    
  12. 
    
  13. class Employee(models.Model):
    
  14.     firstname = models.CharField(max_length=50)
    
  15.     lastname = models.CharField(max_length=50)
    
  16.     salary = models.IntegerField(blank=True, null=True)
    
  17.     manager = models.ForeignKey(Manager, models.CASCADE, null=True)
    
  18. 
    
  19.     def __str__(self):
    
  20.         return "%s %s" % (self.firstname, self.lastname)
    
  21. 
    
  22. 
    
  23. class RemoteEmployee(Employee):
    
  24.     adjusted_salary = models.IntegerField()
    
  25. 
    
  26. 
    
  27. class Company(models.Model):
    
  28.     name = models.CharField(max_length=100)
    
  29.     num_employees = models.PositiveIntegerField()
    
  30.     num_chairs = models.PositiveIntegerField()
    
  31.     ceo = models.ForeignKey(
    
  32.         Employee,
    
  33.         models.CASCADE,
    
  34.         related_name="company_ceo_set",
    
  35.     )
    
  36.     point_of_contact = models.ForeignKey(
    
  37.         Employee,
    
  38.         models.SET_NULL,
    
  39.         related_name="company_point_of_contact_set",
    
  40.         null=True,
    
  41.     )
    
  42.     based_in_eu = models.BooleanField(default=False)
    
  43. 
    
  44.     def __str__(self):
    
  45.         return self.name
    
  46. 
    
  47. 
    
  48. class Number(models.Model):
    
  49.     integer = models.BigIntegerField(db_column="the_integer")
    
  50.     float = models.FloatField(null=True, db_column="the_float")
    
  51.     decimal_value = models.DecimalField(max_digits=20, decimal_places=17, null=True)
    
  52. 
    
  53.     def __str__(self):
    
  54.         return "%i, %.3f, %.17f" % (self.integer, self.float, self.decimal_value)
    
  55. 
    
  56. 
    
  57. class Experiment(models.Model):
    
  58.     name = models.CharField(max_length=24)
    
  59.     assigned = models.DateField()
    
  60.     completed = models.DateField()
    
  61.     estimated_time = models.DurationField()
    
  62.     start = models.DateTimeField()
    
  63.     end = models.DateTimeField()
    
  64.     scalar = models.IntegerField(null=True)
    
  65. 
    
  66.     class Meta:
    
  67.         db_table = "expressions_ExPeRiMeNt"
    
  68.         ordering = ("name",)
    
  69. 
    
  70.     def duration(self):
    
  71.         return self.end - self.start
    
  72. 
    
  73. 
    
  74. class Result(models.Model):
    
  75.     experiment = models.ForeignKey(Experiment, models.CASCADE)
    
  76.     result_time = models.DateTimeField()
    
  77. 
    
  78.     def __str__(self):
    
  79.         return "Result at %s" % self.result_time
    
  80. 
    
  81. 
    
  82. class Time(models.Model):
    
  83.     time = models.TimeField(null=True)
    
  84. 
    
  85.     def __str__(self):
    
  86.         return str(self.time)
    
  87. 
    
  88. 
    
  89. class SimulationRun(models.Model):
    
  90.     start = models.ForeignKey(Time, models.CASCADE, null=True, related_name="+")
    
  91.     end = models.ForeignKey(Time, models.CASCADE, null=True, related_name="+")
    
  92.     midpoint = models.TimeField()
    
  93. 
    
  94.     def __str__(self):
    
  95.         return "%s (%s to %s)" % (self.midpoint, self.start, self.end)
    
  96. 
    
  97. 
    
  98. class UUIDPK(models.Model):
    
  99.     id = models.UUIDField(primary_key=True, default=uuid.uuid4)
    
  100. 
    
  101. 
    
  102. class UUID(models.Model):
    
  103.     uuid = models.UUIDField(null=True)
    
  104.     uuid_fk = models.ForeignKey(UUIDPK, models.CASCADE, null=True)