OCA Maintainers Tools
Installation
$ git clone git@github.com:OCA/maintainers-tools.git
$ cd maintainers-tools
$ virtualenv env
$ . env/bin/activate
$ python setup.py install
If you want to use the oca-copy-branches
command, you also have to install:
https://github.com/felipec/git-remote-bzr. git-remote-bzr
must be in the
$PATH
.
Usage
Get a token from Github, you may have to delete the existing one from Account settings -> Applications -> Personnal Access Token
$ oca-github-login USERNAME
Copy the users from the teams configured on community.odoo.com to the GitHub teams
Goal: members of the teams should never be added directly on GitHub. They should be added on https://community.odoo.com. This script will sync all the teams from odoo to GitHub.
Prerequisites:
- Your odoo user must have read accesses to the projects and users.
- The partners on odoo must have their GitHub login set otherwise they won't be added in the GitHub teams.
- Your GitHub user must have owners rights on the OCA organization to be able to add or remove members.
- The odoo project must have the same name than the GitHub teams.
Run the script in "dry-run" mode:
$ oca-copy-maintainers --dry-run
Apply the changes on GitHub:
$ oca-copy-maintainers
The first time it runs, it will ask you for your odoo's username and
password. You may store them using the --store
option, but be warned
that the password is stored in clear text.
Migrate the Launchpad branches to GitHub
The mapping of the branches is in tools/branches.yaml
.
When running:
$ oca-copy-branches PATH
all the Launchpad branches will be fetched (as git
repositories with git-remote-bzr
in PATH
).
The default mode of execution is a dry run
mode, it will not push the branches to GitHub.
If you want to push the branches to GitHub, run:
$ oca-copy-branches PATH --push
To copy the branches of a particular project, put the name of the project (the GitHub's one):
$ oca-copy-branches PATH --projects OCA/magento-connector
The same tool can also be used to move other branches to GitHub, see https://github.com/OCA/maintainers-tools/wiki/How-to-move-a-Merge-Proposal-to-GitHub
Set labels on OCA repository on GitHub
Set standardized labels to ease the issue workflow on all repositories with same colors This tools will also warn you what are the specific labels on some repository
$ oca-set-repo-labels
Auto fix pep8 guidelines
To auto fix pep8 guidelines of your code you can run:
$ oca-autopep8 -ri PATH
This script overwrite with monkey patch the original script of autopep8 to support custom code refactoring.
-
List of errors added:
CW0001
Class name with snake_case style found, should use CamelCase.CW0002
Delete vim comment.
More info of original autopep8 here
You can rename snake_case to CamelCase with next command: $ oca-autopep8 -ri --select=CW0001 PATH
You can delete vim comment $ oca-autopep8 -ri --select=CW0002,W391 PATH
Clone all OCA repositories
The script oca-clone-everything
can be used to clone all the OCA projects:
create a fresh directory, use oca-github-login (or copy oca.cfg from a place
where you've already logged in) and run oca-clone-everything.
The script will create a clone for all the OCA projects registered on
github. For projects already cloned, it run git fetch --all
to get the
lastest versions.
If you pass the --organization-remotes <comma-separated-list>
option, the script will also add remotes for the listed
accounts, and run git fetch
to get the source code from these forks. For instance:
$ oca-clone-everything --organization-remotes yourlogin,otherlogin
will create two remotes, in addition to the default origin
, called
yourlogin
and otherlogin
, respectively referencing
git@github.com:yourlogin/projectname
and
git@github.com:otherlogin/projectname
and fetch these remotes, for all the
OCA projects. It does not matter whether the forks exist on github or not, and
you can create them later.
Developers
As a developer, you want to launch the scripts without installing the egg.
$ git clone git@github.com:OCA/maintainers-tools.git
$ cd maintainers-tools
$ virtualenv env
$ . env/bin/activate
$ pip install -e .
Get a token from Github
$ python -m tools.github_login USERNAME
Run a script
$ python -m tools.copy_maintainers
You can use the GITHUB_TOKEN
environment variable to specify the token
$ GITHUB_TOKEN=xxx python -m tools.copy_maintainers