From edf6ed4113244d9a30c0dda605ac2ee0bc357202 Mon Sep 17 00:00:00 2001 From: Luciano Almeida Date: Thu, 5 Jan 2017 16:46:21 -0200 Subject: [PATCH] =?UTF-8?q?Arruma=20fun=C3=A7=C3=A3o=20save=5Fwith=5Fid?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: Luciano Almeida --- sapl/legacy/migration.py | 25 ++++++++++++++++--------- 1 file changed, 16 insertions(+), 9 deletions(-) diff --git a/sapl/legacy/migration.py b/sapl/legacy/migration.py index d8ce30175..a46696700 100644 --- a/sapl/legacy/migration.py +++ b/sapl/legacy/migration.py @@ -233,16 +233,21 @@ def stub_desnecessario(obj): return desnecessario -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() +def get_last_value(model): + last_value = model.objects.all().aggregate(Max('pk')) + return last_value['pk__max'] if last_value['pk__max'] else 0 + + +def alter_sequence(model, id): + sequence_name = '%s_id_seq' % model._meta.db_table + exec_sql('ALTER SEQUENCE %s RESTART WITH %s;' % (sequence_name, id)) - cursor = exec_sql( - 'ALTER SEQUENCE %s RESTART WITH %s;' % (sequence_name, id)) + +def save_with_id(new, id): + last_value = get_last_value(type(new)) + alter_sequence(type(new), id) new.save() - cursor = exec_sql( - 'ALTER SEQUENCE %s RESTART WITH %s;' % (sequence_name, last_value + 1)) + alter_sequence(type(new), last_value + 1) assert new.id == id, 'New id is different from provided!' @@ -372,7 +377,7 @@ class DataMigrator: while self.delete_stubs(): pass info('Recriando unique constraints...') - recreate_constraints() + # recreate_constraints() def _do_migrate(self, obj): if isinstance(obj, AppConfig): @@ -626,6 +631,8 @@ def check_app_no_ind_excluido(app): def make_with_log(model, _quantity=None, make_m2m=False, **attrs): + last_value = get_last_value(model) + alter_sequence(model, last_value + 1) fields_dict = get_fields_dict(model) stub = make(model, _quantity, make_m2m, **fields_dict) problema = 'Um stub foi necessário durante a criação de um outro stub'