Skip to main content

Module to integrate in the server_wide_modules option to make upgrades between two major revisions.

Project description

Odoo Community Association

Openupgrade Framework

Beta License: AGPL-3 OCA/OpenUpgrade Translate me on Weblate Try me on Runboat

This module is a technical module that contains a number of monkeypatches to improve the behaviour of Odoo when migrating your database using the OpenUpgrade migration scripts:

  • Prevent dropping columns or tables in the database when fields or models are obsoleted in the Odoo data model of the target release. After the migration, you can review and delete unused database tables and columns using database_cleanup. See https://odoo-community.org/shop/product/database-cleanup-918

  • When data records are deleted during the migration (such as views or other system records), this is done in a secure mode. If the deletion fails because of some unforeseen dependency, the deletion will be cancelled and a message is logged, after which the migration continues.

  • Prevent a number of log messages that do not apply when using OpenUpgrade.

  • Suppress log messages about failed view validation, which are to be expected during a migration.

  • Run migration scripts for modules that are installed as new dependencies of upgraded modules (when there are such scripts for those particular modules)

  • Production databases generated with demo data, will be transformed to non-demo ones. If you want to avoid that, you have to pass through the environment variable OPENUPGRADE_USE_DEMO, the value “yes”.

For detailed documentation see:

Table of contents

Installation

This module does not need to be installed on a database. It simply needs to be available via your addons-path.

Configuration

  • call your odoo instance with the option --load=base,web,openupgrade_framework

or

  • add the key to your configuration file:

[options]
server_wide_modules = web,openupgrade_framework

When you load the module in either way of these ways, and you have the openupgrade_scripts module in your addons path available, the –upgrade-path option of Odoo will be set automatically to the location of the OpenUpgrade migration scripts.

Development

The odoo_patch folder contains python files in a tree that mimicks the folder tree of the Odoo project. It contains a number of monkey patches to improve the migration of an Odoo database between two major versions.

So far, we are able to make everything work without overwriting large blocks of code, but if larger patches need to be added, please use the method described below:

To see the patches added, you can use meld tools:

meld PATH_TO_ODOO_FOLDER/odoo/ PATH_TO_OPENUPGRADE_FRAMEWORK_MODULE/odoo_patch

To make more easy the diff analysis :

  • Make sure the python files has the same path as the original one.

  • Keep the same indentation as the original file. (using if True: if required)

  • Add the following two lines at the beginning of your file, to avoid flake8 / pylint errors

# flake8: noqa
# pylint: skip-file
  • When you want to change the code. add the following tags:

For an addition:

# <OpenUpgrade:ADD>
some code...
# </OpenUpgrade>

For a change:

# <OpenUpgrade:CHANGE>
some code...
# </OpenUpgrade>

For a removal:

# <OpenUpgrade:REMOVE>
# Comment the code, instead of removing it.
# </OpenUpgrade>

Bug Tracker

Bugs are tracked on GitHub Issues. In case of trouble, please check there if your issue has already been reported. If you spotted it first, help us to smash it by providing a detailed and welcomed feedback.

Do not contact contributors directly about support or help with technical issues.

Credits

Authors

  • Therp BV

  • Opener B.V.

  • GRAP

Contributors

Other credits

Many developers have contributed to the OpenUpgrade framework in its previous incarnation. Their original contributions may no longer needed, or they are no longer recognizable in their current form but OpenUpgrade would not have existed at this point without them.

Maintainers

This module is maintained by the OCA.

Odoo Community Association

OCA, or the Odoo Community Association, is a nonprofit organization whose mission is to support the collaborative development of Odoo features and promote its widespread use.

Current maintainers:

legalsylvain StefanRijnhart

This module is part of the OCA/OpenUpgrade project on GitHub.

You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

File details

Details for the file odoo14_addon_openupgrade_framework-14.0.1.0.1-py3-none-any.whl.

File metadata

File hashes

Hashes for odoo14_addon_openupgrade_framework-14.0.1.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 d32c130dc8023d289dde1ca7fbb05ce8ce9e5ba0301fbb3df5c9e85bfa5bce9a
MD5 64d192ac7dc267c7b0097f6677adebe3
BLAKE2b-256 1075b689a3c0edee5682ee231d18314a32a9700e8c6bc1d29086c5ec27a79d9c

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page