From 29815184bcebf1b260340f269781c42d3ccf970a Mon Sep 17 00:00:00 2001 From: Holger Brunn Date: Sat, 23 Dec 2023 18:07:46 +0100 Subject: [PATCH] [FIX] _convert_field_bootstrap_4to5_sql: Detect json and convert its values --- openupgradelib/openupgrade_160.py | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) diff --git a/openupgradelib/openupgrade_160.py b/openupgradelib/openupgrade_160.py index 36f3b96d..b8d7c164 100644 --- a/openupgradelib/openupgrade_160.py +++ b/openupgradelib/openupgrade_160.py @@ -9,6 +9,7 @@ from itertools import product from psycopg2 import sql +from psycopg2.extras import Json from odoo.tools.translate import _get_translation_upgrade_queries @@ -393,7 +394,15 @@ def _convert_field_bootstrap_4to5_sql(cr, table, field, ids=None): params = (tuple(ids),) cr.execute(sql.SQL(query).format(**format_query_args), params) for id_, old_content in cr.fetchall(): - new_content = convert_string_bootstrap_4to5(old_content) + if type(old_content) == dict: + new_content = Json( + { + key: convert_string_bootstrap_4to5(value) + for key, value in old_content.items() + } + ) + else: + new_content = convert_string_bootstrap_4to5(old_content) if old_content != new_content: cr.execute( sql.SQL("UPDATE {table} SET {field} = %s WHERE id = %s").format(