Loading django/core/management/commands/startapp.py +1 −2 Original line number Diff line number Diff line Loading @@ -9,8 +9,7 @@ class Command(TemplateCommand): "directory.") def handle(self, app_name=None, target=None, **options): if app_name is None: raise CommandError("you must provide an app name") self.validate_name(app_name, "app") # Check that the app_name cannot be imported. try: Loading django/core/management/commands/startproject.py +1 −2 Original line number Diff line number Diff line Loading @@ -10,8 +10,7 @@ class Command(TemplateCommand): "given directory.") def handle(self, project_name=None, target=None, *args, **options): if project_name is None: raise CommandError("you must provide a project name") self.validate_name(project_name, "project") # Check that the project_name cannot be imported. try: Loading django/core/management/templates.py +15 −10 Original line number Diff line number Diff line Loading @@ -67,16 +67,7 @@ class TemplateCommand(BaseCommand): self.paths_to_remove = [] self.verbosity = int(options.get('verbosity')) # If it's not a valid directory name. if not re.search(r'^[_a-zA-Z]\w*$', name): # Provide a smart error message, depending on the error. if not re.search(r'^[_a-zA-Z]', name): message = ('make sure the name begins ' 'with a letter or underscore') else: message = 'use only numbers, letters and underscores' raise CommandError("%r is not a valid %s name. Please %s." % (name, app_or_project, message)) self.validate_name(name, app_or_project) # if some directory is given, make sure it's nicely expanded if target is None: Loading Loading @@ -211,6 +202,20 @@ class TemplateCommand(BaseCommand): raise CommandError("couldn't handle %s template %s." % (self.app_or_project, template)) def validate_name(self, name, app_or_project): if name is None: raise CommandError("you must provide %s %s name" % ( "an" if app_or_project == "app" else "a", app_or_project)) # If it's not a valid directory name. if not re.search(r'^[_a-zA-Z]\w*$', name): # Provide a smart error message, depending on the error. if not re.search(r'^[_a-zA-Z]', name): message = 'make sure the name begins with a letter or underscore' else: message = 'use only numbers, letters and underscores' raise CommandError("%r is not a valid %s name. Please %s." % (name, app_or_project, message)) def download(self, url): """ Downloads the given URL and returns the file name. Loading tests/regressiontests/admin_scripts/tests.py +9 −7 Original line number Diff line number Diff line Loading @@ -1430,12 +1430,14 @@ class StartProject(LiveServerTestCase, AdminScriptTestCase): def test_invalid_project_name(self): "Make sure the startproject management command validates a project name" args = ['startproject', '7testproject'] testproject_dir = os.path.join(test_dir, '7testproject') for bad_name in ('7testproject', '../testproject'): args = ['startproject', bad_name] testproject_dir = os.path.join(test_dir, bad_name) self.addCleanup(shutil.rmtree, testproject_dir, True) out, err = self.run_django_admin(args) self.assertOutput(err, "Error: '7testproject' is not a valid project name. Please make sure the name begins with a letter or underscore.") self.assertOutput(err, "Error: '%s' is not a valid project name. " "Please make sure the name begins with a letter or underscore." % bad_name) self.assertFalse(os.path.exists(testproject_dir)) def test_simple_project_different_directory(self): Loading Loading
django/core/management/commands/startapp.py +1 −2 Original line number Diff line number Diff line Loading @@ -9,8 +9,7 @@ class Command(TemplateCommand): "directory.") def handle(self, app_name=None, target=None, **options): if app_name is None: raise CommandError("you must provide an app name") self.validate_name(app_name, "app") # Check that the app_name cannot be imported. try: Loading
django/core/management/commands/startproject.py +1 −2 Original line number Diff line number Diff line Loading @@ -10,8 +10,7 @@ class Command(TemplateCommand): "given directory.") def handle(self, project_name=None, target=None, *args, **options): if project_name is None: raise CommandError("you must provide a project name") self.validate_name(project_name, "project") # Check that the project_name cannot be imported. try: Loading
django/core/management/templates.py +15 −10 Original line number Diff line number Diff line Loading @@ -67,16 +67,7 @@ class TemplateCommand(BaseCommand): self.paths_to_remove = [] self.verbosity = int(options.get('verbosity')) # If it's not a valid directory name. if not re.search(r'^[_a-zA-Z]\w*$', name): # Provide a smart error message, depending on the error. if not re.search(r'^[_a-zA-Z]', name): message = ('make sure the name begins ' 'with a letter or underscore') else: message = 'use only numbers, letters and underscores' raise CommandError("%r is not a valid %s name. Please %s." % (name, app_or_project, message)) self.validate_name(name, app_or_project) # if some directory is given, make sure it's nicely expanded if target is None: Loading Loading @@ -211,6 +202,20 @@ class TemplateCommand(BaseCommand): raise CommandError("couldn't handle %s template %s." % (self.app_or_project, template)) def validate_name(self, name, app_or_project): if name is None: raise CommandError("you must provide %s %s name" % ( "an" if app_or_project == "app" else "a", app_or_project)) # If it's not a valid directory name. if not re.search(r'^[_a-zA-Z]\w*$', name): # Provide a smart error message, depending on the error. if not re.search(r'^[_a-zA-Z]', name): message = 'make sure the name begins with a letter or underscore' else: message = 'use only numbers, letters and underscores' raise CommandError("%r is not a valid %s name. Please %s." % (name, app_or_project, message)) def download(self, url): """ Downloads the given URL and returns the file name. Loading
tests/regressiontests/admin_scripts/tests.py +9 −7 Original line number Diff line number Diff line Loading @@ -1430,12 +1430,14 @@ class StartProject(LiveServerTestCase, AdminScriptTestCase): def test_invalid_project_name(self): "Make sure the startproject management command validates a project name" args = ['startproject', '7testproject'] testproject_dir = os.path.join(test_dir, '7testproject') for bad_name in ('7testproject', '../testproject'): args = ['startproject', bad_name] testproject_dir = os.path.join(test_dir, bad_name) self.addCleanup(shutil.rmtree, testproject_dir, True) out, err = self.run_django_admin(args) self.assertOutput(err, "Error: '7testproject' is not a valid project name. Please make sure the name begins with a letter or underscore.") self.assertOutput(err, "Error: '%s' is not a valid project name. " "Please make sure the name begins with a letter or underscore." % bad_name) self.assertFalse(os.path.exists(testproject_dir)) def test_simple_project_different_directory(self): Loading