| 33 | class GetStorageClassTests(unittest.TestCase): |
| 34 | def assertRaisesErrorWithMessage(self, error, message, callable, |
| 35 | *args, **kwargs): |
| 36 | self.assertRaises(error, callable, *args, **kwargs) |
| 37 | try: |
| 38 | callable(*args, **kwargs) |
| 39 | except error, e: |
| 40 | self.assertEqual(message, str(e)) |
| 41 | |
| 42 | def test_get_filesystem_storage(self): |
| 43 | """ |
| 44 | get_storage_class returns the class for a storage backend name/path. |
| 45 | """ |
| 46 | self.assertEqual( |
| 47 | get_storage_class('django.core.files.storage.FileSystemStorage'), |
| 48 | FileSystemStorage) |
| 49 | |
| 50 | def test_get_invalid_storage_module(self): |
| 51 | """ |
| 52 | get_storage_class raises an error if the requested import don't exist. |
| 53 | """ |
| 54 | self.assertRaisesErrorWithMessage( |
| 55 | ImproperlyConfigured, |
| 56 | "NonExistingStorage isn't a storage module.", |
| 57 | get_storage_class, |
| 58 | 'NonExistingStorage') |
| 59 | |
| 60 | def test_get_nonexisting_storage_class(self): |
| 61 | """ |
| 62 | get_storage_class raises an error if the requested class don't exist. |
| 63 | """ |
| 64 | self.assertRaisesErrorWithMessage( |
| 65 | ImproperlyConfigured, |
| 66 | 'Storage module "django.core.files.storage" does not define a '\ |
| 67 | '"NonExistingStorage" class.', |
| 68 | get_storage_class, |
| 69 | 'django.core.files.storage.NonExistingStorage') |
| 70 | |
| 71 | def test_get_nonexisting_storage_module(self): |
| 72 | """ |
| 73 | get_storage_class raises an error if the requested module don't exist. |
| 74 | """ |
| 75 | self.assertRaisesErrorWithMessage( |
| 76 | ImproperlyConfigured, |
| 77 | 'Error importing storage module django.core.files.non_existing_'\ |
| 78 | 'storage: "No module named non_existing_storage"', |
| 79 | get_storage_class, |
| 80 | 'django.core.files.non_existing_storage.NonExistingStorage') |
| 81 | |
| 111 | def test_file_save_without_name(self): |
| 112 | """ |
| 113 | File storage extracts the filename from the content object if no |
| 114 | name is given explicitly. |
| 115 | """ |
| 116 | self.failIf(self.storage.exists('test.file')) |
| 117 | |
| 118 | f = ContentFile('custom contents') |
| 119 | f.name = 'test.file' |
| 120 | |
| 121 | storage_f_name = self.storage.save(None, f) |
| 122 | |
| 123 | self.assertEqual(storage_f_name, f.name) |
| 124 | |
| 125 | self.assert_(os.path.exists(os.path.join(self.temp_dir, f.name))) |
| 126 | |
| 127 | self.storage.delete(storage_f_name) |
| 128 | |
| 129 | def test_file_path(self): |
| 130 | """ |
| 131 | File storage returns the full path of a file |
| 132 | """ |
| 133 | self.failIf(self.storage.exists('test.file')) |
| 134 | |
| 135 | f = ContentFile('custom contents') |
| 136 | f_name = self.storage.save('test.file', f) |
| 137 | |
| 138 | self.assertEqual(self.storage.path(f_name), |
| 139 | os.path.join(self.temp_dir, f_name)) |
| 140 | |
| 141 | self.storage.delete(f_name) |
| 142 | |
| 143 | def test_file_url(self): |
| 144 | """ |
| 145 | File storage returns a url to access a given file from the web. |
| 146 | """ |
| 147 | self.assertEqual(self.storage.url('test.file'), |
| 148 | '%s%s' % (self.storage.base_url, 'test.file')) |
| 149 | |
| 150 | self.storage.base_url = None |
| 151 | self.assertRaises(ValueError, self.storage.url, 'test.file') |
| 152 | |
| 153 | def test_file_with_mixin(self): |
| 154 | """ |
| 155 | File storage can get a mixin to extend the functionality of the |
| 156 | returned file. |
| 157 | """ |
| 158 | self.failIf(self.storage.exists('test.file')) |
| 159 | |
| 160 | class TestFileMixin(object): |
| 161 | mixed_in = True |
| 162 | |
| 163 | f = ContentFile('custom contents') |
| 164 | f_name = self.storage.save('test.file', f) |
| 165 | |
| 166 | self.assert_(isinstance( |
| 167 | self.storage.open('test.file', mixin=TestFileMixin), |
| 168 | TestFileMixin |
| 169 | )) |
| 170 | |
| 171 | self.storage.delete('test.file') |
| 172 | |
| 173 | def test_listdir(self): |
| 174 | """ |
| 175 | File storage returns a tuple containing directories and files. |
| 176 | """ |
| 177 | self.failIf(self.storage.exists('storage_test_1')) |
| 178 | self.failIf(self.storage.exists('storage_test_2')) |
| 179 | self.failIf(self.storage.exists('storage_dir_1')) |
| 180 | |
| 181 | f = self.storage.save('storage_test_1', ContentFile('custom content')) |
| 182 | f = self.storage.save('storage_test_2', ContentFile('custom content')) |
| 183 | os.mkdir(os.path.join(self.temp_dir, 'storage_dir_1')) |
| 184 | |
| 185 | dirs, files = self.storage.listdir('') |
| 186 | self.assertEqual(set(dirs), set([u'storage_dir_1'])) |
| 187 | self.assertEqual(set(files), |
| 188 | set([u'storage_test_1', u'storage_test_2'])) |
| 189 | |
| 190 | self.storage.delete('storage_test_1') |
| 191 | self.storage.delete('storage_test_2') |
| 192 | os.rmdir(os.path.join(self.temp_dir, 'storage_dir_1')) |
| 193 | |