mirror of
				https://github.com/django/django.git
				synced 2025-10-26 15:16:09 +00:00 
			
		
		
		
	Fixed #15035 -- Fixed collectstatic management command to work with non-local storage backends correctly. Also refactored a bit code smell.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@15154 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
		
							
								
								
									
										19
									
								
								tests/regressiontests/staticfiles_tests/storage.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										19
									
								
								tests/regressiontests/staticfiles_tests/storage.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,19 @@ | ||||
| from datetime import datetime | ||||
| from django.core.files import storage | ||||
|  | ||||
| class DummyStorage(storage.Storage): | ||||
|     """ | ||||
|     A storage class that does implement modified_time() but raises | ||||
|     NotImplementedError when calling  | ||||
|     """ | ||||
|     def _save(self, name, content): | ||||
|         return 'dummy' | ||||
|  | ||||
|     def delete(self, name): | ||||
|         pass | ||||
|  | ||||
|     def exists(self, name): | ||||
|         pass | ||||
|  | ||||
|     def modified_time(self, name): | ||||
|         return datetime.date(1970, 1, 1) | ||||
| @@ -92,7 +92,6 @@ class BuildStaticTestCase(StaticFilesTestCase): | ||||
|     """ | ||||
|     def setUp(self): | ||||
|         super(BuildStaticTestCase, self).setUp() | ||||
|         self.old_staticfiles_storage = settings.STATICFILES_STORAGE | ||||
|         self.old_root = settings.STATIC_ROOT | ||||
|         settings.STATIC_ROOT = tempfile.mkdtemp() | ||||
|         self.run_collectstatic() | ||||
| @@ -220,18 +219,35 @@ class TestBuildStaticExcludeNoDefaultIgnore(BuildStaticTestCase, TestDefaults): | ||||
|         self.assertFileContains('test/CVS', 'should be ignored') | ||||
|  | ||||
|  | ||||
| class TestBuildStaticDryRun(BuildStaticTestCase): | ||||
| class TestNoFilesCreated(object): | ||||
|  | ||||
|     def test_no_files_created(self): | ||||
|         """ | ||||
|         Make sure no files were create in the destination directory. | ||||
|         """ | ||||
|         self.assertEquals(os.listdir(settings.STATIC_ROOT), []) | ||||
|  | ||||
|  | ||||
| class TestBuildStaticDryRun(BuildStaticTestCase, TestNoFilesCreated): | ||||
|     """ | ||||
|     Test ``--dry-run`` option for ``collectstatic`` management command. | ||||
|     """ | ||||
|     def run_collectstatic(self): | ||||
|         super(TestBuildStaticDryRun, self).run_collectstatic(dry_run=True) | ||||
|  | ||||
|     def test_no_files_created(self): | ||||
|         """ | ||||
|         With --dry-run, no files created in destination dir. | ||||
|         """ | ||||
|         self.assertEquals(os.listdir(settings.STATIC_ROOT), []) | ||||
|  | ||||
| class TestBuildStaticNonLocalStorage(BuildStaticTestCase, TestNoFilesCreated): | ||||
|     """ | ||||
|     Tests for #15035 | ||||
|     """ | ||||
|     def setUp(self): | ||||
|         self.old_staticfiles_storage = settings.STATICFILES_STORAGE | ||||
|         settings.STATICFILES_STORAGE = 'regressiontests.staticfiles_tests.storage.DummyStorage' | ||||
|         super(TestBuildStaticNonLocalStorage, self).setUp() | ||||
|  | ||||
|     def tearDown(self): | ||||
|         super(TestBuildStaticNonLocalStorage, self).tearDown() | ||||
|         settings.STATICFILES_STORAGE = self.old_staticfiles_storage | ||||
|  | ||||
|  | ||||
| if sys.platform != 'win32': | ||||
|   | ||||
		Reference in New Issue
	
	Block a user