2014-08-12 14:08:40 +02:00
|
|
|
from django.db import connection
|
|
|
|
from django.db.models import Max
|
|
|
|
from django.test import TestCase
|
|
|
|
|
2015-01-28 13:35:27 +01:00
|
|
|
from .models import Cash, CashModel
|
2014-08-12 14:08:40 +02:00
|
|
|
|
|
|
|
|
|
|
|
class FromDBValueTest(TestCase):
|
2018-11-24 02:59:38 +01:00
|
|
|
@classmethod
|
|
|
|
def setUpTestData(cls):
|
2014-08-12 14:08:40 +02:00
|
|
|
CashModel.objects.create(cash="12.50")
|
|
|
|
|
|
|
|
def test_simple_load(self):
|
|
|
|
instance = CashModel.objects.get()
|
|
|
|
self.assertIsInstance(instance.cash, Cash)
|
|
|
|
|
2015-06-17 15:42:23 +02:00
|
|
|
def test_values_list(self):
|
2014-08-12 14:08:40 +02:00
|
|
|
values_list = CashModel.objects.values_list("cash", flat=True)
|
|
|
|
self.assertIsInstance(values_list[0], Cash)
|
|
|
|
|
2015-06-17 15:42:23 +02:00
|
|
|
def test_values(self):
|
|
|
|
values = CashModel.objects.values("cash")
|
2015-06-17 20:07:00 +02:00
|
|
|
self.assertIsInstance(values[0]["cash"], Cash)
|
2015-06-17 15:42:23 +02:00
|
|
|
|
2014-08-12 14:08:40 +02:00
|
|
|
def test_aggregation(self):
|
|
|
|
maximum = CashModel.objects.aggregate(m=Max("cash"))["m"]
|
|
|
|
self.assertIsInstance(maximum, Cash)
|
|
|
|
|
|
|
|
def test_defer(self):
|
|
|
|
instance = CashModel.objects.defer("cash").get()
|
|
|
|
self.assertIsInstance(instance.cash, Cash)
|
|
|
|
|
|
|
|
def test_connection(self):
|
|
|
|
instance = CashModel.objects.get()
|
|
|
|
self.assertEqual(instance.cash.vendor, connection.vendor)
|