[1.8.x] Fixed #24826 -- Accounted for filesystem-dependent filename max length

Thanks Raphaël Hertzog for the report and help on the patch, and Tim Graham
for the review.

Backport of 170f7115bb from master
This commit is contained in:
Claude Paroz 2015-05-22 19:43:08 +02:00 committed by Tim Graham
parent ae03d1ac5b
commit 0bfe322bac
1 changed files with 13 additions and 1 deletions

View File

@ -435,6 +435,18 @@ class FileFieldStorageTests(TestCase):
def tearDown(self): def tearDown(self):
shutil.rmtree(temp_storage_location) shutil.rmtree(temp_storage_location)
def _storage_max_filename_length(self, storage):
"""
Query filesystem for maximum filename length (e.g. AUFS has 242).
"""
dir_to_test = storage.location
while not os.path.exists(dir_to_test):
dir_to_test = os.path.dirname(dir_to_test)
try:
return os.pathconf(dir_to_test, 'PC_NAME_MAX')
except Exception:
return 255 # Should be safe on most backends
def test_files(self): def test_files(self):
# Attempting to access a FileField from the class raises a descriptive # Attempting to access a FileField from the class raises a descriptive
# error # error
@ -536,7 +548,7 @@ class FileFieldStorageTests(TestCase):
def test_extended_length_storage(self): def test_extended_length_storage(self):
# Testing FileField with max_length > 255. Most systems have filename # Testing FileField with max_length > 255. Most systems have filename
# length limitation of 255. Path takes extra chars. # length limitation of 255. Path takes extra chars.
filename = 251 * 'a' # 4 chars for extension. filename = (self._storage_max_filename_length(temp_storage) - 4) * 'a' # 4 chars for extension.
obj = Storage() obj = Storage()
obj.extended_length.save('%s.txt' % filename, ContentFile('Same Content')) obj.extended_length.save('%s.txt' % filename, ContentFile('Same Content'))
self.assertEqual(obj.extended_length.name, 'tests/%s.txt' % filename) self.assertEqual(obj.extended_length.name, 'tests/%s.txt' % filename)