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