Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/OCA/odoo-pre-commit-hooks
Linters of Odoo addons that complement pylint-odoo
https://github.com/OCA/odoo-pre-commit-hooks
Last synced: 2 months ago
JSON representation
Linters of Odoo addons that complement pylint-odoo
- Host: GitHub
- URL: https://github.com/OCA/odoo-pre-commit-hooks
- Owner: OCA
- License: agpl-3.0
- Created: 2022-06-29T09:11:56.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2024-06-29T00:42:53.000Z (7 months ago)
- Last Synced: 2024-07-05T14:02:32.695Z (7 months ago)
- Language: Python
- Size: 242 KB
- Stars: 9
- Watchers: 17
- Forks: 9
- Open Issues: 8
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
[//]: # (start-badges)
[![Build Status](https://github.com/OCA/odoo-pre-commit-hooks/actions/workflows/test.yml/badge.svg?branch=main)](https://github.com/OCA/odoo-pre-commit-hooks/actions/workflows/test.yml?query=branch%3Amain)
[![codecov](https://codecov.io/gh/OCA/odoo-pre-commit-hooks/branch/main/graph/badge.svg)](https://codecov.io/gh/OCA/odoo-pre-commit-hooks)
[![version](https://img.shields.io/pypi/v/oca-odoo-pre-commit-hooks.svg)](https://pypi.org/project/oca-odoo-pre-commit-hooks)
[![wheel](https://img.shields.io/pypi/wheel/oca-odoo-pre-commit-hooks.svg)](https://pypi.org/project/oca-odoo-pre-commit-hooks)
[![supported-versions](https://img.shields.io/pypi/pyversions/oca-odoo-pre-commit-hooks.svg)](https://pypi.org/project/oca-odoo-pre-commit-hooks)
[![commits-since](https://img.shields.io/github/commits-since/OCA/odoo-pre-commit-hooks/v0.0.34.svg)](https://github.com/OCA/odoo-pre-commit-hooks/compare/v0.0.34...main)
[![code-style-black](https://img.shields.io/badge/code%20style-black-000000.svg)](https://github.com/psf/black)[//]: # (end-badges)
# odoo-pre-commit-hooks
OCA's custom pre-commit hooks for Odoo modules
# Installation
You don't need to install it directly only configure your ".pre-commit-config.yaml" file
You even can install it directly:
- Installing from pypi:
- `pip install -U oca-odoo-pre-commit-hooks`- Installing from github:
- `pip install --force-reinstall -U git+https://github.com/OCA/odoo-pre-commit-hooks.git@main`# Usage pre-commit-config.yaml
Add to your ".pre-commit-config.yaml" configuration file the following input
```yaml
- repo: https://github.com/OCA/odoo-pre-commit-hooks
rev: v0.0.34
hooks:
- id: oca-checks-odoo-module
- id: oca-checks-po
args: ["--fix"]
```# Usage directly the entry points
If you install directly the package use the entry point:
oca-checks-odoo-module --help
oca-checks-po --help# Skip one xml-check for only one file
If you need to skip one check in one particular XML file you can use the follow comment
```xml
...
```
```xml
...
```
The position of the comment it is not relative to the line that throw the check
It disable the entire file
# Configuration
Behavior can be configured through several methods and as of now only consists of enabling/disabling checks.## Enabling or Disabling Checks
Each available hook consists of multiple checks which can be enabled/disabled using any of the following methods (ordered by priority):1. As an argument e.g., `oca-checks-odoo --enable=check-to-enable --disable=check-to-disable1,check-to-disable2`
2. Using environment variables `OCA_HOOKS_ENABLE` or `OCA_HOOKS_DISABLE` e.g., `export OCA_HOOKS_ENABLE=check1,check2`
3. A configuration file. The path to it can be specified with the argument `--config`. Alternatively a file named `.oca_hooks.cfg`
will be looked for (by default) in the following locations (in order):
1. Current working directory
2. Repo's root
3. User's home### Using a Configuration File
To enable or disable checks using a configuration file, add a `disable` or `enable` key under the `MESSAGES_CONTROL` section.
For example:
```
[MESSAGES_CONTROL]
enable=check-enable1,check-enable2
disable=check-to-disable
```As stated before, each source has a certain priority. This means that if the environment variable `OCA_HOOKS_ENABLE=check1`
exists, the configuration file above would not have any effect when it comes to enabling checks, and the only enabled
check will be `check1`.However, if `OCA_HOOKS_DISABLE` is not set, the configuration file will still have an effect and `check-to-disable` will
be disabled.[//]: # (start-checks)
# Checks
* Check manifest-syntax-error
Check if the manifest file has syntax error* Check csv-duplicate-record-id
duplicate CSV "id" AKA xmlid but for CSV files* Check csv-syntax-error
Check syntax error for CSV files declared in the manifest* Check xml-deprecated-data-node
Deprecated node inside xml node* Check xml-deprecated-openerp-node
deprecated xml node* Check xml-deprecated-qweb-directive
for use of deprecated QWeb directives t-*-options* Check xml-not-valid-char-link
The resource in in src/href contains a not valid character.* Check xml-oe-structure-missing-id
Ensure all tags with class 'oe_structure' have an ID. For more information on the rationale, see:
https://github.com/OCA/odoo-pre-commit-hooks/issues/27* Check xml-redundant-module-name
If the module is called "module_a" and the xmlid is
`
...
* Check xml-deprecated-tree-attribute
The tree-view declaration is using a deprecated attribute.* Check xml-record-missing-id
Generated when a tag has no id.* Check xml-duplicate-record-id
If a module has duplicated record_id AKA xml_ids
file1.xml
` node
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/broken_module/model_view.xml#L3 Deprecated `` node
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/broken_module/model_view2.xml#L3 Deprecated `` node
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/broken_module/model_view_odoo.xml#L3 Deprecated `` node
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/broken_module/model_view_odoo2.xml#L3 Deprecated `` node
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/broken_module/skip_xml_check.xml#L5 Deprecated `` node
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/broken_module/skip_xml_check_2.xml#L3 Deprecated `` node
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/test_module/model_view.xml#L3 Deprecated `` node* xml-deprecated-openerp-node
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/broken_module/model_view.xml#L2 Deprecated `` xml node
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/broken_module/model_view2.xml#L2 Deprecated `` xml node
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/test_module/model_view.xml#L2 Deprecated `` xml node
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/test_module/res_users.xml#L2 Deprecated `` xml node* xml-deprecated-qweb-directive
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/test_module/website_templates.xml#L7 Deprecated QWeb directive `t-esc-options`. Use `t-options` instead
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/test_module/website_templates.xml#L20 Deprecated QWeb directive `t-field-options`. Use `t-options` instead* xml-deprecated-tree-attribute
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/broken_module/model_view_odoo.xml#L31 Deprecated "`
* xml-syntax-error
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/broken_module/file_no_exist.xml#L1 [Errno 2] No such file or directory: ''
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/broken_module/file_no_exist.xml#L1 [Errno 2] No such file or directory: ''* xml-view-dangerous-replace-low-priority
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/broken_module/model_view2.xml#L25 Dangerous use of `replace` from view with priority 0 < 99
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/broken_module/model_view2.xml#L37 Dangerous use of `replace` from view with priority 0 < 99
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/broken_module/model_view2.xml#L47 Dangerous use of `replace` from view with priority 0 < 99
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/broken_module/model_view2.xml#L70 Dangerous use of `replace` from view with priority 10 < 99
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/broken_module/model_view2.xml#L92 Dangerous use of `replace` from view with priority 10 < 99
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/broken_module/model_view2.xml#L108 Dangerous use of `replace` from view with priority 10 < 99
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/broken_module/skip_xml_check_3.xml#L15 Dangerous use of `replace` from view with priority 0 < 99* xml-xpath-translatable-item
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/broken_module/model_view.xml#L11 Use of translatable xpath `text()`
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/broken_module/template1.xml#L39 Use of translatable xpath `text()`
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/broken_module/template1_copy.xml#L31 Use of translatable xpath `text()`
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/broken_module/template1_copy2.xml#L31 Use of translatable xpath `text()`[//]: # (end-example)
[//]: # (start-example-po)
# Examples PO
* po-duplicate-message-definition
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/broken_module/i18n/es.po#L17 Duplicate PO message definition `Branch` in lines 23, 29
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/broken_module/i18n/es.po#L35 Duplicate PO message definition `Message id toooooooooooooooooooooooooooo...` in lines 41
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/broken_module/i18n/es.po#L65 Duplicate PO message definition `One variable {variable1}` in lines 71* po-duplicate-model-definition
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/broken_module/i18n/es.po#L17 Translation for model:ir.model.fields,field_description:broken_module.field_wizard_description has been defined more than once in line(s) 29
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/broken_module/i18n/es.po#L35 Translation for model:ir.model.fields,field_description2:broken_module.field_wizard_description2 has been defined more than once in line(s) 41
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/broken_module/i18n/es.po#L59 Translation for model:ir.model.fields,field_description5:broken_module.field_wizard_description5 has been defined more than once in line(s) 65
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/test_module/i18n/fr.po#L24 Translation for model:ir.model.fields,field_description2:test_module.field_description2 has been defined more than once in line(s) 24
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/test_module/i18n/fr.po#L31 Translation for model:ir.model.fields,field_description5:test_module.field_description5 has been defined more than once in line(s) 31
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/test_module/i18n/fr.po#L38 Translation for model:ir.model.fields,field_description3:test_module.field_description3 has been defined more than once in line(s) 38
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/test_module/i18n/fr.po#L45 Translation for model:ir.model.fields,field_description4:test_module.field_description4 has been defined more than once in line(s) 45* po-pretty-format
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/broken_module/i18n/ar_unicode.po Wrong formatting
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/broken_module/i18n/broken_module.pot Wrong formatting
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/broken_module/i18n/es.po Wrong formatting
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/broken_module/xml_semi_empty.po Wrong formatting
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/eleven_module/i18n/ugly.po Wrong formatting
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/test_module/i18n/fr.po Wrong formatting* po-python-parse-format
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/broken_module/i18n/es.po#L53 Translation string couldn't be parsed correctly using str.format IndexError('Replacement index 1 out of range for positional args tuple')
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/broken_module/i18n/es.po#L59 Translation string couldn't be parsed correctly using str.format IndexError('Replacement index 1 out of range for positional args tuple')
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/broken_module/i18n/es.po#L65 Translation string couldn't be parsed correctly using str.format KeyError('variable2')
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/broken_module/i18n/es.po#L71 Translation string couldn't be parsed correctly using str.format KeyError('variable2')* po-python-parse-printf
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/broken_module/i18n/es.po#L47 Translation string couldn't be parsed correctly using str%variables TypeError('not all arguments converted during string formatting')
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/broken_module/i18n/es.po#L83 Translation string couldn't be parsed correctly using str%variables TypeError('%d format: a real number is required, not str')* po-requires-module
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/broken_module/i18n/broken_module.pot#L14 Translation entry requires comment `#. module: MODULE`
* po-syntax-error
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/broken_module2/i18n/en.po#L1 Syntax error in po file
- https://github.com/OCA/odoo-pre-commit-hooks/blob/v0.0.34/test_repo/syntax_err_module/i18n/es.po#L19 Syntax error in po file[//]: # (end-example-po)
## Licenses
This repository is licensed under [AGPL-3.0](LICENSE).
----
OCA, or the [Odoo Community Association](http://odoo-community.org/), is a nonprofit
organization whose mission is to support the collaborative development of Odoo features
and promote its widespread use.