Skip to main content

py.test plugin to run Odoo tests

Project description

pytest plugin to run Odoo tests

This lib allows to run the tests built in Odoo addons which are using Python’s unittest, but with the comfort of the pytest CLI. Also allowing to run tests without updating given module.

Odoo’s –test-enable machinery and pytest-odoo do not cover exactly the same scope. The Odoo’s test runner runs the tests during the upgrades of the addons, that’s why they need the “at install” and “post install” markers.

Running tests during upgrades of addons is waaay too slow to work efficiently in a TDD mode, that’s where pytest-odoo shines. Consider that all the tests are running post-install with pytest-odoo, as you must run the upgrade of the addon before (but only when needed vs each run).

At the end of the day, its beneficial to run the Odoo tests with –test-enable because, as in very rare conditions, a test can pass with pytest-odoo but not with the “at install” tests run during the upgrade (or the oposite). Pytest-odoo can be considered a development tool, but not the tool that should replace entirely –test-enable in a CI.

See also the official Odoo documentation on writing tests.

Usage

install via:

pip install pytest-odoo

usage:

pytest -s --odoo-database=test --odoo-log-level=debug_sql [--odoo-http]

The custom options are:

  • --odoo-database: name of the database to test.

  • --odoo-log-level: log level as expected by odoo. As time of writing: info, debug_rpc, warn, test, critical, debug_sql, error, debug, debug_rpc_answer. The default is critical to have a clean output.

  • --odoo-config: path of the odoo.cfg file to use.

  • --odoo-http: Allow to launch the Odoo http instance

Alternatively, you can use environment variables, like the Odoo Docker image:

  • HOST: hostname of the database server

  • PORT: port of the database server

  • USER: username to access the database

  • PASSWORD: password to access the database

These only work in addition to --odoo-database.

You can use the ODOO_RC environment variable using an odoo configuration file, containing at least the database option with the name of the database to test:

export ODOO_RC=/path/to/odoo/config.cfg
pytest ...

The plugin is also compatible with distributed run provided by the pytest-xdist library. When tests are distributed, a copy of the database is created for each worker at the start of the test session. This is useful to avoid concurrent access to the same database, which can lead to deadlocks. The provided database is therefore used only as template. At the end of the tests, all the created databases are dropped.

Project details


Download files

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

Source Distribution

pytest_odoo-2.1.1.tar.gz (19.9 kB view details)

Uploaded Source

Built Distribution

pytest_odoo-2.1.1-py3-none-any.whl (17.9 kB view details)

Uploaded Python 3

File details

Details for the file pytest_odoo-2.1.1.tar.gz.

File metadata

  • Download URL: pytest_odoo-2.1.1.tar.gz
  • Upload date:
  • Size: 19.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.1 CPython/3.12.7

File hashes

Hashes for pytest_odoo-2.1.1.tar.gz
Algorithm Hash digest
SHA256 aa4841c02a7d37dca969870029689c1f29ee40ba12a754242b8e6e4d5f65c6be
MD5 8bd723dbe37e1f97a74721445c55a19b
BLAKE2b-256 725c9dd2404bdc504ea3e573a6707aa1afef75041385ebb663ee4b9cf5c3a08f

See more details on using hashes here.

File details

Details for the file pytest_odoo-2.1.1-py3-none-any.whl.

File metadata

  • Download URL: pytest_odoo-2.1.1-py3-none-any.whl
  • Upload date:
  • Size: 17.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.1 CPython/3.12.7

File hashes

Hashes for pytest_odoo-2.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 b7d1bc17940ba179c27ef1f4a89ffe3b91e6a3eb48556c0bec619659823b4fb3
MD5 c560c45c743f4802c3e7c287b9d0cd13
BLAKE2b-256 6c9022bd8684d7c54788709a61a5ff32b48828732bf2391709040fcf8822b780

See more details on using hashes here.

Supported by

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