Browse Source

Verifica qtd de constraints unique together

pull/989/head
Marcio Mazza 8 years ago
parent
commit
451e2949a5
  1. 19
      sapl/legacy/migration.py

19
sapl/legacy/migration.py

@ -17,19 +17,20 @@ from django.db.models.signals import post_delete, post_save
from model_mommy import mommy from model_mommy import mommy
from model_mommy.mommy import foreign_key_required, make from model_mommy.mommy import foreign_key_required, make
from sapl.base.models import Autor, ProblemaMigracao, Constraint, Argumento from sapl.base.models import Argumento, Autor, Constraint, ProblemaMigracao
from sapl.comissoes.models import Comissao, Composicao, Participacao from sapl.comissoes.models import Comissao, Composicao, Participacao
from sapl.legacy.models import Protocolo as ProtocoloLegado from sapl.legacy.models import Protocolo as ProtocoloLegado
from sapl.materia.models import (StatusTramitacao, TipoDocumento, Tramitacao, from sapl.materia.models import (DocumentoAcessorio, MateriaLegislativa,
StatusTramitacao, TipoDocumento,
TipoMateriaLegislativa, TipoProposicao, TipoMateriaLegislativa, TipoProposicao,
DocumentoAcessorio, MateriaLegislativa) Tramitacao)
from sapl.norma.models import (AssuntoNorma, NormaJuridica, from sapl.norma.models import (AssuntoNorma, NormaJuridica,
TipoVinculoNormaJuridica) TipoVinculoNormaJuridica)
from sapl.parlamentares.models import Parlamentar from sapl.parlamentares.models import Parlamentar
from sapl.protocoloadm.models import Protocolo, StatusTramitacaoAdministrativo from sapl.protocoloadm.models import Protocolo, StatusTramitacaoAdministrativo
from sapl.sessao.models import ExpedienteMateria, OrdemDia from sapl.sessao.models import ExpedienteMateria, OrdemDia
from sapl.settings import PROJECT_DIR from sapl.settings import PROJECT_DIR
from sapl.utils import normalize, save_texto, delete_texto from sapl.utils import delete_texto, normalize, save_texto
# BASE ###################################################################### # BASE ######################################################################
# apps to be migrated, in app dependency order (very important) # apps to be migrated, in app dependency order (very important)
@ -202,6 +203,12 @@ def iter_sql_records(sql, db):
record.__dict__.update(zip(fieldnames, row)) record.__dict__.update(zip(fieldnames, row))
yield record yield record
# Todos os models têm no máximo uma constraint unique together
# Isso é necessário para que o método delete_constraints funcione corretamente
assert all(len(model._meta.unique_together) <= 1
for app in appconfs
for model in app.models.values())
def delete_constraints(model): def delete_constraints(model):
# pega nome da unique constraint dado o nome da tabela # pega nome da unique constraint dado o nome da tabela
@ -221,10 +228,8 @@ def delete_constraints(model):
for w in words_list: for w in words_list:
Argumento.objects.create(constraint=constraint, argumento=w) Argumento.objects.create(constraint=constraint, argumento=w)
else: else:
args = None
if model._meta.unique_together: if model._meta.unique_together:
args = model._meta.unique_together[0] args_list = model._meta.unique_together[0]
args_list = list(args)
constraint = Constraint.objects.create( constraint = Constraint.objects.create(
nome_tabela=table, nome_constraint=r[0], nome_tabela=table, nome_constraint=r[0],
nome_model=model.__name__, nome_model=model.__name__,

Loading…
Cancel
Save