diff --git a/sapl/legacy/migration.py b/sapl/legacy/migration.py index ffe48cd9a..5b1797715 100644 --- a/sapl/legacy/migration.py +++ b/sapl/legacy/migration.py @@ -6,7 +6,7 @@ from django.apps import apps from django.apps.config import AppConfig from django.contrib.auth import get_user_model from django.core.exceptions import ObjectDoesNotExist -from django.db import connections, models +from django.db import connections, models, OperationalError, ProgrammingError from django.db.models import CharField, TextField, ProtectedError from django.db.models.base import ModelBase from model_mommy import mommy @@ -115,8 +115,13 @@ def get_fk_related(field, value, label=None): if value == 0: if not field.null: fields_dict = get_fields_dict(field.related_model) - value = mommy.make(field.related_model, - **fields_dict) + # Cria stub ao final da tabela para evitar erros + pk = 1 + if hasattr(field.related_model.objects.last(), 'pk'): + pk = field.related_model.objects.last().pk + value = mommy.make( + field.related_model, **fields_dict, + pk=(pk + 1 or 1)) descricao = 'stub criado para campos não nuláveis!' save_relation(value, [field.name], msg, descricao, eh_stub=True) @@ -141,6 +146,15 @@ def get_field(model, fieldname): return model._meta.get_field(fieldname) +def exec_sql_file(path, db='default'): + cursor = connections[db].cursor() + for line in open(path): + try: + cursor.execute(line) + except (OperationalError, ProgrammingError) as e: + print("Args: '%s'" % (str(e.args))) + + def exec_sql(sql, db='default'): cursor = connections[db].cursor() cursor.execute(sql) @@ -221,11 +235,13 @@ def save_with_id(new, id): sequence_name = '%s_id_seq' % type(new)._meta.db_table cursor = exec_sql('SELECT last_value from %s;' % sequence_name) (last_value,) = cursor.fetchone() + if last_value == 1 or id != last_value + 1: # we explicitly set the next id if last_value == 1 # because last_value == 1 for a table containing either 0 or 1 records # (we would have trouble for id == 2 and a missing id == 1) - exec_sql('ALTER SEQUENCE %s RESTART WITH %s;' % (sequence_name, id)) + cursor = exec_sql( + 'ALTER SEQUENCE %s RESTART WITH %s;' % (sequence_name, id)) new.save() assert new.id == id, 'New id is different from provided!' @@ -241,7 +257,7 @@ def save_relation(obj, nome_campo='', problema='', descricao='', def make_stub(model, id): fields_dict = get_fields_dict(model) - new = mommy.prepare(model, **fields_dict) + new = mommy.prepare(model, **fields_dict, pk=id) save_with_id(new, id) return new @@ -332,6 +348,7 @@ class DataMigrator: # warning: model/app migration order is of utmost importance self.to_delete = [] ProblemaMigracao.objects.all().delete() + exec_sql_file('sapl/legacy/scripts/fix_tables.sql', 'legacy') get_user_model().objects.exclude(is_superuser=True).delete() info('Começando migração: %s...' % obj) diff --git a/sapl/legacy/scripts/fix_tables.sql b/sapl/legacy/scripts/fix_tables.sql new file mode 100644 index 000000000..997379f65 --- /dev/null +++ b/sapl/legacy/scripts/fix_tables.sql @@ -0,0 +1,3 @@ +DROP PROCEDURE IF EXISTS verifica_campos; +CREATE PROCEDURE verifica_campos() BEGIN IF NOT EXISTS (SELECT * FROM information_schema.columns WHERE table_schema=DATABASE() AND table_name='proposicao' AND column_name='num_proposicao') THEN ALTER TABLE proposicao add column num_proposicao int(11) NULL after txt_justif_devolucao; END IF; END; +CALL verifica_campos; diff --git a/sapl/legacy_migration_settings.py b/sapl/legacy_migration_settings.py index 0aab3baa9..4176c6df9 100644 --- a/sapl/legacy_migration_settings.py +++ b/sapl/legacy_migration_settings.py @@ -28,6 +28,8 @@ DATABASES['legacy'] = config('DATABASE_URL', cast=db_url,) DATABASE_ROUTERS = ['sapl.legacy.router.LegacyRouter', ] +DEBUG = False + MOMMY_CUSTOM_FIELDS_GEN = { 'django.db.models.ForeignKey': 'sapl.legacy.migration.make_with_log' } diff --git a/sapl/norma/forms.py b/sapl/norma/forms.py index 68b059436..02420adab 100644 --- a/sapl/norma/forms.py +++ b/sapl/norma/forms.py @@ -35,8 +35,6 @@ ORDENACAO_CHOICES = [('', '---------'), class NormaFilterSet(django_filters.FilterSet): - RANGE_ANOS.insert(0, ('', 'Selecione')) - filter_overrides = {models.DateField: { 'filter_class': django_filters.DateFromToRangeFilter, 'extra': lambda f: {