-
-
Notifications
You must be signed in to change notification settings - Fork 705
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
3075af8
commit c7c6900
Showing
4 changed files
with
189 additions
and
1 deletion.
There are no files selected for viewing
72 changes: 72 additions & 0 deletions
72
addons/purchase/migrations/13.0.1.2/openupgrade_analysis_work.txt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,72 @@ | ||
---Models in module 'purchase'--- | ||
---Fields in module 'purchase'--- | ||
purchase / account.invoice / purchase_id (many2one) : DEL relation: purchase.order | ||
purchase / account.move / purchase_id (many2one) : NEW relation: purchase.order | ||
# NOTHING TO DO: the new field becomes non stored | ||
|
||
purchase / account.invoice / vendor_bill_purchase_id (many2one): DEL relation: purchase.bill.union | ||
purchase / account.move / purchase_vendor_bill_id (many2one): NEW relation: purchase.bill.union | ||
# NOTHING TO DO: the new field becomes non stored | ||
|
||
purchase / account.invoice.line / purchase_line_id (many2one) : DEL relation: purchase.order.line | ||
purchase / account.move.line / purchase_line_id (many2one) : NEW relation: purchase.order.line | ||
purchase / purchase.order.line / invoice_lines (one2many) : relation is now 'account.move.line' ('account.invoice.line') [nothing to do] | ||
# DONE: post-migration: mapping | ||
|
||
purchase / purchase.order / currency_rate (float) : NEW isfunction: function, stored | ||
# NOTHING TO DO: new field to compute every PO in the company currency | ||
|
||
purchase / purchase.order / date_approve (date) : type is now 'datetime' ('date') | ||
# DONE: handled the change of type from 'date' to 'datetime' | ||
|
||
purchase / purchase.order / date_planned (datetime) : not a function anymore | ||
# NOTHING TO DO: Previously, "date_planned" was computed and set while the creation of PO, now field will be empty until user fills it | ||
|
||
purchase / purchase.order / invoice_ids (many2many) : relation is now 'account.move' ('account.invoice') [nothing to do] | ||
purchase / purchase.order / invoice_ids (many2many) : table is now 'account_move_purchase_order_rel' ('account_invoice_purchase_order_rel') | ||
# DONE: pre-migration: renamed table 'account_invoice_purchase_order_rel' to 'account_move_purchase_order_rel' | ||
# DONE: post-migration: rebuilt table with account.move instead of account.invoice | ||
|
||
purchase / purchase.order.line / display_type (selection) : NEW selection_keys: ['line_note', 'line_section'], hasdefault | ||
# NOTHING TO DO: new feature: add section and note on order line | ||
|
||
purchase / purchase.order.line / qty_received (float) : now a function | ||
purchase / purchase.order.line / qty_received_manual (float) : NEW | ||
purchase / purchase.order.line / qty_received_method (selection): NEW selection_keys: ['manual'], isfunction: function, stored | ||
# DONE: pre/post/end-migration: done the same as done in v12 sale module for qty_delivered* | ||
|
||
---XML records in module 'purchase'--- | ||
DEL ir.actions.act_window: purchase.action_invoice_pending | ||
DEL ir.actions.act_window: purchase.purchase_open_invoice | ||
DEL ir.actions.act_window.view: purchase.action_invoice__supplier_tree1_view2 | ||
DEL ir.actions.act_window.view: purchase.action_invoice_supplier_tree1_view1 | ||
# NOTHING TO DO: noupdate=0 records | ||
|
||
NEW ir.model.access: purchase.access_account_move_purchase | ||
DEL ir.model.access: purchase.access_account_invoice_purchase | ||
NEW ir.model.access: purchase.access_account_move_purchase_manager | ||
DEL ir.model.access: purchase.access_account_invoice_purchase_manager | ||
# DONE: pre-migration: renamed xmlids | ||
|
||
DEL ir.model.access: purchase.access_account_invoice_line_purchase | ||
DEL ir.model.access: purchase.access_account_invoice_line_purchase_manager | ||
DEL ir.model.access: purchase.access_account_invoice_tax_purchase | ||
DEL ir.model.access: purchase.access_product_price_history_purchase_manager | ||
DEL ir.model.access: purchase.access_product_price_history_purchase_user | ||
# NOTHING TO DO: noupdate=0 records | ||
|
||
NEW ir.module.category: base.module_category_operations_purchase (noupdate) | ||
# NOTHING TO DO: New noupdate=1 records | ||
|
||
NEW ir.ui.menu: purchase.menu_purchase_products | ||
NEW ir.ui.menu: purchase.menu_report_purchase | ||
DEL ir.ui.menu: purchase.menu_procurement_management_pending_invoice | ||
DEL ir.ui.menu: purchase.menu_purchase_control | ||
NEW ir.ui.view: purchase.purchase_order_view_activity | ||
NEW ir.ui.view: purchase.purchase_order_view_search | ||
NEW ir.ui.view: purchase.purchase_order_view_tree | ||
NEW ir.ui.view: purchase.view_move_form_inherit_purchase | ||
DEL ir.ui.view: purchase.view_invoice_line_form_inherit_purchase | ||
DEL ir.ui.view: purchase.view_invoice_supplier_purchase_form | ||
DEL res.groups: purchase.group_manage_vendor_price | ||
# NOTHING TO DO: noupdate=0 records |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,71 @@ | ||
# Copyright 2020 ForgeFlow <http://www.forgeflow.com> | ||
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html). | ||
from openupgradelib import openupgrade | ||
|
||
|
||
def move_fields_from_invoice_to_moves(env): | ||
openupgrade.logged_query( | ||
env.cr, """ | ||
UPDATE account_move_line aml | ||
SET purchase_line_id = ail.purchase_line_id | ||
FROM account_invoice_line ail | ||
WHERE aml.old_invoice_line_id = ail.id AND | ||
ail.purchase_line_id IS NOT NULL""" | ||
) | ||
|
||
|
||
def change_type_purchase_order_date_approve(env): | ||
openupgrade.logged_query( | ||
env.cr, """ | ||
UPDATE purchase_order | ||
SET date_approve = {date}::TIMESTAMP AT TIME ZONE 'UTC' | ||
WHERE {date} IS NOT NULL | ||
""".format(date=openupgrade.get_legacy_name('date_approve')) | ||
) | ||
|
||
|
||
def update_account_move_purchase_order_rel_table(env): | ||
openupgrade.logged_query( | ||
env.cr, """ | ||
UPDATE account_move_purchase_order_rel ampor | ||
SET account_move_id = am.id | ||
FROM account_invoice ai | ||
JOIN account_move am ON am.old_invoice_id = ai.id | ||
WHERE ampor.{} = ai.id | ||
""".format(openupgrade.get_legacy_name('account_invoice_id')) | ||
) | ||
|
||
|
||
def fill_purchase_order_line_qty_received_method(cr): | ||
if openupgrade.column_exists(cr, 'purchase_order', 'picking_type_id'): | ||
# purchase_stock is installed | ||
# set qty_delivered_method = 'stock_moves' | ||
openupgrade.logged_query( | ||
cr, """ | ||
UPDATE purchase_order_line pol | ||
SET qty_received_method = 'stock_moves', qty_received_manual = NULL | ||
FROM product_product pp | ||
LEFT JOIN product_template pt ON pp.product_tmpl_id = pt.id | ||
WHERE pol.product_id = pp.id AND pol.display_type IS NULL | ||
AND pt.type IN ('consu', 'product')""" | ||
) | ||
# set qty_received_method = 'manual' | ||
openupgrade.logged_query( | ||
cr, """ | ||
UPDATE purchase_order_line pol | ||
SET qty_received_method = 'manual' | ||
FROM product_product pp | ||
LEFT JOIN product_template pt ON pp.product_tmpl_id = pt.id | ||
WHERE pol.qty_received_method IS NULL AND pol.product_id = pp.id | ||
AND pt.type IN ('consu', 'service')""" | ||
) | ||
|
||
|
||
@openupgrade.migrate() | ||
def migrate(env, version): | ||
move_fields_from_invoice_to_moves(env) | ||
change_type_purchase_order_date_approve(env) | ||
update_account_move_purchase_order_rel_table(env) | ||
fill_purchase_order_line_qty_received_method(env.cr) | ||
openupgrade.load_data( | ||
env.cr, "purchase", "migrations/13.0.1.2/noupdate_changes.xml") |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,45 @@ | ||
# Copyright 2020 ForgeFlow <http://www.forgeflow.com> | ||
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html). | ||
from openupgradelib import openupgrade | ||
|
||
_column_copies = { | ||
'account_invoice_purchase_order_rel': [ | ||
('account_invoice_id', 'account_move_id', None), | ||
], | ||
'purchase_order_line': [ | ||
('qty_received', 'qty_received_manual', None), | ||
], | ||
} | ||
|
||
_column_renames = { | ||
'purchase_order': [ | ||
('date_approve', None), | ||
], | ||
'account_invoice_purchase_order_rel': [ | ||
('account_invoice_id', None), | ||
], | ||
} | ||
|
||
_table_renames = [ | ||
('account_invoice_purchase_order_rel', 'account_move_purchase_order_rel'), | ||
] | ||
|
||
_xmlid_renames = [ | ||
("purchase.access_account_invoice_purchase", | ||
"purchase.access_account_move_purchase"), | ||
("purchase.access_account_invoice_purchase_manager", | ||
"purchase.access_account_move_purchase_manager"), | ||
] | ||
|
||
|
||
@openupgrade.migrate() | ||
def migrate(env, version): | ||
openupgrade.copy_columns(env.cr, _column_copies) | ||
openupgrade.rename_columns(env.cr, _column_renames) | ||
openupgrade.rename_tables(env.cr, _table_renames) | ||
openupgrade.rename_xmlids(env.cr, _xmlid_renames) | ||
openupgrade.logged_query( | ||
env.cr, """ | ||
ALTER TABLE purchase_order_line | ||
ADD COLUMN qty_received_method varchar""", | ||
) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters