Browse Source

Merge pull request #489 from interlegis/476-migracao-tipoproposicao

fix #476 Ajustar migração TipoProposicao
pull/516/head
Edward 9 years ago
committed by GitHub
parent
commit
5137d0c629
  1. 74
      sapl/legacy/migration.py
  2. 2
      sapl/legacy_migration_settings.py
  3. 3
      sapl/materia/legacy.yaml

74
sapl/legacy/migration.py

@ -13,7 +13,7 @@ from model_mommy.mommy import foreign_key_required, make
from sapl.base.models import ProblemaMigracao from sapl.base.models import ProblemaMigracao
from sapl.comissoes.models import Composicao, Participacao from sapl.comissoes.models import Composicao, Participacao
from sapl.materia.models import StatusTramitacao, Tramitacao from sapl.materia.models import StatusTramitacao, TipoProposicao, Tramitacao
from sapl.norma.models import AssuntoNormaRelationship, NormaJuridica from sapl.norma.models import AssuntoNormaRelationship, NormaJuridica
from sapl.parlamentares.models import Parlamentar from sapl.parlamentares.models import Parlamentar
from sapl.protocoloadm.models import StatusTramitacaoAdministrativo from sapl.protocoloadm.models import StatusTramitacaoAdministrativo
@ -377,7 +377,24 @@ def migrate(obj=appconfs):
# MIGRATION_ADJUSTMENTS ##################################################### # MIGRATION_ADJUSTMENTS #####################################################
def adjust_participacao(new_participacao, old): def adjust_ordemdia(new, old):
# Prestar atenção
if not old.tip_votacao:
new.tipo_votacao = 1
def adjust_parlamentar(new, old):
if old.ind_unid_deliberativa:
value = new.unidade_deliberativa
# Field is defined as not null in legacy db,
# but data includes null values
# => transform None to False
if value is None:
warn('nulo convertido para falso')
new.unidade_deliberativa = False
def adjust_participacao(new, old):
composicao = Composicao() composicao = Composicao()
composicao.comissao, composicao.periodo = [ composicao.comissao, composicao.periodo = [
get_fk_related(Composicao._meta.get_field(name), value) get_fk_related(Composicao._meta.get_field(name), value)
@ -391,33 +408,21 @@ def adjust_participacao(new_participacao, old):
[composicao] = already_created [composicao] = already_created
else: else:
composicao.save() composicao.save()
new_participacao.composicao = composicao new.composicao = composicao
def adjust_parlamentar(new_parlamentar, old): def adjust_sessaoplenaria(new, old):
if old.ind_unid_deliberativa: assert not old.tip_expediente
value = new_parlamentar.unidade_deliberativa
# Field is defined as not null in legacy db,
# but data includes null values
# => transform None to False
if value is None:
warn('nulo convertido para falso')
new_parlamentar.unidade_deliberativa = False
def adjust_normajuridica(new, old):
# O 'S' vem de 'Selecionar'. Na versão antiga do SAPL, quando uma opção do
# combobox era selecionada, o sistema pegava a primeira letra da seleção,
# sendo F para Federal, E para Estadual, M para Municipal e o S para
# Selecionar, que era a primeira opção quando nada era selecionado.
if old.tip_esfera_federacao == 'S':
new.esfera_federacao = ''
def adjust_ordemdia(new, old): def adjust_tipoproposicao(new, old):
# Prestar atenção if new.materia_ou_documento == 'M':
if not old.tip_votacao: field = TipoProposicao.tipo_materia.field
new.tipo_votacao = 1 value = get_fk_related(field=field, value=old.tip_mat_ou_doc)
elif new.materia_ou_documento == 'D':
field = TipoProposicao.tipo_documento.field
value = get_fk_related(field=field, value=old.tip_mat_ou_doc)
setattr(new, field.name, value)
def adjust_statustramitacao(new, old): def adjust_statustramitacao(new, old):
@ -438,11 +443,18 @@ def adjust_tramitacao(new, old):
new.turno = 'U' new.turno = 'U'
def adjust_sessaoplenaria(new, old): def adjust_normajuridica_antes_salvar(new, old):
assert not old.tip_expediente # Ajusta choice de esfera_federacao
# O 'S' vem de 'Selecionar'. Na versão antiga do SAPL, quando uma opção do
# combobox era selecionada, o sistema pegava a primeira letra da seleção,
# sendo F para Federal, E para Estadual, M para Municipal e o S para
# Selecionar, que era a primeira opção quando nada era selecionado.
if old.tip_esfera_federacao == 'S':
new.esfera_federacao = ''
def adjust_normajuridica(new, old): def adjust_normajuridica_depois_salvar(new, old):
# Ajusta relação M2M
lista_ids_assunto = old.cod_assunto.split(',') lista_ids_assunto = old.cod_assunto.split(',')
for id_assunto in lista_ids_assunto: for id_assunto in lista_ids_assunto:
relacao = AssuntoNormaRelationship() relacao = AssuntoNormaRelationship()
@ -452,17 +464,19 @@ def adjust_normajuridica(new, old):
AJUSTE_ANTES_SALVAR = { AJUSTE_ANTES_SALVAR = {
NormaJuridica: adjust_normajuridica_antes_salvar,
OrdemDia: adjust_ordemdia, OrdemDia: adjust_ordemdia,
Participacao: adjust_participacao,
Parlamentar: adjust_parlamentar, Parlamentar: adjust_parlamentar,
Participacao: adjust_participacao,
SessaoPlenaria: adjust_sessaoplenaria, SessaoPlenaria: adjust_sessaoplenaria,
TipoProposicao: adjust_tipoproposicao,
StatusTramitacao: adjust_statustramitacao, StatusTramitacao: adjust_statustramitacao,
StatusTramitacaoAdministrativo: adjust_statustramitacaoadm, StatusTramitacaoAdministrativo: adjust_statustramitacaoadm,
Tramitacao: adjust_tramitacao, Tramitacao: adjust_tramitacao,
} }
AJUSTE_DEPOIS_SALVAR = { AJUSTE_DEPOIS_SALVAR = {
NormaJuridica: adjust_normajuridica, NormaJuridica: adjust_normajuridica_depois_salvar,
} }
# CHECKS #################################################################### # CHECKS ####################################################################

2
sapl/legacy_migration_settings.py

@ -3,7 +3,7 @@
from .settings import * # flake8: noqa from .settings import * # flake8: noqa
INSTALLED_APPS += ( INSTALLED_APPS += (
'legacy', # legacy reversed model definitions 'sapl.legacy', # legacy reversed model definitions
) )
DATABASES['legacy'] = { DATABASES['legacy'] = {

3
sapl/materia/legacy.yaml

@ -126,7 +126,8 @@ TipoProposicao:
descricao: des_tipo_proposicao descricao: des_tipo_proposicao
materia_ou_documento: ind_mat_ou_doc materia_ou_documento: ind_mat_ou_doc
modelo: nom_modelo modelo: nom_modelo
tipo_materia: tip_mat_ou_doc tipo_documento:
tipo_materia:
Proposicao: Proposicao:
autor: cod_autor autor: cod_autor

Loading…
Cancel
Save