mirror of
				https://github.com/django/django.git
				synced 2025-10-25 06:36:07 +00:00 
			
		
		
		
	Updated testing documentation following 498ae3a360
				
					
				
			- commit/rollback are no longer replaced by nop - the warning about not using TestCase when testing transactional behavior belongs to TestCase section, not TransactionTestCase
This commit is contained in:
		
				
					committed by
					
						 Tim Graham
						Tim Graham
					
				
			
			
				
	
			
			
			
						parent
						
							d049b36f91
						
					
				
				
					commit
					3199ea8ed7
				
			| @@ -633,10 +633,20 @@ TransactionTestCase | |||||||
|  |  | ||||||
| Django's ``TestCase`` class (described below) makes use of database transaction | Django's ``TestCase`` class (described below) makes use of database transaction | ||||||
| facilities to speed up the process of resetting the database to a known state | facilities to speed up the process of resetting the database to a known state | ||||||
| at the beginning of each test. A consequence of this, however, is that the | at the beginning of each test. A consequence of this, however, is that some | ||||||
| effects of transaction commit and rollback cannot be tested by a Django | database behaviors cannot be tested within a Django ``TestCase`` class. For | ||||||
| ``TestCase`` class. If your test requires testing of such transactional | instance, you cannot test that a block of code is executing within a | ||||||
| behavior, you should use a Django ``TransactionTestCase``. | transaction, as is required when using | ||||||
|  | :meth:`~django.db.models.query.QuerySet.select_for_update()`. In those cases, | ||||||
|  | you should use ``TransactionTestCase``. | ||||||
|  |  | ||||||
|  | .. versionchanged:: 1.8 | ||||||
|  |  | ||||||
|  |     In older versions of Django, the effects of transaction commit and rollback | ||||||
|  |     could not be tested within a ``TestCase``.  With the completion of the | ||||||
|  |     deprecation cycle of the old-style transaction management in Django 1.8, | ||||||
|  |     transaction management commands (e.g. ``transaction.commit()``) are no | ||||||
|  |     longer disabled within ``TestCase``. | ||||||
|  |  | ||||||
| ``TransactionTestCase`` and ``TestCase`` are identical except for the manner | ``TransactionTestCase`` and ``TestCase`` are identical except for the manner | ||||||
| in which the database is reset to a known state and the ability for test code | in which the database is reset to a known state and the ability for test code | ||||||
| @@ -648,11 +658,8 @@ to test the effects of commit and rollback: | |||||||
|  |  | ||||||
| * A ``TestCase``, on the other hand, does not truncate tables after a test. | * A ``TestCase``, on the other hand, does not truncate tables after a test. | ||||||
|   Instead, it encloses the test code in a database transaction that is rolled |   Instead, it encloses the test code in a database transaction that is rolled | ||||||
|   back at the end of the test. Both explicit commits like |   back at the end of the test. This guarantees that the rollback at the end of | ||||||
|   ``transaction.commit()`` and implicit ones that may be caused by |   the test restores the database to its initial state. | ||||||
|   ``transaction.atomic()`` are replaced with a ``nop`` operation. This |  | ||||||
|   guarantees that the rollback at the end of the test restores the database to |  | ||||||
|   its initial state. |  | ||||||
|  |  | ||||||
| .. warning:: | .. warning:: | ||||||
|  |  | ||||||
| @@ -666,16 +673,6 @@ to test the effects of commit and rollback: | |||||||
|   this) you can set ``serialized_rollback = True`` inside the |   this) you can set ``serialized_rollback = True`` inside the | ||||||
|   ``TestCase`` body. |   ``TestCase`` body. | ||||||
|  |  | ||||||
| .. warning:: |  | ||||||
|  |  | ||||||
|     While ``commit`` and ``rollback`` operations still *appear* to work when |  | ||||||
|     used in ``TestCase``, no actual commit or rollback will be performed by the |  | ||||||
|     database. This can cause your tests to pass or fail unexpectedly. Always |  | ||||||
|     use ``TransactionTestCase`` when testing transactional behavior or any code |  | ||||||
|     that can't normally be executed in autocommit mode |  | ||||||
|     (:meth:`~django.db.models.query.QuerySet.select_for_update()` is an |  | ||||||
|     example). |  | ||||||
|  |  | ||||||
| ``TransactionTestCase`` inherits from :class:`~django.test.SimpleTestCase`. | ``TransactionTestCase`` inherits from :class:`~django.test.SimpleTestCase`. | ||||||
|  |  | ||||||
| TestCase | TestCase | ||||||
| @@ -701,6 +698,12 @@ additions, including: | |||||||
| * Django-specific assertions for testing for things like redirection and form | * Django-specific assertions for testing for things like redirection and form | ||||||
|   errors. |   errors. | ||||||
|  |  | ||||||
|  | .. warning:: | ||||||
|  |  | ||||||
|  |     If you want to test some specific database transaction behavior, you should | ||||||
|  |     use ``TransactionTestCase``, as ``TestCase`` wraps test execution within an | ||||||
|  |     :func:`~django.db.transaction.atomic()` block. | ||||||
|  |  | ||||||
| ``TestCase`` inherits from :class:`~django.test.TransactionTestCase`. | ``TestCase`` inherits from :class:`~django.test.TransactionTestCase`. | ||||||
|  |  | ||||||
| .. _live-test-server: | .. _live-test-server: | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user