last_cleaned_with. execute _clean_changes only if there was a map update

This commit is contained in:
Laura Klünder 2017-07-08 17:53:44 +02:00
parent cc3d72bc7b
commit b85d245360
2 changed files with 34 additions and 3 deletions

View file

@ -0,0 +1,22 @@
# -*- coding: utf-8 -*-
# Generated by Django 1.11.2 on 2017-07-08 15:52
from __future__ import unicode_literals
from django.db import migrations, models
import django.db.models.deletion
class Migration(migrations.Migration):
dependencies = [
('mapdata', '0018_auto_20170708_1752'),
('editor', '0017_changeset_map_update'),
]
operations = [
migrations.AddField(
model_name='changeset',
name='last_cleaned_with',
field=models.ForeignKey(null=True, on_delete=django.db.models.deletion.CASCADE, related_name='checked_changesets', to='mapdata.MapUpdate'),
),
]

View file

@ -49,6 +49,7 @@ class ChangeSet(models.Model):
assigned_to = models.ForeignKey(settings.AUTH_USER_MODEL, null=True, on_delete=models.PROTECT,
related_name='assigned_changesets', verbose_name=_('assigned to'))
map_update = models.OneToOneField(MapUpdate, null=True, related_name='changeset', verbose_name=_('map update'))
last_cleaned_with = models.ForeignKey(MapUpdate, null=True, related_name='checked_changesets')
class Meta:
verbose_name = _('Change Set')
@ -182,8 +183,13 @@ class ChangeSet(models.Model):
return chain(*(changed_objects.values() for changed_objects in self.changed_objects.values()))
def _clean_changes(self):
changed_objects = self.changed_objects_set.all()
with self.lock_to_edit():
with self.lock_to_edit() as changeset:
last_map_update_pk = MapUpdate.last_update()[0]
if changeset.last_cleaned_with_id == last_map_update_pk:
return
changed_objects = changeset.changed_objects_set.all()
# delete changed objects that refer in some way to deleted objects and clean up m2m changes
object_pks = {}
for changed_object in changed_objects:
@ -209,7 +215,7 @@ class ChangeSet(models.Model):
changed_objects = [obj for obj in changed_objects if obj.pk is not None]
# clean updated fields
objects = self.get_objects(many=False, changed_objects=changed_objects, prefetch_related=('groups', ))
objects = changeset.get_objects(many=False, changed_objects=changed_objects, prefetch_related=('groups', ))
for changed_object in changed_objects:
if changed_object.clean_updated_fields(objects):
to_save.add(changed_object)
@ -259,6 +265,9 @@ class ChangeSet(models.Model):
for changed_object in to_save:
changed_object.save(standalone=True)
changeset.last_cleaned_with_id = last_map_update_pk
changeset.save()
"""
Analyse Changes
"""