2014-08-12 20:08:40 +08:00
|
|
|
from django.db import connection
|
|
|
|
from django.db.models import Max
|
|
|
|
from django.test import TestCase
|
|
|
|
|
2015-01-28 20:35:27 +08:00
|
|
|
from .models import Cash, CashModel
|
2014-08-12 20:08:40 +08:00
|
|
|
|
|
|
|
|
|
|
|
class FromDBValueTest(TestCase):
|
2018-11-24 09:59:38 +08:00
|
|
|
@classmethod
|
|
|
|
def setUpTestData(cls):
|
2014-08-12 20:08:40 +08:00
|
|
|
CashModel.objects.create(cash="12.50")
|
|
|
|
|
|
|
|
def test_simple_load(self):
|
|
|
|
instance = CashModel.objects.get()
|
|
|
|
self.assertIsInstance(instance.cash, Cash)
|
|
|
|
|
2015-06-17 21:42:23 +08:00
|
|
|
def test_values_list(self):
|
2014-08-12 20:08:40 +08:00
|
|
|
values_list = CashModel.objects.values_list("cash", flat=True)
|
|
|
|
self.assertIsInstance(values_list[0], Cash)
|
|
|
|
|
2015-06-17 21:42:23 +08:00
|
|
|
def test_values(self):
|
|
|
|
values = CashModel.objects.values("cash")
|
2015-06-18 02:07:00 +08:00
|
|
|
self.assertIsInstance(values[0]["cash"], Cash)
|
2015-06-17 21:42:23 +08:00
|
|
|
|
2014-08-12 20:08:40 +08: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)
|