From 41674d72328a81557d51b2befe6b597ca7065789 Mon Sep 17 00:00:00 2001 From: Luciano Almeida Date: Thu, 10 Nov 2016 18:33:41 -0200 Subject: [PATCH] =?UTF-8?q?Ajusta=20problema=20de=20objetos=20marcados=20p?= =?UTF-8?q?ra=20exclus=C3=A3o?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: Luciano Almeida --- sapl/legacy/migration.py | 32 +++++++++++++++++++------------- 1 file changed, 19 insertions(+), 13 deletions(-) diff --git a/sapl/legacy/migration.py b/sapl/legacy/migration.py index aed78fd88..3a28f6fa4 100644 --- a/sapl/legacy/migration.py +++ b/sapl/legacy/migration.py @@ -12,8 +12,8 @@ from django.db.models.base import ModelBase from model_mommy import mommy from model_mommy.mommy import foreign_key_required, make -from sapl.base.models import Autor, ProblemaMigracao, TipoAutor -from sapl.comissoes.models import Composicao, Participacao +from sapl.base.models import Autor, ProblemaMigracao +from sapl.comissoes.models import Comissao, Composicao, Participacao from sapl.materia.models import (Proposicao, StatusTramitacao, TipoDocumento, TipoMateriaLegislativa, TipoProposicao, Tramitacao) @@ -338,16 +338,18 @@ class DataMigrator: self._do_migrate(obj) # exclude logically deleted in legacy base info('Deletando models com ind_excluido...') - for obj in self.to_delete: - try: - obj.delete() - except ProtectedError: - msg = 'A entrada de PK %s da model %s não pode ser excluida' %\ - (obj.pk, obj._meta.model_name) - descricao = 'Um ou mais objetos protegidos ' - warn(msg + ' => ' + descricao) - save_relation(obj=obj, problema=msg, - descricao=descricao, eh_stub=False) + while self.to_delete: + for obj in self.to_delete: + try: + obj.delete() + self.to_delete.remove(obj) + except ProtectedError: + msg = 'A entrada de PK %s da model %s não pode ser ' \ + 'excluida' % (obj.pk, obj._meta.model_name) + descricao = 'Um ou mais objetos protegidos ' + warn(msg + ' => ' + descricao) + save_relation(obj=obj, problema=msg, + descricao=descricao, eh_stub=False) info('Deletando stubs desnecessários...') while self.delete_stubs(): @@ -532,7 +534,11 @@ def adjust_normajuridica_depois_salvar(new, old): def adjust_autor(new, old): - new.autor_related = TipoAutor.objects.get(pk=old.tip_autor) + if old.cod_parlamentar: + new.autor_related = Parlamentar.objects.get(pk=old.cod_parlamentar) + elif old.cod_comissao: + new.autor_related = Comissao.objects.get(pk=old.cod_comissao) + if old.col_username: if not User.objects.filter(username=old.col_username).exists(): user = User(username=old.col_username, password=12345)