Opened 16 years ago

Closed 13 years ago

#10200 closed Bug (fixed)

loaddata command does not raise CommandError on errors

Reported by: Lorenzo Gil Sanchez Owned by: nobody
Component: Core (Management commands) Version: dev
Severity: Normal Keywords: exit status
Cc: yishaibeeri Triage Stage: Accepted
Has patch: yes Needs documentation: no
Needs tests: no Patch needs improvement: no
Easy pickings: no UI/UX: no

Description

When there is an error in a fixture being loaded by the command loaddata it prints an error description into stderr and them simple return. I think it would be better to raise a CommandError instead of simple exiting the handle method. My reasons are:

  • You can't easily know the succesfullnes of a loaddata command programmatically. For example, we have a buildbot that load some fixtures and we don't know if it passes this step or not since the exit code is always 0 no matter the data is successfully loaded or not.
  • AFAIK is the standard Django mechanism to report command errors
  • The code that catch this type of exceptions does already print its message to stderr, so we do not lose that functionality.

I'm attaching a patch that fixes this issues with existing tests already fixed.

Attachments (2)

scream-if-error-in-loaddata-command.diff (7.7 KB ) - added by Lorenzo Gil Sanchez 16 years ago.
10200-2.diff (15.8 KB ) - added by Claude Paroz 13 years ago.
Raise CommandError in loaddata

Download all attachments as: .zip

Change History (18)

by Lorenzo Gil Sanchez, 16 years ago

comment:1 by Lorenzo Gil Sanchez, 16 years ago

Has patch: set

comment:2 by (none), 16 years ago

milestone: post-1.0

Milestone post-1.0 deleted

comment:3 by Jacob, 16 years ago

Triage Stage: UnreviewedDesign decision needed

This is a backwards-incompatible change, so we need a very good reason to make this change. I'm not sure your reasons get that far, but I'll leave this open for some more discussion.

comment:4 by Lorenzo Gil Sanchez, 16 years ago

What harm could do this patch to users other than alerting them that they used to have bad fixtures and now they know it?

The only real difference this patch introduces is that loaddata stops trying to load fixtures as soon as one of them is rotten. I think this is a good thing since the previous behaviour could hide obscure bugs in your data.

comment:5 by Phil Mocek, 16 years ago

I noticed what is likely a related problem. When the loaddata
command is used with the auto-generated manage.py, bad syntax
results in silent failure and a return code indicating success.

The built-in usage help shows that the fixture argument is
mandatory:

Usage: manage.py loaddata [options] fixture [fixture ...]

However, manage.py does not report an error when a fixture is not
specified:

$ ./manage.py loaddata
$ echo $?
0

Only when the verbosity level is increased from 0 to 2 is an error
reported, and the return code still indicates success:

$ ./manage.py loaddata --verbosity=1 ; echo $?
0
$ ./manage.py loaddata --verbosity=2 ; echo $?
No fixtures found.
0

Typically, silence implies successful completion. This problem is
particularly troublesome because the syntax for loaddata differs
significantly from that of dumpdata. It took
outside assistance
for me -- new to Django but with a considerable amount of experience
using CLI utilities -- to determine why the following commands
completed with apparent success but left my database empty:

$ ./manage.py dumpdata >data.json
$ ./manage.ph flush
$ ./manage.py loaddata <data.json

comment:6 by anonymous, 16 years ago

Cc: pmocek-django-tickets@… added

comment:7 by Phil Mocek, 16 years ago

Cc: pmocek-django-tickets@… removed

(noticed I receive e-mail updates after commenting regardless of having my address in the CC field)

comment:8 by Chris Beaven, 14 years ago

Severity: Normal
Type: Bug

comment:9 by Julien Phalip, 14 years ago

Patch needs improvement: set

#6397, #11481 and #10849 were closed as dupes. See also related issue in #12007.

Also, the tests need to be updated to use unittest.

comment:10 by Jacob, 13 years ago

Easy pickings: unset
Resolution: duplicate
Status: newclosed
UI/UX: unset

#16026 would solve this one in a quite elegant way. Marking this one a duplicate of that.

comment:11 by yishaibeeri, 13 years ago

Cc: yishaibeeri added
Component: Core (Serialization)Core (Management commands)
Keywords: exit status added
Resolution: duplicate
Status: closedreopened
Triage Stage: Design decision neededAccepted
Version: 1.0SVN

Reopening, as the fix for #16026 did not, eventually, fix this issue. In trunk (as of rev 17029) the exit status of a failed loaddata invocation (e.g., bad value in a fixture causing a DatabaseError) is still 0.

comment:12 by Ramiro Morales, 13 years ago

Needs tests: set

Actually, loaddata code in its current status is such that all error code paths mean:

  • An error is printed to stderr
  • The handle() method returns

So, the only (benefical IMHO) change the change proposed by this ticket would be that the Unix process exit code from zero to a non-zero value.

I suspect the backward-incompatibility reservations Jacob had back then were related to the fact that raising CommandError would mean exiting from the nested loops and aborting execution of the command; but the gradual evolution of the code during the last threee years has resulted is precisely that behavior already

But I'm not sure. Will try to confirm with him.

Version 1, edited 13 years ago by Ramiro Morales (previous) (next) (diff)

comment:13 by anonymous, 13 years ago

Any news about this ?

I've just hit this. We have a buildbot and when the loaddata fails, we cannot easily detect it. So, having run "set -e" in my bash doesn't help in this case, and then tests are run. The tests fail and the error was that loaddata failed, very hidden in the output.

If the exit code of the command could be just like any standard unix command (!=0 on error), that will be great and made life for sysadmins like me happier :)

Btw, we are using django 1.3.1 in case it matters

comment:14 by Claude Paroz, 13 years ago

When #18387 will be committed, we should be able to easily make a clean patch for this one.

by Claude Paroz, 13 years ago

Attachment: 10200-2.diff added

Raise CommandError in loaddata

comment:15 by Claude Paroz, 13 years ago

Needs tests: unset
Patch needs improvement: unset

Here's an updated patch for this issue.

comment:16 by Claude Paroz <claude@…>, 13 years ago

Resolution: fixed
Status: reopenedclosed

In [6fd1950a4e29c1b5ed071a880db64103715ead51]:

Fixed #10200 -- Raised CommandError when errors happen in loaddata.

Note: See TracTickets for help on using tickets.
Back to Top