1
0
mirror of https://github.com/django/django.git synced 2025-10-23 21:59:11 +00:00

Reorganized window db function tests.

This commit is contained in:
Nick Pope
2018-08-16 01:17:02 +01:00
committed by Tim Graham
parent 9ec1a85c77
commit dd3feb0891
2 changed files with 0 additions and 0 deletions

View File

@@ -0,0 +1,39 @@
from django.db.models.functions import Lag, Lead, NthValue, Ntile
from django.test import SimpleTestCase
class ValidationTests(SimpleTestCase):
def test_nth_negative_nth_value(self):
msg = 'NthValue requires a positive integer as for nth'
with self.assertRaisesMessage(ValueError, msg):
NthValue(expression='salary', nth=-1)
def test_nth_null_expression(self):
msg = 'NthValue requires a non-null source expression'
with self.assertRaisesMessage(ValueError, msg):
NthValue(expression=None)
def test_lag_negative_offset(self):
msg = 'Lag requires a positive integer for the offset'
with self.assertRaisesMessage(ValueError, msg):
Lag(expression='salary', offset=-1)
def test_lead_negative_offset(self):
msg = 'Lead requires a positive integer for the offset'
with self.assertRaisesMessage(ValueError, msg):
Lead(expression='salary', offset=-1)
def test_null_source_lead(self):
msg = 'Lead requires a non-null source expression'
with self.assertRaisesMessage(ValueError, msg):
Lead(expression=None)
def test_null_source_lag(self):
msg = 'Lag requires a non-null source expression'
with self.assertRaisesMessage(ValueError, msg):
Lag(expression=None)
def test_negative_num_buckets_ntile(self):
msg = 'num_buckets must be greater than 0'
with self.assertRaisesMessage(ValueError, msg):
Ntile(num_buckets=-1)