Coding quality
We value software quality. Higher quality software has fewer defects, better security, and better performance, which leads to happier users who can work more effectively. The classeval
library is developed with several techniques, such as coding styling, low complexity, docstrings, reviews, and unit tests. Such conventions are helpfull to improve the quality, make the code cleaner and more understandable but alos to trace future bugs, and spot syntax errors.
library
The file structure of the generated package looks like:
path/to/classeval/
├── .editorconfig
├── .gitignore
├── .pre-commit-config.yml
├── .prospector.yml
├── CHANGELOG.rst
├── docs
│ ├── conf.py
│ ├── index.rst
│ └── ...
├── LICENSE
├── MANIFEST.in
├── NOTICE
├── classeval
│ ├── __init__.py
│ ├── __version__.py
│ └── classeval.py
├── README.md
├── requirements.txt
├── setup.cfg
├── setup.py
└── tests
├── __init__.py
└── test_classeval.py
Style
This library is compliant with the PEP-8 standards. PEP stands for Python Enhancement Proposal and sets a baseline for the readability of Python code. Each public function contains a docstring that is based on numpy standards.
Complexity
This library has been developed by using measures that help decreasing technical debt.
Version 0.1.4 of the classeval
library scored, according the code analyzer: 3.89, for which values > 0 are good and 10 is a maximum score.
Developing software with low(er) technical dept may take extra development time, but has many advantages:
Higher quality code
Easier maintanable
Less prone to bugs and errors
Improved security
Unit tests
The use of unit tests is essential to garantee a consistent output of developed functions.
The following tests are secured using tests.test_classeval()
:
The input are checked.
The output values are checked and whether they are encoded properly.
The check of whether parameters are handled correctly.
pytest tests\test_classeval.py
====================================== test session starts ======================================
platform win32 -- Python 3.6.10, pytest-5.4.0, py-1.8.1, pluggy-0.13.1
collected 1 item
tests\test_classeval.py .
================================ 1 passed, 3 warnings in 16.00s =================================