Beautiful, robust and extensible Odoo server API extension suite for DevOps.
Project description
dodoo is a beautiful, robust and extensible Odoo server API extension suite for DevOps. It is based on the excellent Click library.
Quick start
Install it in an environment where Odoo is installed,
pip install dodoo
Custom scripts
Assuming the following script named list-users.py.
from __future__ import print_function
for u in env['res.users'].search([]):
print(u.login, u.name)
It can be run with:
dodoo run -d dbname --log-level=error list-users.py
The second technique to create scripts looks like this. Assuming the following script named list-users2.py.
#!/usr/bin/env python
from __future__ import print_function
import click
import dodoo
CTX_SETTINGS = dict(
default_map={'log_level': 'error'}
)
@click.command(cls=dodoo.CommandWithOdooEnv, context_settings=CTX_SETTINGS)
@click.option('--say-hello', is_flag=True)
def main(env, say_hello):
if say_hello:
click.echo("Hello!")
for u in env['res.users'].search([]):
print(u.login, u.name)
if __name__ == '__main__':
main()
It can be run like this:
$ ./list-users2.py --help Usage: list-users2.py [OPTIONS] Options: -c, --config PATH Specify the Odoo configuration file. Other ways to provide it are with the ODOO_RC or OPENERP_SERVER environment variables, or ~/.odoorc (Odoo >= 10) or ~/.openerp_serverrc. -d, --database TEXT Specify the database name. If present, this parameter takes precedence over the database provided in the Odoo configuration file. --log-level TEXT Specify the logging level. Accepted values depend on the Odoo version, and include debug, info, warn, error. [default: error] --logfile PATH Specify the log file. --rollback Rollback the transaction even if the script does not raise an exception. Note that if the script itself commits, this option has no effect, this is why it is not named dry run. This option is implied when an interactive console is started. --say-hello --help Show this message and exit. $ ./list-users2.py --say-hello -d dbname Hello! admin Administrator ...
dodoo Plugins
For extending tha comfort of the dodoo API itself, you can write a plugin. It’s recommended to clone the plugin scaffolding repository to get started.
The plugin registration is done in setup.py like this:
from setuptools import setup
setup(
name='yourplugin',
version='0.1',
py_modules=['yourplugin'],
install_requires=[
'dodoo',
],
entry_points='''
[core_package.cli_plugins]
cool_subcommand=yourscript.cli:cool_subcommand
another_subcommand=yourscript.cli:another_subcommand
''',
)
Aside from accessing dodoo options through ctx.obj implicitly, you can be explicite by reusing dodoo options in the following way:
import click
from dodoo import options, main
@main.command()
# Set the addons path options and make it mandatory, see options.py
@options.addons_path_opt(True)
def subcommand(addons_path):
"""I do something domain specific."""
Supported Odoo versions
Odoo version 8, 9, 10, 11 and 12 are supported.
An important design goal is to provide a consistent behaviour across Odoo versions.
Database transactions
By default dodoo commits the transaction for you, unless your script raises an exception. This is so that you don’t need to put explicit commits in your scripts, which are therefore easier to compose in larger transactions (provided they pass around the same env).
There is a --rollback option to force a rollback.
A rollback is always performed after an interactive session. If you need to commit changes made before or during an interactive session, use env.cr.commit().
Logging
In version 8, Odoo logs to stdout by default. On other versions it is stderr. dodoo attempts to use stderr for Odoo 8 too.
Logging is controlled by the usual Odoo logging options (--log-level, --logfile) or the Odoo configuration file.
Command line interface (dodoo)
Usage: dodoo [OPTIONS] [SCRIPT] [SCRIPT_ARGS]...
Execute a python script in an initialized Odoo environment. The script has
access to a 'env' global variable which is an odoo.api.Environment
initialized for the given database. If no script is provided, the script
is read from stdin or an interactive console is started if stdin appears
to be a terminal.
Options:
-c, --config FILE Specify the Odoo configuration file. Other
ways to provide it are with the ODOO_RC or
OPENERP_SERVER environment variables, or
~/.odoorc (Odoo >= 10) or
~/.openerp_serverrc.
--addons-path TEXT Specify the addons path. If present, this
parameter takes precedence over the addons
path provided in the Odoo configuration
file.
-d, --database TEXT Specify the database name. If present, this
parameter takes precedence over the database
provided in the Odoo configuration file.
--log-level TEXT Specify the logging level. Accepted values
depend on the Odoo version, and include
debug, info, warn, error. [default: info]
--logfile FILE Specify the log file.
--rollback Rollback the transaction even if the script
does not raise an exception. Note that if
the script itself commits, this option has
no effect. This is why it is not named dry
run. This option is implied when an
interactive console is started.
-i, --interactive / --no-interactive
Inspect interactively after running the
script.
--shell-interface TEXT Preferred shell interface for interactive
mode. Accepted values are ipython, ptpython,
bpython, python. If not provided they are
tried in this order.
--help Show this message and exit.
Most options above are the same as odoo options and behave identically. Additional Odoo options can be set in the the configuration file. Note however that most server-related options (workers, http interface etc) are ignored because no server is actually started when running a script.
An important feature of dodoo compared to, say, odoo shell is the capability to pass arguments to scripts.
In order to avoid confusion between dodoo options and your script options and arguments, it is recommended to separate them with --:
dodoo -d dbname -- list-users.py -d a b ./list-users.py -d dbname -- -d a b
In both examples above, sys.argv[1:] will contain ['-d', 'a', 'b'] in the script.
API
env_options
Customize the behaviour of dodoo.CommandWithOdooEnv through click.Command(env_options={}).
dodoo.CommandWithOdooEnv prepares an odoo Environment and passes it as a env parameter.
It is configurable with the following keyword arguments in env_options:
- database_must_exist
If this flag is False and the selected database does not exist do not fail and pass env=None instead (default: True).
- environment_manager
experimental feature A context manager that yields an intialized odoo.api.Environment. It is invoked after Odoo configuration parsing and initialization. It must have the following signature (identical to OdooEnvironment below, plus **kwargs)
environment_manager(database, rollback, **kwargs)
dodoo.odoo namespace
As a convenience dodoo exports the odoo namespace, so from dodoo import odoo is an alias for import odoo (>9) or import openerp as odoo (<=9).
OdooEnvironment context manager (experimental)
This package also provides an experimental OdooEnvironment context manager. It is meant to be used in after properly intializing Odoo (ie parsing the configuration file etc).
Example:
from dodoo import OdooEnvironment
with OdooEnvironment(database='dbname') as env:
env['res.users'].search([])
Developement
To run tests, type tox. Tests are made using pytest. To run tests matching a specific keyword for, say, Odoo 12 and python 3.6, use tox -e py36-12.0 -- -k keyword.
This project uses black as code formatting convention, as well as isort and flake8. To make sure local coding convention are respected before you commit, install pre-commit and run pre-commit install after cloning the repository.
Useful links
pypi page: https://pypi.org/project/dodoo
code repository: https://github.com/xoe-labs/dodoo
report issues at: https://github.com/xoe-labs/dodoo/issues
Credits
Original Author:
Stéphane Bidoul (ACSONE)
Contributor:
David Arnold (XOE)
Maintainer:
David Arnold (XOE)
Inspiration has been drawn from:
odoo’s own shell command
Maintainer
This project is maintained by XOE Corp. SAS.
Changes
2.0.0 (2019-01-22)
refactor to click native facilities, where possible
replace @env_options() named parameters with context_settings on click.Command()
replace @env_options wrapper with custom Command class
add default_overrides command key to manage script-scoped parameter defaults (eg. adjust default for log_level or rollback)
Rename to dodoo
Add plugin facilities
1.1.1 (2018-11-01)
add with_addons_path option to @dodoo.env_options to control the presence of the --addons-path option. Defaults to False. Enabled for the CLI.
1.1.0 (2018-10-31)
add environment_manager to @dodoo.env_options, providing a hook on odoo.api.Environment creation.
add --addons-path option to the CLI.
add database_must_exist env option to @dodoo.env_options so scripts can behave how they please in case the database is absent.
1.0.4 (2018-10-07)
silence deprecation warning
adapt tests for Odoo 12
1.0.3 (2018-06-05)
clarify the behaviour of @env_option with_database and database_required parameters; in particular, when with_database and database_required are both set (the default), the --database option can be omitted as long as a database is declared in the Odoo configuration file.
1.0.2 (2018-06-01)
refactor the OdooEnvironment class: it is much cleaner when it leaves the global Odoo config alone, so we completely move responsibility to initialize the Odoo config to the CLI part.
1.0.1 (2018-05-27)
better error logging and handling: all exceptions occuring in scripts under dodoo.env_options are logged and converted to ClickException so we are sure they are both in the log file and on the console (handled by click) for the user to see. The OdooEnvironment context manager does not do additional logging, leaving that responsibility to the caller.
1.0.0 (2018-05-20)
close db connections when releasing OdooEnvironment
expose dodoo.odoo_bin (odoo or openerp-server depending on Odoo series). not documented yet, because it should ideally be a full path corresponding to the installed dodoo.odoo, and I’m not sure how best to detect it yet.
1.0.0b4 (2018-05-17)
minor documentation improvements
add the possibility to run script without --database (ie without env, but with a properly initialized Odoo library such as addons path)
be more resilient in case we can’t obtain a context for the user
1.0.0b3 (2018-03-22)
dodoo now exports the odoo namespace: from dodoo import odoo is an alias for import odoo (>9) or import openerp as odoo (<=9)
add a with_rollback option to the env_options decorator, to control the presence of the rollback option
document the env_options decorator
1.0.0b2 (2018-03-21)
commit in case of success, so users do not need to commit in their scripts, therefore making scripts easier to compose in larger transactions
add a –rollback option
interactive mode forces –rollback
1.0.0b1 (2018-03-20)
clear cache when starting environment (mostly useful for tests)
simplify and test transaction and exception handling
when leaving the env, log the exception to be sure it is visible when using --logfile
1.0.0a2 (2018-03-19)
improve transaction management: avoid some rare deadlock
avoid masking original exception in case of error during rollback
make sure launched scripts have __name__ == '__main__'
add --logfile option
1.0.0a1 (2018-03-19)
first alpha
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file dodoo-2.0.0rc8.tar.gz
.
File metadata
- Download URL: dodoo-2.0.0rc8.tar.gz
- Upload date:
- Size: 25.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.31.1 CPython/3.6.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 35133f32b0e9d7cfb759a608132603f8ff6333508f0d33222098580a1b275170 |
|
MD5 | 7887bb1d8ab5b0cd628d663f67dd82b4 |
|
BLAKE2b-256 | 100f0a2403945358443d948c0f02f49bd6274cf2923b9239e5c68267c63ee46a |
File details
Details for the file dodoo-2.0.0rc8-py2.py3-none-any.whl
.
File metadata
- Download URL: dodoo-2.0.0rc8-py2.py3-none-any.whl
- Upload date:
- Size: 15.9 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.31.1 CPython/3.6.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | e3e2677cd5144fdac0eefe9bc3a74fd631dc58f6fe1eda37a6bf377ba2702f7f |
|
MD5 | 09cd4f9e70b61ae38f36867e25a14d7e |
|
BLAKE2b-256 | 13943cc05ae88b17550be61c76f3a95dcfb314f86ee2867142df3e7e4852f379 |