| 1 | from django.core.exceptions import ImproperlyConfigured
|
|---|
| 2 | from django.core.management.base import BaseCommand, CommandError
|
|---|
| 3 | from django.core import serializers
|
|---|
| 4 | from django.utils.datastructures import SortedDict
|
|---|
| 5 |
|
|---|
| 6 | from optparse import make_option
|
|---|
| 7 |
|
|---|
| 8 | class Command(BaseCommand):
|
|---|
| 9 | option_list = BaseCommand.option_list + (
|
|---|
| 10 | make_option('--format', default='json', dest='format',
|
|---|
| 11 | help='Specifies the output serialization format for fixtures.'),
|
|---|
| 12 | make_option('-e', '--exclude', dest='exclude',action='append', default=[],
|
|---|
| 13 | help='App to exclude (use multiple --exclude to exclude multiple apps).'),
|
|---|
| 14 | make_option('--stop-on-errors', action='store_true', dest='stop_on_errors',
|
|---|
| 15 | help='Stop on encountering the first serialization error.'),
|
|---|
| 16 | )
|
|---|
| 17 | help = 'Identify all objects that are causing serialization errors.'
|
|---|
| 18 | args = '[appname ...]'
|
|---|
| 19 |
|
|---|
| 20 | def handle(self, *app_labels, **options):
|
|---|
| 21 | import sys, traceback
|
|---|
| 22 | from django.db.models import get_app, get_apps, get_models, get_model
|
|---|
| 23 |
|
|---|
| 24 | format = options.get('format','json')
|
|---|
| 25 | exclude = options.get('exclude',[])
|
|---|
| 26 | show_traceback = options.get('traceback', False)
|
|---|
| 27 | stop_on_errors = options.get('stop_on_errors', False)
|
|---|
| 28 |
|
|---|
| 29 | excluded_apps = [get_app(app_label) for app_label in exclude]
|
|---|
| 30 |
|
|---|
| 31 | if len(app_labels) == 0:
|
|---|
| 32 | app_list = SortedDict([(app, None) for app in get_apps() if app not in excluded_apps])
|
|---|
| 33 | else:
|
|---|
| 34 | app_list = SortedDict()
|
|---|
| 35 | for label in app_labels:
|
|---|
| 36 | try:
|
|---|
| 37 | app_label, model_label = label.split('.')
|
|---|
| 38 | try:
|
|---|
| 39 | app = get_app(app_label)
|
|---|
| 40 | except ImproperlyConfigured:
|
|---|
| 41 | raise CommandError("Unknown application: %s" % app_label)
|
|---|
| 42 |
|
|---|
| 43 | model = get_model(app_label, model_label)
|
|---|
| 44 | if model is None:
|
|---|
| 45 | raise CommandError("Unknown model: %s.%s" % (app_label, model_label))
|
|---|
| 46 |
|
|---|
| 47 | if app in app_list.keys():
|
|---|
| 48 | if app_list[app] and model not in app_list[app]:
|
|---|
| 49 | app_list[app].append(model)
|
|---|
| 50 | else:
|
|---|
| 51 | app_list[app] = [model]
|
|---|
| 52 | except ValueError:
|
|---|
| 53 | # This is just an app - no model qualifier
|
|---|
| 54 | app_label = label
|
|---|
| 55 | try:
|
|---|
| 56 | app = get_app(app_label)
|
|---|
| 57 | except ImproperlyConfigured:
|
|---|
| 58 | raise CommandError("Unknown application: %s" % app_label)
|
|---|
| 59 | app_list[app] = None
|
|---|
| 60 |
|
|---|
| 61 | # Check that the serialization format exists; this is a shortcut to
|
|---|
| 62 | # avoid collating all the objects and _then_ failing.
|
|---|
| 63 | if format not in serializers.get_public_serializer_formats():
|
|---|
| 64 | raise CommandError("Unknown serialization format: %s" % format)
|
|---|
| 65 |
|
|---|
| 66 | try:
|
|---|
| 67 | serializers.get_serializer(format)
|
|---|
| 68 | except KeyError:
|
|---|
| 69 | raise CommandError("Unknown serialization format: %s" % format)
|
|---|
| 70 |
|
|---|
| 71 | objects = []
|
|---|
| 72 | for app, model_list in app_list.items():
|
|---|
| 73 | if model_list is None:
|
|---|
| 74 | model_list = get_models(app)
|
|---|
| 75 |
|
|---|
| 76 | for model in model_list:
|
|---|
| 77 | if not model._meta.proxy:
|
|---|
| 78 | sys.stderr.write('Searching %s\n' % model)
|
|---|
| 79 | try:
|
|---|
| 80 | # Try serializing the whole lot first, before going one by one
|
|---|
| 81 | serializers.serialize(format, model._default_manager.all())
|
|---|
| 82 | except:
|
|---|
| 83 | for instance in model._default_manager.all():
|
|---|
| 84 | try:
|
|---|
| 85 | serializers.serialize(format, model._default_manager.filter(pk=instance.pk))
|
|---|
| 86 | except Exception, e:
|
|---|
| 87 | sys.stderr.write('\nERROR IN %s instance: %s\n' % (model, `instance`))
|
|---|
| 88 | sys.stdout.write('%s\n' % instance.__dict__)
|
|---|
| 89 | if stop_on_errors:
|
|---|
| 90 | raise
|
|---|
| 91 | else:
|
|---|
| 92 | sys.stderr.write(traceback.format_exc())
|
|---|