In addition to the Leapp project contribution guidelines, please follow also these rules:
- Description of all PRs must clearly state what is being changed and the rationale for the change.
- Description in the docstring of actors, models and/or phases must conform to their implementation. Description of an actor should include the expected behaviour, inputs and outputs, so that one is able to write component tests for the actor without looking at the actor's code.
- Actors must have component tests covering the behaviour mentioned in the actor's description.
- Bug fix PRs must include component tests covering the fixed issue.
- Writing unit tests for the actor's code is optional but encouraged.
- Follow PEP 8 - Style Guide for Python Code
- with the exception of line length which can be up to 120 characters
- use of linters (PyLint, pep8, flake8) is encouraged to be sure to follow the PEP 8
- Follow PEP 257 - Docstring Conventions
- All Python code must be Python 2.7+/3.6+ compatible.
- New folders and/or Python files must use lowercase without underscores.
- with the exception of test file names, which need to be named
test_*.py
or*_test.py
- with the exception of test file names, which need to be named
- Do not use actor in the actor's name, neither model/topic/tag/phase in the model/topic/tag/phase name, as these things are implicit.
- The actor's main file must be named
actor.py
. - Use of Python language for the actor's logic is preferred, even though you can call a script in any language from the actor's Python skeleton.
- The code should follow these documents as much as feasible: