2009-11-04 4 views
5

Interessanterweise funktioniert es auch auf der Shell.Django-Tests schlagen mit InternalError fehl: kein solcher Sicherungspunkt. DB: Postgres, übergibt mysql

[MY code which calls Model.objects.get_or_create(...)] 
    File "/usr/lib/python2.5/site-packages/django/db/models/manager.py", line 123, in get_or_create 
    return self.get_query_set().get_or_create(**kwargs) 
    File "/usr/lib/python2.5/site-packages/django/db/models/query.py", line 308, in get_or_create 
    transaction.savepoint_rollback(sid) 
    File "/usr/lib/python2.5/site-packages/django/db/transaction.py", line 199, in savepoint_rollback 
    connection._savepoint_rollback(sid) 
    File "/usr/lib/python2.5/site-packages/django/db/backends/__init__.py", line 67, in _savepoint_rollback 
    self.cursor().execute(self.ops.savepoint_rollback_sql(sid)) 
InternalError: no such savepoint 

Antwort

3

Wenn Sie Code testen möchten, die Transaktionen verwendet, müssen Sie TransactionTestCase statt TestCase

zum Beispiel Unterklasse:

from django.test import TransactionTestCase 

class MyTests(TransactionTestCase): 
    ... 

Es geht wahrscheinlich in MySql, weil du bist Verwendung von MyISAM-Tabellen, die keine Transaktionen unterstützen

Verwandte Themen