mirror of
https://github.com/django/django.git
synced 2024-12-26 02:56:25 +00:00
e94d293504
other database backends, but the exception classes should still be the same. This commit changes the way the tests check for specific database errors to be more portable between implementations. It's possible these tests will still fail if, e.g., Oracle doesn't raise IntegrityError (but raises DatabaseError) when we except it to, but we can cross that bridge if and when it appears. git-svn-id: http://code.djangoproject.com/svn/django/trunk@8450 bcc190cf-cafb-0310-a4f2-bffc1f526a37
65 lines
1.7 KiB
Python
65 lines
1.7 KiB
Python
"""
|
|
Tests for forcing insert and update queries (instead of Django's normal
|
|
automatic behaviour).
|
|
"""
|
|
from django.db import models, transaction, IntegrityError
|
|
|
|
class Counter(models.Model):
|
|
name = models.CharField(max_length = 10)
|
|
value = models.IntegerField()
|
|
|
|
class WithCustomPK(models.Model):
|
|
name = models.IntegerField(primary_key=True)
|
|
value = models.IntegerField()
|
|
|
|
__test__ = {"API_TESTS": """
|
|
>>> c = Counter.objects.create(name="one", value=1)
|
|
|
|
# The normal case
|
|
>>> c.value = 2
|
|
>>> c.save()
|
|
|
|
# Same thing, via an update
|
|
>>> c.value = 3
|
|
>>> c.save(force_update=True)
|
|
|
|
# Won't work because force_update and force_insert are mutually exclusive
|
|
>>> c.value = 4
|
|
>>> c.save(force_insert=True, force_update=True)
|
|
Traceback (most recent call last):
|
|
...
|
|
ValueError: Cannot force both insert and updating in model saving.
|
|
|
|
# Try to update something that doesn't have a primary key in the first place.
|
|
>>> c1 = Counter(name="two", value=2)
|
|
>>> c1.save(force_update=True)
|
|
Traceback (most recent call last):
|
|
...
|
|
ValueError: Cannot force an update in save() with no primary key.
|
|
|
|
>>> c1.save(force_insert=True)
|
|
|
|
# Won't work because we can't insert a pk of the same value.
|
|
>>> sid = transaction.savepoint()
|
|
>>> c.value = 5
|
|
>>> try:
|
|
... c.save(force_insert=True)
|
|
... except Exception, e:
|
|
... if isinstance(e, IntegrityError):
|
|
... print "Pass"
|
|
... else:
|
|
... print "Fail with %s" % type(e)
|
|
Pass
|
|
>>> transaction.savepoint_rollback(sid)
|
|
|
|
# Trying to update should still fail, even with manual primary keys, if the
|
|
# data isn't in the database already.
|
|
>>> obj = WithCustomPK(name=1, value=1)
|
|
>>> obj.save(force_update=True)
|
|
Traceback (most recent call last):
|
|
...
|
|
DatabaseError: ...
|
|
|
|
"""
|
|
}
|