-
-
Notifications
You must be signed in to change notification settings - Fork 461
Migration to version 10.0
- Update yourself with the latest OCA Conventions: https://github.com/OCA/maintainer-tools/blob/master/CONTRIBUTING.md
- Subscribe to the mailing list of the related project: https://odoo-community.org/groups
- Announce on the corresponding GitHub issue with the name "Migration to version 10.0" which module(s) you want to migrate
-
Switch the
installable
key toTrue
-
Bump module version to
10.0.1.0.0
-
Remove any possible migration script from previous version.
-
Migrate code to new ORM API if not yet.
-
Replace
openerp
imports toodoo
. You can use this command:find . -type f -name '*.py' | xargs sed -i 's/from openerp/from odoo/g'
-
Rename
__openerp__.py
to__manifest__.py
if not yet renamed. -
Update README.rst from https://raw.githubusercontent.com/OCA/maintainer-tools/master/template/module/README.rst if not updated to the latest template.
-
Add tests to increase code coverage.
-
Update code to remove use of deprecated methods.
-
Update code to take advantage of the new features.
-
Replace
select = True
byindex = True
-
Replace string selectors in XML by name (if possible) or other attribute selector or even another equivalent path/reference. For example, change
<group string="x" position="after">
by<group name="x" position="after">
-
Remove
<data>
and</data>
in xml files ifnoupdate="0"
-
Replace the
<openerp>
/</openerp>
tags in xml files by<odoo>
/</odoo>
. -
Don't use
@api.one
with@api.onchange
or it will crash. -
base.group_configuration
has been renamed tobase.group_system
. -
Change decorator of copy method
def copy(self):
from@api.one
to@api.multi
. -
These security groups have changed its module from
base
tosales_team
:-
base.group_sale_salesman
>sales_team.group_sale_salesman
. -
base.group_sale_salesman_all_leads
>sales_team.group_sale_salesman_all_leads
. -
base.group_sale_manager
>sales_team.group_sale_manager
.
-
-
Do the changes you need to do for making the module works on new version.
-
$REPO
: the OCA repository hosting the module -
$MODULE
: the name of the module you want to migrate -
$USER_ORG
: your GitHub login or organization name
Full process for beginners in Git flows
$ git clone https://github.com/OCA/$REPO -b 10.0
$ git checkout -b 10.0-mig-$MODULE origin/10.0
$ git format-patch --keep-subject --stdout origin/10.0..origin/9.0 -- $MODULE | git am -3 --keep
$ # Adapt the module to the 10.0 version and commit the changes
$ ...
$ git add --all
$ git commit -m "[MIG] $MODULE: Migration to 10.0"
$ git remote add $USER_ORG git@github.com:$USER_ORG/$REPO.git # This mode requires an SSH key in the GitHub account
$ ... or ....
$ git remote add $USER_ORG https://github.com/$USER_ORG/$REPO.git # This will required to enter user/password each time
$ # push the changes to GitHub and make the PR
$ git push $USER_ORG 10.0-mig-$MODULE --set-upstream
Short method for advanced users that know the rest of the Git flow
$ git remote update # In case the repo was already cloned before
$ git checkout -b 10.0-mig-<module> origin/10.0
$ git format-patch --keep-subject --stdout origin/10.0..origin/9.0 -- <module path> | git am -3 --keep
Before migrating the first module, the following tasks must be performed in the repository:
- Create 10.0 branch from 9.0.
- Update all modules manifest with installable = False.
- Update metafiles (.travis.yml and README.md), adapting them from the template in https://github.com/OCA/maintainer-quality-tools/tree/master/sample_files to have the proper data.
- Remove setup folder in the root (if any).
- Rename
__openerp__.py
to__manifest__.py
. - Make 10.0 default branch.
There's an script to automate all these process in: https://github.com/OCA/maintainer-tools/blob/master/tools/migrate_branch.py.