Browse Source

lint check. unnecessary queries in uninstall hook.

pull/162/head
aheficent 8 years ago
committed by Darshan Patel
parent
commit
cbf6ef59bd
  1. 40
      bi_sql_editor/hooks.py
  2. 16
      bi_sql_editor/models/bi_sql_view.py

40
bi_sql_editor/hooks.py

@ -10,43 +10,3 @@ def uninstall_hook(cr, registry):
recs = env['bi.sql.view'].search([]) recs = env['bi.sql.view'].search([])
for rec in recs: for rec in recs:
rec.button_set_draft() rec.button_set_draft()
rec.unlink()
# delete dirty data that could cause problems
# while re-installing the module
# Drop materialized views
cr.execute("""
select relname
from pg_class
where relname like 'x_bi_sql_view%' and relkind='m'
""")
for r in cr.fetchall():
cr.execute("""
DROP MATERIALIZED VIEW %s
""" % r)
cr.execute("""
select relname
from pg_class
where relname like 'x_bi_sql_view%' and relkind='r'
""")
for r in cr.fetchall():
cr.execute("""
DROP TABLE %s
""" % r)
cr.execute("""
select table_name from INFORMATION_SCHEMA.views
where table_name like 'x_bi_sql%'""")
# Drop not materialized views
for v in cr.fetchall():
cr.execute("""
DROP VIEW %s
""" % v)
# Drop table if uninstalling went wrong
cr.execute("""
delete from ir_model_fields where model like 'bi.sql.view%';
delete from ir_model_fields where model like 'bi_sql_%';
delete from ir_model where model like 'x_bi_sql_view.%';
""")

16
bi_sql_editor/models/bi_sql_view.py

@ -203,24 +203,18 @@ class BiSQLView(models.Model):
for sql_view in self: for sql_view in self:
if sql_view.state in ('model_valid', 'ui_valid'): if sql_view.state in ('model_valid', 'ui_valid'):
# Drop SQL View (and indexes by cascade) # Drop SQL View (and indexes by cascade)
if sql_view.is_materialized:
sql_view._drop_view() sql_view._drop_view()
# Drop ORM # Drop ORM
sql_view._drop_model_and_fields() sql_view._drop_model_and_fields()
if sql_view.tree_view_id:
sql_view.tree_view_id.unlink() sql_view.tree_view_id.unlink()
if sql_view.graph_view_id:
sql_view.graph_view_id.unlink() sql_view.graph_view_id.unlink()
if sql_view.pivot_view_id:
sql_view.pivot_view_id.unlink() sql_view.pivot_view_id.unlink()
if sql_view.search_view_id:
sql_view.search_view_id.unlink() sql_view.search_view_id.unlink()
if sql_view.action_id:
sql_view.action_id.unlink() sql_view.action_id.unlink()
if sql_view.menu_id:
sql_view.menu_id.unlink() sql_view.menu_id.unlink()
if sql_view.rule_id:
sql_view.rule_id.unlink() sql_view.rule_id.unlink()
if sql_view.cron_id: if sql_view.cron_id:
sql_view.cron_id.unlink() sql_view.cron_id.unlink()
@ -416,14 +410,9 @@ class BiSQLView(models.Model):
@api.multi @api.multi
def _drop_view(self): def _drop_view(self):
for sql_view in self: for sql_view in self:
try:
self._log_execute( self._log_execute(
"DROP %s VIEW IF EXISTS %s" % ( "DROP %s VIEW IF EXISTS %s" % (
sql_view.materialized_text, sql_view.view_name)) sql_view.materialized_text, sql_view.view_name))
except ProgrammingError as e:
# If it is not a materialized view will raise an error,
# and we pass.
continue
sql_view.size = False sql_view.size = False
@api.multi @api.multi
@ -560,7 +549,8 @@ class BiSQLView(models.Model):
@api.multi @api.multi
def _refresh_materialized_view(self): def _refresh_materialized_view(self):
for sql_view in self.filtered(lambda v: v.is_materialized == True):
for sql_view in self:
if sql_view.is_materialized:
req = "REFRESH %s VIEW %s" % ( req = "REFRESH %s VIEW %s" % (
sql_view.materialized_text, sql_view.view_name) sql_view.materialized_text, sql_view.view_name)
self._log_execute(req) self._log_execute(req)

Loading…
Cancel
Save