[1.7.x] Fixed #22772 -- Defer wizard temporary files deletion.

Backport of e2112edd9a from master
This commit is contained in:
Simon Charette 2014-06-06 23:41:15 -04:00
parent 211ff288a0
commit 2b13576c8f
2 changed files with 9 additions and 3 deletions

View File

@ -3,7 +3,7 @@ from importlib import import_module
import os import os
import tempfile import tempfile
from django.http import HttpRequest from django.http import HttpRequest, HttpResponse
from django.conf import settings from django.conf import settings
from django.contrib.auth.models import User from django.contrib.auth.models import User
from django.core.files.storage import FileSystemStorage from django.core.files.storage import FileSystemStorage
@ -107,4 +107,5 @@ class TestStorage(object):
self.assertTrue(storage.file_storage.exists(tmp_name)) self.assertTrue(storage.file_storage.exists(tmp_name))
storage.reset() storage.reset()
storage.update_response(HttpResponse())
self.assertFalse(storage.file_storage.exists(tmp_name)) self.assertFalse(storage.file_storage.exists(tmp_name))

View File

@ -17,6 +17,7 @@ class BaseStorage(object):
self.request = request self.request = request
self.file_storage = file_storage self.file_storage = file_storage
self._files = {} self._files = {}
self._tmp_files = []
def init_data(self): def init_data(self):
self.data = { self.data = {
@ -27,11 +28,13 @@ class BaseStorage(object):
} }
def reset(self): def reset(self):
# Delete temporary files before breaking reference to them. # Store unused temporary file names in order to delete them
# at the end of the response cycle through a callback attached in
# `update_response`.
wizard_files = self.data[self.step_files_key] wizard_files = self.data[self.step_files_key]
for step_files in six.itervalues(wizard_files): for step_files in six.itervalues(wizard_files):
for step_file in six.itervalues(step_files): for step_file in six.itervalues(step_files):
self.file_storage.delete(step_file['tmp_name']) self._tmp_files.append(step_file['tmp_name'])
self.init_data() self.init_data()
def _get_current_step(self): def _get_current_step(self):
@ -118,6 +121,8 @@ class BaseStorage(object):
for file in self._files.values(): for file in self._files.values():
if not file.closed: if not file.closed:
file.close() file.close()
for tmp_file in self._tmp_files:
self.file_storage.delete(tmp_file)
if hasattr(response, 'render'): if hasattr(response, 'render'):
response.add_post_render_callback(post_render_callback) response.add_post_render_callback(post_render_callback)