Alexander Hess
1c19da2f70
- as of September 2021, PyCharm is used to write some of the code - PyCharm's built-in code styler, linter, and type checker issued some warnings that are resolved in this commit + spelling mistakes + all instance attributes must be specified explicitly in a class's __init__() method => use `functools.cached_property` for caching + make `tuple`s explicit with `(...)` + one test failed randomly although everything is ok => adjust the fixture's return value (stub for Google Directions API) + reformulate SQL so that PyCharm can understand the symbols
331 lines
9.7 KiB
INI
331 lines
9.7 KiB
INI
[black]
|
|
# black's settings are in pyproject.toml => [tool.black]
|
|
|
|
|
|
[coverage:paths]
|
|
source =
|
|
src/
|
|
*/site-packages/
|
|
|
|
[coverage:report]
|
|
show_missing = true
|
|
skip_covered = true
|
|
skip_empty = true
|
|
|
|
[coverage:run]
|
|
branch = true
|
|
data_file = .cache/coverage/data
|
|
source =
|
|
urban_meal_delivery
|
|
|
|
|
|
[flake8]
|
|
# Include error classes only explicitly
|
|
# to avoid forward compatibility issues.
|
|
select =
|
|
# =============
|
|
# flake8's base
|
|
# =============
|
|
# mccabe => cyclomatic complexity
|
|
C901,
|
|
# pycodestyle => PEP8 compliance
|
|
E, W,
|
|
# pyflakes => basic errors
|
|
F4, F5, F6, F7, F8, F9
|
|
# ========================
|
|
# wemake-python-styleguide
|
|
# Source: https://wemake-python-stylegui.de/en/latest/pages/usage/violations/index.html
|
|
# ========================
|
|
WPS1, WPS2, WPS3, WPS4, WPS5, WPS6,
|
|
# darglint => docstring matches implementation
|
|
DAR0, DAR1, DAR2, DAR3, DAR4, DAR5,
|
|
# flake8-bandit => common security issues
|
|
S1, S2, S3, S4, S5, S6, S7,
|
|
# flake8-broken-line => no \ to end a line
|
|
N400,
|
|
# flake8-bugbear => opinionated bugs and design flaws
|
|
B0, B3, B9,
|
|
# flake8-commas => better comma placements
|
|
C8,
|
|
# flake8-comprehensions => better comprehensions
|
|
C4,
|
|
# flake8-debugger => no debugger usage
|
|
T100,
|
|
# flake8-docstrings => PEP257 compliance
|
|
D1, D2, D3, D4,
|
|
# flake8-eradicate => no commented out code
|
|
E800,
|
|
# flake8-isort => isort would make changes
|
|
I0,
|
|
# flake8-rst-docstrings => valid rst in docstrings
|
|
RST2, RST3, RST4,
|
|
# flake8-string-format => unify usage of str.format()
|
|
P1, P2, P3,
|
|
# flake8-quotes => use double quotes everywhere (complying with black)
|
|
Q0,
|
|
# pep8-naming
|
|
N8,
|
|
# =====
|
|
# other
|
|
# =====
|
|
# flake8-annotations => enforce type checking for functions
|
|
ANN0, ANN2, ANN3,
|
|
# flake8-black => complain if black would make changes
|
|
BLK1, BLK9,
|
|
# flake8-expression-complexity => not too many expressions at once
|
|
ECE001,
|
|
# flake8-pytest-style => enforce a consistent style with pytest
|
|
PT0,
|
|
|
|
# By default, flake8 ignores some errors.
|
|
# Instead, do not ignore anything.
|
|
ignore =
|
|
|
|
# If --ignore is passed on the command
|
|
# line, still ignore the following:
|
|
extend-ignore =
|
|
# Too long line => duplicate with E501.
|
|
B950,
|
|
# Comply with black's style.
|
|
# Source: https://github.com/psf/black/blob/master/docs/compatible_configs.md#flake8
|
|
E203, W503, WPS348,
|
|
# Let's not do `@pytest.mark.no_cover()` instead of `@pytest.mark.no_cover`.
|
|
PT023,
|
|
# Google's Python Style Guide is not reStructuredText
|
|
# until after being processed by Sphinx Napoleon.
|
|
# Source: https://github.com/peterjc/flake8-rst-docstrings/issues/17
|
|
RST201,RST203,RST210,RST213,RST301,
|
|
# String constant over-use is checked visually by the programmer.
|
|
WPS226,
|
|
# Allow underscores in numbers.
|
|
WPS303,
|
|
# f-strings are ok.
|
|
WPS305,
|
|
# Classes should not have to specify a base class.
|
|
WPS306,
|
|
# Let's be modern: The Walrus is ok.
|
|
WPS332,
|
|
# Let's not worry about the number of noqa's.
|
|
WPS402,
|
|
# Putting logic into __init__.py files may be justified.
|
|
WPS412,
|
|
# Allow multiple assignment, e.g., x = y = 123
|
|
WPS429,
|
|
# There are no magic numbers.
|
|
WPS432,
|
|
|
|
per-file-ignores =
|
|
# Top-levels of a sub-packages are intended to import a lot.
|
|
**/__init__.py:
|
|
F401,WPS201,
|
|
docs/conf.py:
|
|
# Allow shadowing built-ins and reading __*__ variables.
|
|
WPS125,WPS609,
|
|
migrations/env.py:
|
|
# Type annotations are not strictly enforced.
|
|
ANN0, ANN2,
|
|
migrations/versions/*.py:
|
|
# Type annotations are not strictly enforced.
|
|
ANN0, ANN2,
|
|
# Do not worry about SQL injection here.
|
|
S608,
|
|
# File names of revisions are ok.
|
|
WPS114,WPS118,
|
|
# Revisions may have too many expressions.
|
|
WPS204,WPS213,
|
|
noxfile.py:
|
|
# Type annotations are not strictly enforced.
|
|
ANN0, ANN2,
|
|
# TODO (isort): Check if still too many module members.
|
|
WPS202,
|
|
# TODO (isort): Remove after simplifying the nox session "lint".
|
|
WPS213,
|
|
src/urban_meal_delivery/configuration.py:
|
|
# Allow upper case class variables within classes.
|
|
WPS115,
|
|
src/urban_meal_delivery/console/forecasts.py:
|
|
# The module is not too complex.
|
|
WPS232,
|
|
src/urban_meal_delivery/db/addresses_addresses.py:
|
|
# The module does not have too many imports.
|
|
WPS201,
|
|
src/urban_meal_delivery/db/customers.py:
|
|
# The module is not too complex.
|
|
WPS232,
|
|
src/urban_meal_delivery/db/restaurants.py:
|
|
# The module is not too complex.
|
|
WPS232,
|
|
src/urban_meal_delivery/forecasts/methods/decomposition.py:
|
|
# The module is not too complex.
|
|
WPS232,
|
|
src/urban_meal_delivery/forecasts/methods/extrapolate_season.py:
|
|
# The module is not too complex.
|
|
WPS232,
|
|
src/urban_meal_delivery/forecasts/models/tactical/horizontal.py:
|
|
# The many noqa's are ok.
|
|
WPS403,
|
|
src/urban_meal_delivery/forecasts/timify.py:
|
|
# No SQL injection as the inputs come from a safe source.
|
|
S608,
|
|
# The many noqa's are ok.
|
|
WPS403,
|
|
tests/*.py:
|
|
# Type annotations are not strictly enforced.
|
|
ANN0, ANN2,
|
|
# The `Meta` class inside the factory_boy models do not need a docstring.
|
|
D106,
|
|
# `assert` statements are ok in the test suite.
|
|
S101,
|
|
# The `random` module is not used for cryptography.
|
|
S311,
|
|
# Shadowing outer scopes occurs naturally with mocks.
|
|
WPS442,
|
|
# Test names may be longer than 40 characters.
|
|
WPS118,
|
|
# Modules may have many test cases.
|
|
WPS202,WPS204,WPS214,
|
|
# Do not check for Jones complexity in the test suite.
|
|
WPS221,
|
|
# "Private" methods are really just a convention for
|
|
# fixtures without a return value.
|
|
WPS338,
|
|
# We do not care about the number of "# noqa"s in the test suite.
|
|
WPS402,
|
|
# Allow closures.
|
|
WPS430,
|
|
# When testing, it is normal to use implementation details.
|
|
WPS437,
|
|
|
|
# Explicitly set mccabe's maximum complexity to 10 as recommended by
|
|
# Thomas McCabe, the inventor of the McCabe complexity, and the NIST.
|
|
# Source: https://en.wikipedia.org/wiki/Cyclomatic_complexity#Limiting_complexity_during_development
|
|
max-complexity = 10
|
|
|
|
# Allow more than wemake-python-styleguide's 5 local variables per function.
|
|
max-local-variables = 8
|
|
|
|
# Allow more than wemake-python-styleguide's 7 methods per class.
|
|
max-methods = 15
|
|
|
|
# Comply with black's style.
|
|
# Source: https://github.com/psf/black/blob/master/docs/the_black_code_style.md#line-length
|
|
max-line-length = 88
|
|
|
|
# Preview the code lines that cause errors.
|
|
show-source = true
|
|
|
|
# ===================================
|
|
# wemake-python-styleguide's settings
|
|
# ===================================
|
|
allowed-domain-names =
|
|
data,
|
|
obj,
|
|
param,
|
|
result,
|
|
results,
|
|
value,
|
|
max-name-length = 40
|
|
# darglint
|
|
strictness = long
|
|
# flake8-docstrings
|
|
docstring-convention = google
|
|
# flake8-eradicate
|
|
eradicate-aggressive = true
|
|
|
|
# ==============================
|
|
# flake8-pytest-style's settings
|
|
# ==============================
|
|
# Prefer @pytest.fixture over @pytest.fixture().
|
|
pytest-fixture-no-parentheses = true
|
|
# Prefer @pytest.mark.parametrize(['param1', 'param2'], [(1, 2), (3, 4)])
|
|
# over @pytest.mark.parametrize(('param1', 'param2'), ([1, 2], [3, 4]))
|
|
pytest-parametrize-names-type = list
|
|
pytest-parametrize-values-row-type = tuple
|
|
pytest-parametrize-values-type = list
|
|
|
|
|
|
[isort]
|
|
atomic = true
|
|
case_sensitive = true
|
|
combine_star = true
|
|
force_alphabetical_sort_within_sections = true
|
|
lines_after_imports = 2
|
|
remove_redundant_aliases = true
|
|
|
|
# Comply with black's style.
|
|
# Source: https://github.com/psf/black/blob/master/docs/compatible_configs.md#isort
|
|
ensure_newline_before_comments = true
|
|
force_grid_wrap = 0
|
|
include_trailing_comma = true
|
|
line_length = 88
|
|
multi_line_output = 3
|
|
use_parentheses = true
|
|
|
|
# Comply with Google's Python Style Guide.
|
|
# All imports go on a single line except the ones from the typing module.
|
|
# Source: https://google.github.io/styleguide/pyguide.html#313-imports-formatting
|
|
force_single_line = true
|
|
single_line_exclusions = typing
|
|
|
|
|
|
[mypy]
|
|
cache_dir = .cache/mypy
|
|
|
|
# Check the interior of functions without type annotations.
|
|
check_untyped_defs = true
|
|
|
|
# Disallow generic types without explicit type parameters.
|
|
disallow_any_generics = true
|
|
|
|
# Disallow functions with incomplete type annotations.
|
|
disallow_incomplete_defs = true
|
|
|
|
# Disallow calling functions without type annotations.
|
|
disallow_untyped_calls = true
|
|
|
|
# Disallow functions without type annotations (or incomplete annotations).
|
|
disallow_untyped_defs = true
|
|
|
|
[mypy-folium.*]
|
|
ignore_missing_imports = true
|
|
[mypy-geopy.*]
|
|
ignore_missing_imports = true
|
|
[mypy-googlemaps.*]
|
|
ignore_missing_imports = true
|
|
[mypy-matplotlib.*]
|
|
ignore_missing_imports = true
|
|
[mypy-nox.*]
|
|
ignore_missing_imports = true
|
|
[mypy-numpy.*]
|
|
ignore_missing_imports = true
|
|
[mypy-ordered_set.*]
|
|
ignore_missing_imports = true
|
|
[mypy-packaging]
|
|
ignore_missing_imports = true
|
|
[mypy-pandas]
|
|
ignore_missing_imports = true
|
|
[mypy-pytest]
|
|
ignore_missing_imports = true
|
|
[mypy-rpy2.*]
|
|
ignore_missing_imports = true
|
|
[mypy-sqlalchemy.*]
|
|
ignore_missing_imports = true
|
|
[mypy-statsmodels.*]
|
|
ignore_missing_imports = true
|
|
[mypy-utm.*]
|
|
ignore_missing_imports = true
|
|
|
|
|
|
[tool:pytest]
|
|
addopts =
|
|
--strict-markers
|
|
cache_dir = .cache/pytest
|
|
console_output_style = count
|
|
env =
|
|
TESTING=true
|
|
filterwarnings =
|
|
ignore:::patsy.*
|
|
markers =
|
|
db: (integration) tests touching the database
|
|
e2e: non-db and non-r integration tests
|
|
r: (integration) tests using rpy2
|