Skip to content
Projeler
Gruplar
Parçacıklar
Yardım
Yükleniyor...
Oturum aç / Kaydol
Gezinmeyi değiştir
D
django
Proje
Proje
Ayrıntılar
Etkinlik
Cycle Analytics
Depo (repository)
Depo (repository)
Dosyalar
Kayıtlar (commit)
Dallar (branch)
Etiketler
Katkıda bulunanlar
Grafik
Karşılaştır
Grafikler
Konular (issue)
0
Konular (issue)
0
Liste
Pano
Etiketler
Kilometre Taşları
Birleştirme (merge) Talepleri
0
Birleştirme (merge) Talepleri
0
CI / CD
CI / CD
İş akışları (pipeline)
İşler
Zamanlamalar
Grafikler
Paketler
Paketler
Wiki
Wiki
Parçacıklar
Parçacıklar
Üyeler
Üyeler
Collapse sidebar
Close sidebar
Etkinlik
Grafik
Grafikler
Yeni bir konu (issue) oluştur
İşler
Kayıtlar (commit)
Konu (issue) Panoları
Kenar çubuğunu aç
Batuhan Osman TASKAYA
django
Commits
5c3db0ef
Kaydet (Commit)
5c3db0ef
authored
Agu 16, 2018
tarafından
Nick Pope
Kaydeden (comit)
Tim Graham
Agu 16, 2018
Dosyalara gözat
Seçenekler
Dosyalara Gözat
İndir
Eposta Yamaları
Sade Fark
Reorganized comparison db function tests.
üst
32889858
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
257 additions
and
1 deletion
+257
-1
__init__.py
tests/db_functions/comparison/__init__.py
+0
-0
test_cast.py
tests/db_functions/comparison/test_cast.py
+1
-1
test_coalesce.py
tests/db_functions/comparison/test_coalesce.py
+72
-0
test_greatest.py
tests/db_functions/comparison/test_greatest.py
+91
-0
test_least.py
tests/db_functions/comparison/test_least.py
+93
-0
tests.py
tests/db_functions/tests.py
+0
-0
No files found.
tests/db_functions/comparison/__init__.py
0 → 100644
Dosyayı görüntüle @
5c3db0ef
tests/db_functions/test_cast.py
→
tests/db_functions/
comparison/
test_cast.py
Dosyayı görüntüle @
5c3db0ef
...
...
@@ -10,7 +10,7 @@ from django.test import (
TestCase
,
ignore_warnings
,
override_settings
,
skipUnlessDBFeature
,
)
from
.models
import
Author
from
.
.
models
import
Author
class
CastTests
(
TestCase
):
...
...
tests/db_functions/comparison/test_coalesce.py
0 → 100644
Dosyayı görüntüle @
5c3db0ef
from
django.db.models
import
TextField
from
django.db.models.functions
import
Coalesce
,
Lower
from
django.test
import
TestCase
from
django.utils
import
timezone
from
..models
import
Article
,
Author
lorem_ipsum
=
"""
Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod
tempor incididunt ut labore et dolore magna aliqua."""
class
CoalesceTests
(
TestCase
):
def
test_basic
(
self
):
Author
.
objects
.
create
(
name
=
'John Smith'
,
alias
=
'smithj'
)
Author
.
objects
.
create
(
name
=
'Rhonda'
)
authors
=
Author
.
objects
.
annotate
(
display_name
=
Coalesce
(
'alias'
,
'name'
))
self
.
assertQuerysetEqual
(
authors
.
order_by
(
'name'
),
[
'smithj'
,
'Rhonda'
],
lambda
a
:
a
.
display_name
)
def
test_gt_two_expressions
(
self
):
with
self
.
assertRaisesMessage
(
ValueError
,
'Coalesce must take at least two expressions'
):
Author
.
objects
.
annotate
(
display_name
=
Coalesce
(
'alias'
))
def
test_mixed_values
(
self
):
a1
=
Author
.
objects
.
create
(
name
=
'John Smith'
,
alias
=
'smithj'
)
a2
=
Author
.
objects
.
create
(
name
=
'Rhonda'
)
ar1
=
Article
.
objects
.
create
(
title
=
'How to Django'
,
text
=
lorem_ipsum
,
written
=
timezone
.
now
(),
)
ar1
.
authors
.
add
(
a1
)
ar1
.
authors
.
add
(
a2
)
# mixed Text and Char
article
=
Article
.
objects
.
annotate
(
headline
=
Coalesce
(
'summary'
,
'text'
,
output_field
=
TextField
()),
)
self
.
assertQuerysetEqual
(
article
.
order_by
(
'title'
),
[
lorem_ipsum
],
lambda
a
:
a
.
headline
)
# mixed Text and Char wrapped
article
=
Article
.
objects
.
annotate
(
headline
=
Coalesce
(
Lower
(
'summary'
),
Lower
(
'text'
),
output_field
=
TextField
()),
)
self
.
assertQuerysetEqual
(
article
.
order_by
(
'title'
),
[
lorem_ipsum
.
lower
()],
lambda
a
:
a
.
headline
)
def
test_ordering
(
self
):
Author
.
objects
.
create
(
name
=
'John Smith'
,
alias
=
'smithj'
)
Author
.
objects
.
create
(
name
=
'Rhonda'
)
authors
=
Author
.
objects
.
order_by
(
Coalesce
(
'alias'
,
'name'
))
self
.
assertQuerysetEqual
(
authors
,
[
'Rhonda'
,
'John Smith'
],
lambda
a
:
a
.
name
)
authors
=
Author
.
objects
.
order_by
(
Coalesce
(
'alias'
,
'name'
)
.
asc
())
self
.
assertQuerysetEqual
(
authors
,
[
'Rhonda'
,
'John Smith'
],
lambda
a
:
a
.
name
)
authors
=
Author
.
objects
.
order_by
(
Coalesce
(
'alias'
,
'name'
)
.
desc
())
self
.
assertQuerysetEqual
(
authors
,
[
'John Smith'
,
'Rhonda'
],
lambda
a
:
a
.
name
)
tests/db_functions/comparison/test_greatest.py
0 → 100644
Dosyayı görüntüle @
5c3db0ef
from
datetime
import
datetime
,
timedelta
from
decimal
import
Decimal
from
unittest
import
skipIf
,
skipUnless
from
django.db
import
connection
from
django.db.models.expressions
import
RawSQL
from
django.db.models.functions
import
Coalesce
,
Greatest
from
django.test
import
TestCase
,
skipIfDBFeature
,
skipUnlessDBFeature
from
django.utils
import
timezone
from
..models
import
Article
,
Author
,
DecimalModel
,
Fan
class
GreatestTests
(
TestCase
):
def
test_basic
(
self
):
now
=
timezone
.
now
()
before
=
now
-
timedelta
(
hours
=
1
)
Article
.
objects
.
create
(
title
=
'Testing with Django'
,
written
=
before
,
published
=
now
)
articles
=
Article
.
objects
.
annotate
(
last_updated
=
Greatest
(
'written'
,
'published'
))
self
.
assertEqual
(
articles
.
first
()
.
last_updated
,
now
)
@skipUnlessDBFeature
(
'greatest_least_ignores_nulls'
)
def
test_ignores_null
(
self
):
now
=
timezone
.
now
()
Article
.
objects
.
create
(
title
=
'Testing with Django'
,
written
=
now
)
articles
=
Article
.
objects
.
annotate
(
last_updated
=
Greatest
(
'written'
,
'published'
))
self
.
assertEqual
(
articles
.
first
()
.
last_updated
,
now
)
@skipIfDBFeature
(
'greatest_least_ignores_nulls'
)
def
test_propagates_null
(
self
):
Article
.
objects
.
create
(
title
=
'Testing with Django'
,
written
=
timezone
.
now
())
articles
=
Article
.
objects
.
annotate
(
last_updated
=
Greatest
(
'written'
,
'published'
))
self
.
assertIsNone
(
articles
.
first
()
.
last_updated
)
@skipIf
(
connection
.
vendor
==
'mysql'
,
"This doesn't work on MySQL"
)
def
test_coalesce_workaround
(
self
):
past
=
datetime
(
1900
,
1
,
1
)
now
=
timezone
.
now
()
Article
.
objects
.
create
(
title
=
'Testing with Django'
,
written
=
now
)
articles
=
Article
.
objects
.
annotate
(
last_updated
=
Greatest
(
Coalesce
(
'written'
,
past
),
Coalesce
(
'published'
,
past
),
),
)
self
.
assertEqual
(
articles
.
first
()
.
last_updated
,
now
)
@skipUnless
(
connection
.
vendor
==
'mysql'
,
"MySQL-specific workaround"
)
def
test_coalesce_workaround_mysql
(
self
):
past
=
datetime
(
1900
,
1
,
1
)
now
=
timezone
.
now
()
Article
.
objects
.
create
(
title
=
'Testing with Django'
,
written
=
now
)
past_sql
=
RawSQL
(
"cast(
%
s as datetime)"
,
(
past
,))
articles
=
Article
.
objects
.
annotate
(
last_updated
=
Greatest
(
Coalesce
(
'written'
,
past_sql
),
Coalesce
(
'published'
,
past_sql
),
),
)
self
.
assertEqual
(
articles
.
first
()
.
last_updated
,
now
)
def
test_all_null
(
self
):
Article
.
objects
.
create
(
title
=
'Testing with Django'
,
written
=
timezone
.
now
())
articles
=
Article
.
objects
.
annotate
(
last_updated
=
Greatest
(
'published'
,
'updated'
))
self
.
assertIsNone
(
articles
.
first
()
.
last_updated
)
def
test_one_expressions
(
self
):
with
self
.
assertRaisesMessage
(
ValueError
,
'Greatest must take at least two expressions'
):
Greatest
(
'written'
)
def
test_related_field
(
self
):
author
=
Author
.
objects
.
create
(
name
=
'John Smith'
,
age
=
45
)
Fan
.
objects
.
create
(
name
=
'Margaret'
,
age
=
50
,
author
=
author
)
authors
=
Author
.
objects
.
annotate
(
highest_age
=
Greatest
(
'age'
,
'fans__age'
))
self
.
assertEqual
(
authors
.
first
()
.
highest_age
,
50
)
def
test_update
(
self
):
author
=
Author
.
objects
.
create
(
name
=
'James Smith'
,
goes_by
=
'Jim'
)
Author
.
objects
.
update
(
alias
=
Greatest
(
'name'
,
'goes_by'
))
author
.
refresh_from_db
()
self
.
assertEqual
(
author
.
alias
,
'Jim'
)
def
test_decimal_filter
(
self
):
obj
=
DecimalModel
.
objects
.
create
(
n1
=
Decimal
(
'1.1'
),
n2
=
Decimal
(
'1.2'
))
self
.
assertCountEqual
(
DecimalModel
.
objects
.
annotate
(
greatest
=
Greatest
(
'n1'
,
'n2'
),
)
.
filter
(
greatest
=
Decimal
(
'1.2'
)),
[
obj
],
)
tests/db_functions/comparison/test_least.py
0 → 100644
Dosyayı görüntüle @
5c3db0ef
from
datetime
import
datetime
,
timedelta
from
decimal
import
Decimal
from
unittest
import
skipIf
,
skipUnless
from
django.db
import
connection
from
django.db.models.expressions
import
RawSQL
from
django.db.models.functions
import
Coalesce
,
Least
from
django.test
import
TestCase
,
skipIfDBFeature
,
skipUnlessDBFeature
from
django.utils
import
timezone
from
..models
import
Article
,
Author
,
DecimalModel
,
Fan
class
LeastTests
(
TestCase
):
def
test_basic
(
self
):
now
=
timezone
.
now
()
before
=
now
-
timedelta
(
hours
=
1
)
Article
.
objects
.
create
(
title
=
'Testing with Django'
,
written
=
before
,
published
=
now
)
articles
=
Article
.
objects
.
annotate
(
first_updated
=
Least
(
'written'
,
'published'
))
self
.
assertEqual
(
articles
.
first
()
.
first_updated
,
before
)
@skipUnlessDBFeature
(
'greatest_least_ignores_nulls'
)
def
test_ignores_null
(
self
):
now
=
timezone
.
now
()
Article
.
objects
.
create
(
title
=
'Testing with Django'
,
written
=
now
)
articles
=
Article
.
objects
.
annotate
(
first_updated
=
Least
(
'written'
,
'published'
),
)
self
.
assertEqual
(
articles
.
first
()
.
first_updated
,
now
)
@skipIfDBFeature
(
'greatest_least_ignores_nulls'
)
def
test_propagates_null
(
self
):
Article
.
objects
.
create
(
title
=
'Testing with Django'
,
written
=
timezone
.
now
())
articles
=
Article
.
objects
.
annotate
(
first_updated
=
Least
(
'written'
,
'published'
))
self
.
assertIsNone
(
articles
.
first
()
.
first_updated
)
@skipIf
(
connection
.
vendor
==
'mysql'
,
"This doesn't work on MySQL"
)
def
test_coalesce_workaround
(
self
):
future
=
datetime
(
2100
,
1
,
1
)
now
=
timezone
.
now
()
Article
.
objects
.
create
(
title
=
'Testing with Django'
,
written
=
now
)
articles
=
Article
.
objects
.
annotate
(
last_updated
=
Least
(
Coalesce
(
'written'
,
future
),
Coalesce
(
'published'
,
future
),
),
)
self
.
assertEqual
(
articles
.
first
()
.
last_updated
,
now
)
@skipUnless
(
connection
.
vendor
==
'mysql'
,
"MySQL-specific workaround"
)
def
test_coalesce_workaround_mysql
(
self
):
future
=
datetime
(
2100
,
1
,
1
)
now
=
timezone
.
now
()
Article
.
objects
.
create
(
title
=
'Testing with Django'
,
written
=
now
)
future_sql
=
RawSQL
(
"cast(
%
s as datetime)"
,
(
future
,))
articles
=
Article
.
objects
.
annotate
(
last_updated
=
Least
(
Coalesce
(
'written'
,
future_sql
),
Coalesce
(
'published'
,
future_sql
),
),
)
self
.
assertEqual
(
articles
.
first
()
.
last_updated
,
now
)
def
test_all_null
(
self
):
Article
.
objects
.
create
(
title
=
'Testing with Django'
,
written
=
timezone
.
now
())
articles
=
Article
.
objects
.
annotate
(
first_updated
=
Least
(
'published'
,
'updated'
))
self
.
assertIsNone
(
articles
.
first
()
.
first_updated
)
def
test_one_expressions
(
self
):
with
self
.
assertRaisesMessage
(
ValueError
,
'Least must take at least two expressions'
):
Least
(
'written'
)
def
test_related_field
(
self
):
author
=
Author
.
objects
.
create
(
name
=
'John Smith'
,
age
=
45
)
Fan
.
objects
.
create
(
name
=
'Margaret'
,
age
=
50
,
author
=
author
)
authors
=
Author
.
objects
.
annotate
(
lowest_age
=
Least
(
'age'
,
'fans__age'
))
self
.
assertEqual
(
authors
.
first
()
.
lowest_age
,
45
)
def
test_update
(
self
):
author
=
Author
.
objects
.
create
(
name
=
'James Smith'
,
goes_by
=
'Jim'
)
Author
.
objects
.
update
(
alias
=
Least
(
'name'
,
'goes_by'
))
author
.
refresh_from_db
()
self
.
assertEqual
(
author
.
alias
,
'James Smith'
)
def
test_decimal_filter
(
self
):
obj
=
DecimalModel
.
objects
.
create
(
n1
=
Decimal
(
'1.1'
),
n2
=
Decimal
(
'1.2'
))
self
.
assertCountEqual
(
DecimalModel
.
objects
.
annotate
(
least
=
Least
(
'n1'
,
'n2'
),
)
.
filter
(
least
=
Decimal
(
'1.1'
)),
[
obj
],
)
tests/db_functions/tests.py
Dosyayı görüntüle @
5c3db0ef
This diff is collapsed.
Click to expand it.
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment