mirror of
https://github.com/django/django.git
synced 2025-08-04 19:08:28 +00:00
Merged regressiontests and modeltests into the test root.
This commit is contained in:
parent
b3d2ccb5bf
commit
89f40e3624
1050 changed files with 0 additions and 0 deletions
0
tests/string_lookup/__init__.py
Normal file
0
tests/string_lookup/__init__.py
Normal file
55
tests/string_lookup/models.py
Normal file
55
tests/string_lookup/models.py
Normal file
|
@ -0,0 +1,55 @@
|
|||
# -*- coding: utf-8 -*-
|
||||
from __future__ import unicode_literals
|
||||
|
||||
from django.db import models
|
||||
from django.utils.encoding import python_2_unicode_compatible
|
||||
|
||||
|
||||
@python_2_unicode_compatible
|
||||
class Foo(models.Model):
|
||||
name = models.CharField(max_length=50)
|
||||
friend = models.CharField(max_length=50, blank=True)
|
||||
|
||||
def __str__(self):
|
||||
return "Foo %s" % self.name
|
||||
|
||||
@python_2_unicode_compatible
|
||||
class Bar(models.Model):
|
||||
name = models.CharField(max_length=50)
|
||||
normal = models.ForeignKey(Foo, related_name='normal_foo')
|
||||
fwd = models.ForeignKey("Whiz")
|
||||
back = models.ForeignKey("Foo")
|
||||
|
||||
def __str__(self):
|
||||
return "Bar %s" % self.place.name
|
||||
|
||||
@python_2_unicode_compatible
|
||||
class Whiz(models.Model):
|
||||
name = models.CharField(max_length=50)
|
||||
|
||||
def __str__(self):
|
||||
return "Whiz %s" % self.name
|
||||
|
||||
@python_2_unicode_compatible
|
||||
class Child(models.Model):
|
||||
parent = models.OneToOneField('Base')
|
||||
name = models.CharField(max_length=50)
|
||||
|
||||
def __str__(self):
|
||||
return "Child %s" % self.name
|
||||
|
||||
@python_2_unicode_compatible
|
||||
class Base(models.Model):
|
||||
name = models.CharField(max_length=50)
|
||||
|
||||
def __str__(self):
|
||||
return "Base %s" % self.name
|
||||
|
||||
@python_2_unicode_compatible
|
||||
class Article(models.Model):
|
||||
name = models.CharField(max_length=50)
|
||||
text = models.TextField()
|
||||
submitted_from = models.IPAddressField(blank=True, null=True)
|
||||
|
||||
def __str__(self):
|
||||
return "Article %s" % self.name
|
81
tests/string_lookup/tests.py
Normal file
81
tests/string_lookup/tests.py
Normal file
|
@ -0,0 +1,81 @@
|
|||
# -*- coding: utf-8 -*-
|
||||
from __future__ import absolute_import, unicode_literals
|
||||
|
||||
from django.test import TestCase
|
||||
from .models import Foo, Whiz, Bar, Article, Base, Child
|
||||
|
||||
|
||||
class StringLookupTests(TestCase):
|
||||
|
||||
def test_string_form_referencing(self):
|
||||
"""
|
||||
Regression test for #1661 and #1662
|
||||
|
||||
Check that string form referencing of
|
||||
models works, both as pre and post reference, on all RelatedField types.
|
||||
"""
|
||||
|
||||
f1 = Foo(name="Foo1")
|
||||
f1.save()
|
||||
f2 = Foo(name="Foo2")
|
||||
f2.save()
|
||||
|
||||
w1 = Whiz(name="Whiz1")
|
||||
w1.save()
|
||||
|
||||
b1 = Bar(name="Bar1", normal=f1, fwd=w1, back=f2)
|
||||
b1.save()
|
||||
|
||||
self.assertEqual(b1.normal, f1)
|
||||
|
||||
self.assertEqual(b1.fwd, w1)
|
||||
|
||||
self.assertEqual(b1.back, f2)
|
||||
|
||||
base1 = Base(name="Base1")
|
||||
base1.save()
|
||||
|
||||
child1 = Child(name="Child1", parent=base1)
|
||||
child1.save()
|
||||
|
||||
self.assertEqual(child1.parent, base1)
|
||||
|
||||
def test_unicode_chars_in_queries(self):
|
||||
"""
|
||||
Regression tests for #3937
|
||||
|
||||
make sure we can use unicode characters in queries.
|
||||
If these tests fail on MySQL, it's a problem with the test setup.
|
||||
A properly configured UTF-8 database can handle this.
|
||||
"""
|
||||
|
||||
fx = Foo(name='Bjorn', friend='François')
|
||||
fx.save()
|
||||
self.assertEqual(Foo.objects.get(friend__contains='\xe7'), fx)
|
||||
|
||||
# We can also do the above query using UTF-8 strings.
|
||||
self.assertEqual(Foo.objects.get(friend__contains=b'\xc3\xa7'), fx)
|
||||
|
||||
def test_queries_on_textfields(self):
|
||||
"""
|
||||
Regression tests for #5087
|
||||
|
||||
make sure we can perform queries on TextFields.
|
||||
"""
|
||||
|
||||
a = Article(name='Test', text='The quick brown fox jumps over the lazy dog.')
|
||||
a.save()
|
||||
self.assertEqual(Article.objects.get(text__exact='The quick brown fox jumps over the lazy dog.'), a)
|
||||
|
||||
self.assertEqual(Article.objects.get(text__contains='quick brown fox'), a)
|
||||
|
||||
def test_ipaddress_on_postgresql(self):
|
||||
"""
|
||||
Regression test for #708
|
||||
|
||||
"like" queries on IP address fields require casting to text (on PostgreSQL).
|
||||
"""
|
||||
a = Article(name='IP test', text='The body', submitted_from='192.0.2.100')
|
||||
a.save()
|
||||
self.assertEqual(repr(Article.objects.filter(submitted_from__contains='192.0.2')),
|
||||
repr([a]))
|
Loading…
Add table
Add a link
Reference in a new issue