mirror of
https://github.com/django/django.git
synced 2025-01-13 20:07:13 +00:00
d725cc9734
A description of the new features can be found in the new [http://www.djangoproject.com/documentation/upload_handing/ upload handling documentation]; the executive summary is that Django will now happily handle uploads of large files without issues. This changes the representation of uploaded files from dictionaries to bona fide objects; see BackwardsIncompatibleChanges for details. git-svn-id: http://code.djangoproject.com/svn/django/trunk@7814 bcc190cf-cafb-0310-a4f2-bffc1f526a37
40 lines
1.4 KiB
Python
40 lines
1.4 KiB
Python
"""
|
|
Tests for file field behavior, and specifically #639, in which Model.save() gets
|
|
called *again* for each FileField. This test will fail if calling an
|
|
auto-manipulator's save() method causes Model.save() to be called more than once.
|
|
"""
|
|
|
|
import os
|
|
import unittest
|
|
from regressiontests.bug639.models import Photo
|
|
from django.http import QueryDict
|
|
from django.utils.datastructures import MultiValueDict
|
|
from django.core.files.uploadedfile import SimpleUploadedFile
|
|
|
|
class Bug639Test(unittest.TestCase):
|
|
|
|
def testBug639(self):
|
|
"""
|
|
Simulate a file upload and check how many times Model.save() gets called.
|
|
"""
|
|
# Grab an image for testing
|
|
img = open(os.path.join(os.path.dirname(__file__), "test.jpg"), "rb").read()
|
|
|
|
# Fake a request query dict with the file
|
|
qd = QueryDict("title=Testing&image=", mutable=True)
|
|
qd["image_file"] = SimpleUploadedFile('test.jpg', img, 'image/jpeg')
|
|
|
|
manip = Photo.AddManipulator()
|
|
manip.do_html2python(qd)
|
|
p = manip.save(qd)
|
|
|
|
# Check the savecount stored on the object (see the model)
|
|
self.assertEqual(p._savecount, 1)
|
|
|
|
def tearDown(self):
|
|
"""
|
|
Make sure to delete the "uploaded" file to avoid clogging /tmp.
|
|
"""
|
|
p = Photo.objects.get()
|
|
os.unlink(p.get_image_filename())
|