mirror of
				https://github.com/django/django.git
				synced 2025-10-24 22:26:08 +00:00 
			
		
		
		
	Improved test coverage for startapp/startproject management commands.
This commit is contained in:
		| @@ -1905,6 +1905,25 @@ class StartProject(LiveServerTestCase, AdminScriptTestCase): | ||||
|             ) | ||||
|             self.assertFalse(os.path.exists(testproject_dir)) | ||||
|  | ||||
|     def test_importable_project_name(self): | ||||
|         """ | ||||
|         startproject validates that project name doesn't clash with existing | ||||
|         Python modules. | ||||
|         """ | ||||
|         bad_name = 'os' | ||||
|         args = ['startproject', bad_name] | ||||
|         testproject_dir = os.path.join(self.test_dir, bad_name) | ||||
|         self.addCleanup(shutil.rmtree, testproject_dir, True) | ||||
|  | ||||
|         out, err = self.run_django_admin(args) | ||||
|         self.assertOutput( | ||||
|             err, | ||||
|             "CommandError: 'os' conflicts with the name of an existing " | ||||
|             "Python module and cannot be used as a project name. Please try " | ||||
|             "another name." | ||||
|         ) | ||||
|         self.assertFalse(os.path.exists(testproject_dir)) | ||||
|  | ||||
|     def test_simple_project_different_directory(self): | ||||
|         "Make sure the startproject management command creates a project in a specific directory" | ||||
|         args = ['startproject', 'testproject', 'othertestproject'] | ||||
| @@ -2085,6 +2104,43 @@ class StartProject(LiveServerTestCase, AdminScriptTestCase): | ||||
|                 'üäö €']) | ||||
|  | ||||
|  | ||||
| class StartApp(AdminScriptTestCase): | ||||
|  | ||||
|     def test_invalid_name(self): | ||||
|         """startapp validates that app name is a valid Python identifier.""" | ||||
|         for bad_name in ('7testproject', '../testproject'): | ||||
|             args = ['startapp', bad_name] | ||||
|             testproject_dir = os.path.join(self.test_dir, bad_name) | ||||
|             self.addCleanup(shutil.rmtree, testproject_dir, True) | ||||
|  | ||||
|             out, err = self.run_django_admin(args) | ||||
|             self.assertOutput( | ||||
|                 err, | ||||
|                 "CommandError: '{}' is not a valid app name. Please make " | ||||
|                 "sure the name is a valid identifier.".format(bad_name) | ||||
|             ) | ||||
|             self.assertFalse(os.path.exists(testproject_dir)) | ||||
|  | ||||
|     def test_importable_name(self): | ||||
|         """ | ||||
|         startapp validates that app name doesn't clash with existing Python | ||||
|         modules. | ||||
|         """ | ||||
|         bad_name = 'os' | ||||
|         args = ['startapp', bad_name] | ||||
|         testproject_dir = os.path.join(self.test_dir, bad_name) | ||||
|         self.addCleanup(shutil.rmtree, testproject_dir, True) | ||||
|  | ||||
|         out, err = self.run_django_admin(args) | ||||
|         self.assertOutput( | ||||
|             err, | ||||
|             "CommandError: 'os' conflicts with the name of an existing " | ||||
|             "Python module and cannot be used as an app name. Please try " | ||||
|             "another name." | ||||
|         ) | ||||
|         self.assertFalse(os.path.exists(testproject_dir)) | ||||
|  | ||||
|  | ||||
| class DiffSettings(AdminScriptTestCase): | ||||
|     """Tests for diffsettings management command.""" | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user