Commits

Anonymous committed 6b57688

Fixed #10080 -- Slightly extended the fix made in r10401 by also taking command line options into account that don't have have a default set. Thanks, Claude Paroz.

Comments (0)

Files changed (2)

django/core/management/__init__.py

     # when the script runs from the command line, but since call_command can
     # be called programatically, we need to simulate the loading and handling
     # of defaults (see #10080 for details).
-    defaults = dict([(o.dest, o.default)
-                     for o in klass.option_list
-                     if o.default is not NO_DEFAULT])
+    defaults = {}
+    for opt in klass.option_list:
+        if opt.default is NO_DEFAULT:
+            defaults[opt.dest] = None
+        else:
+            defaults[opt.dest] = opt.default
     defaults.update(options)
 
     return klass.execute(*args, **defaults)

tests/modeltests/user_commands/management/commands/dance.py

     requires_model_validation = True
 
     option_list =[
-        make_option("-s", "--style", default="Rock'n'Roll")
+        make_option("-s", "--style", default="Rock'n'Roll"),
+        make_option("-x", "--example")
     ]
 
     def handle(self, *args, **options):
+        example = options["example"]
         self.stdout.write("I don't feel like dancing %s." % options["style"])