These are the coding style followed on the rs-server project.
Pre-commit checks
pre-commit rules are configured to perform basic checks before each commit. You can install it on your workstation when installing your environment. It is recommended to verify your code follows the project coding rules.
Python style
By default, the pep8 is followed.
All python files are formatted by black. It is run in the pre-commit hooks and can be run after each file save. The line length is extended to 120 but keep lines as small and readable as possible.
The lint is performed by pylint and flake8 in the CI workflow.
The doc-strings are written using the reStructuredText because the python api is generated using Sphinx.
The following file header should be added at the start of each python file.
TODO
Unit test style
The unittests are written with pytest.
We use marks to categorize tests. The following marks are defined currently.
import pytest
@pytest.mark.integration
def a_fixture_for_integration_only():
return None
@pytest.mark.unit
def test_a_unit_test():
assert False
@pytest.mark.integration
def test_an_integration_test(a_fixture_for_integration_only):
assert False
Commit style
The commit messages are written using the conventional commit.
The messages try to follow the following best practices.
Changelog
The project changelog is produced following keepchangelog practices. Please keep the changelog up-to-date after each modification.
Documentation
The documentation is written in asciidoctor following the documentation system.