-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpyproject.toml
265 lines (236 loc) · 13.7 KB
/
pyproject.toml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
[project]
name = "celery_starter"
# https://packaging.python.org/en/latest/guides/writing-pyproject-toml/#version
dynamic = ["version"]
license = {file = "LICENSE"}
authors = [
{name="Friskes", email="[email protected]"},
]
description = "Django command to launch celery worker, beat, flower"
readme = "README.md"
requires-python = ">=3.8"
keywords = ["Django", "Celery", "Beat", "Flower", "Autoreload"]
classifiers = [
"Development Status :: 5 - Production/Stable",
"Environment :: Web Environment",
"Intended Audience :: Developers",
"Operating System :: OS Independent",
"License :: OSI Approved :: MIT License",
"Programming Language :: Python :: 3.8",
"Programming Language :: Python :: 3.9",
"Programming Language :: Python :: 3.10",
"Programming Language :: Python :: 3.11",
"Programming Language :: Python :: 3.12",
"Framework :: Django :: 4.0",
"Framework :: Django :: 4.1",
"Framework :: Django :: 4.2",
"Topic :: Internet :: WWW/HTTP",
"Topic :: Documentation",
"Topic :: Software Development :: Code Generators",
]
# pip install .
dependencies = [
"django>=4.0.0",
"celery>=5.3.6",
"python-dotenv>=1.0.1",
]
# Для того чтобы при запуске тестов использовалось приложение из директории src/celery_starter
# а не из venv/Lib/celery_starter необходимо устанавливать символическую ссылку на приложение
# в venv а не само приложение с помощью команды: pip install -e .[dev]
# pip install .[dev]
# pip install .[ci]
[project.optional-dependencies]
dev = [
"pre-commit>=3.5.0",
"ruff==0.8.0",
"mypy>=1.10.0",
"pytest>=7.0.1",
"pytest-cov>=5.0.0",
]
ci = [
"ruff==0.8.0",
"mypy>=1.10.0",
"pytest>=7.0.1",
"pytest-cov>=5.0.0",
]
[project.urls]
Homepage = "https://github.com/Friskes/celery-starter"
Changelog = "https://github.com/Friskes/celery-starter/releases/"
Issues = "https://github.com/Friskes/celery-starter/issues"
[build-system]
requires = ["setuptools>=64", "setuptools_scm[toml]>=8"]
build-backend = "setuptools.build_meta"
# https://setuptools-scm.readthedocs.io/en/latest/
# https://stackoverflow.com/a/76470558/19276507
# Данная настройка позволяет PyPI получать версию пакета из GitHub release tag
[project.entry-points."setuptools.finalize_distribution_options"]
setuptools_scm = "setuptools_scm._integration.setuptools:infer_version"
[tool.setuptools_scm]
[tool.pytest.ini_options]
testpaths = ["tests"]
python_files = "test_*.py"
addopts = [
"--strict-config",
"--strict-markers",
]
xfail_strict = true
filterwarnings = [
"error",
"ignore::DeprecationWarning:typer",
]
[tool.mypy]
# for ignore rules: # type: ignore[error_code]
packages = ["src.celery_starter"]
python_version = "3.9"
strict = true # строгая проверка типов
ignore_missing_imports = true # [import-untyped]
# Проверять тело функции без типизации аргументов
check_untyped_defs = true # [annotation-unchecked]
# Не ругаться на нетипизированный родительский класс
disallow_subclassing_any = false # [misc]
# Не ругаться на вызов нетипизированной функции
disallow_untyped_calls = false # [no-untyped-call]
# Не ругаться на return -> Any
warn_return_any = false # [no-any-return]
# Не ругаться на определение функций без аннотаций типов или с неполными аннотациями типов
# disallow_untyped_defs = false
# Игнор ряда кодов, глобально по проекту
disable_error_code = [
"operator",
"assignment",
"union-attr",
]
[tool.coverage.run]
concurrency = ["multiprocessing", "thread"]
omit = ["*/tests/*", "apps.py"] # Не проверять директории и(или) файлы
parallel = true
branch = true # Включать в замер результаты вхождения в условия
source = ["src.celery_starter"]
[tool.coverage.report]
fail_under = 75 # Тест упадёт если покрытие составит менее 75%
skip_covered = true # Не включать в отчет информацию о файлах со 100% покрытием
show_missing = true # Включать в отчет информацию о номерах не протестированных строк кода
sort = "-Cover" # Сортировать отчет по уровню покрытия
# https://docs.astral.sh/ruff/settings/
# https://docs.astral.sh/ruff/configuration/#full-command-line-interface
# cmd: ruff format # Отформатирует все файлы в `.` текущем каталоге.
[tool.ruff]
required-version = "<=0.8.0"
target-version = "py312" # Версия python которую будет обслуживать ruff
line-length = 105 # Макс длина строки кода после которой будет выполнен автоперенос
indent-width = 4
force-exclude = true # pre-commit файл будет использовать exclude список
src = ["src"] # Корень проекта в котором лежат приложения (необходимо для работы ruff.lint.isort)
extend-exclude = [
"migrations",
]
[tool.ruff.format]
quote-style = "single" # Использовать одинарные кавычки при форматировании файла
indent-style = "space" # Использовать пробелы вместо табуляции при форматировании файла
# line-ending = "lf" # Последовательность конца строки для файлов по умолчанию
# https://docs.astral.sh/ruff/linter/
# cmd: ruff check --fix # Проверить линтером все файлы в `.` текущем каталоге и исправить все безопасные проблемы.
[tool.ruff.lint]
# Настройки по умолчанию: https://docs.astral.sh/ruff/configuration/
# https://docs.astral.sh/ruff/rules/
# select по умолчанию: ["E4", "E7", "E9", "F"]
extend-select = [
"E", # https://docs.astral.sh/ruff/rules/#pycodestyle-e-w
"W", # https://docs.astral.sh/ruff/rules/#pycodestyle-e-w
"I", # https://docs.astral.sh/ruff/rules/#isort-i
"N", # https://docs.astral.sh/ruff/rules/#pep8-naming-n
"UP", # https://docs.astral.sh/ruff/rules/#pyupgrade-up
"YTT", # https://docs.astral.sh/ruff/rules/#flake8-2020-ytt
"ASYNC", # https://docs.astral.sh/ruff/rules/#flake8-async-async
"BLE", # https://docs.astral.sh/ruff/rules/#flake8-blind-except-ble
"B", # https://docs.astral.sh/ruff/rules/#flake8-bugbear-b
"A", # https://docs.astral.sh/ruff/rules/#flake8-builtins-a
"COM", # https://docs.astral.sh/ruff/rules/#flake8-commas-com
"C4", # https://docs.astral.sh/ruff/rules/#flake8-comprehensions-c4
"DTZ", # https://docs.astral.sh/ruff/rules/#flake8-datetimez-dtz
"T10", # https://docs.astral.sh/ruff/rules/#flake8-debugger-t10
"DJ", # https://docs.astral.sh/ruff/rules/#flake8-django-dj
"FA", # https://docs.astral.sh/ruff/rules/#flake8-future-annotations-fa
"ISC", # https://docs.astral.sh/ruff/rules/#flake8-implicit-str-concat-isc
"ICN", # https://docs.astral.sh/ruff/rules/#flake8-import-conventions-icn
"G", # https://docs.astral.sh/ruff/rules/#flake8-logging-format-g
"INP", # https://docs.astral.sh/ruff/rules/#flake8-no-pep420-inp
"PIE", # https://docs.astral.sh/ruff/rules/#flake8-pie-pie
"PYI", # https://docs.astral.sh/ruff/rules/#flake8-pyi-pyi
"PT", # https://docs.astral.sh/ruff/rules/#flake8-pytest-style-pt
"Q", # https://docs.astral.sh/ruff/rules/#flake8-quotes-q
"RSE", # https://docs.astral.sh/ruff/rules/#flake8-raise-rse
"RET", # https://docs.astral.sh/ruff/rules/#flake8-return-ret
"SLF", # https://docs.astral.sh/ruff/rules/#flake8-self-slf
"SLOT", # https://docs.astral.sh/ruff/rules/#flake8-slots-slot
"SIM", # https://docs.astral.sh/ruff/rules/#flake8-simplify-sim
"TID", # https://docs.astral.sh/ruff/rules/#flake8-tidy-imports-tid
"TCH", # https://docs.astral.sh/ruff/rules/#flake8-type-checking-tch
"TD", # https://docs.astral.sh/ruff/rules/#flake8-todos-td
"INT", # https://docs.astral.sh/ruff/rules/#flake8-gettext-int
"FLY", # https://docs.astral.sh/ruff/rules/#flynt-fly
"PERF", # https://docs.astral.sh/ruff/rules/#perflint-perf
"LOG", # https://docs.astral.sh/ruff/rules/#flake8-logging-log
"RUF", # https://docs.astral.sh/ruff/rules/#ruff-specific-rules-ruf
#! https://docs.astral.sh/ruff/rules/#refurb-furb
#! "FURB", # refurb (пока что не стабильно 29.03.2024)
]
ignore = [
# https://docs.astral.sh/ruff/rules/#pyflakes-f
"F403", # (не ругаться на использование from ... import *)
# https://docs.astral.sh/ruff/rules/#pyupgrade-up
"UP031", # (не ругаться на форматирование с помощью %s)
"UP036", # (не ругаться на использование sys.version_info если текущая версия не подпадает под условие)
# https://docs.astral.sh/ruff/rules/#flake8-logging-format-g
"G004", # (не ругаться на использование f-строк для сообщения лога)
# https://docs.astral.sh/ruff/rules/#ruff-specific-rules-ruf
"RUF001", # (не ругаться на кириллицу в строках)
"RUF002", # (не ругаться на кириллицу в докстрингах)
"RUF003", # (не ругаться на кириллицу в комментариях)
"RUF012", # (не ругаться на мутабельность коллекций)
# https://docs.astral.sh/ruff/rules/#flake8-pytest-style-pt
"PT009", # (не ругаться на unittest ассерты)
"PT027", # (не ругаться на unittest ассерты)
"PT001", # (не ругаться на отсутствие круглых скобок у декоратора fixture)
"PT004", # (не ругаться на написание фикстур которые ничего не возвращают без префикса "_")
# https://docs.astral.sh/ruff/rules/#flake8-implicit-str-concat-isc
"ISC001", # (конфликт с `COM812`)
# https://docs.astral.sh/ruff/rules/#flake8-commas-com
"COM812", # (конфликт с `ISC001`)
# https://docs.astral.sh/ruff/rules/#flake8-self-slf
"SLF001", # (не ругаться на приватные названия объектов)
# https://docs.astral.sh/ruff/rules/#flake8-simplify-sim
"SIM105", # (не ругаться на использование try except pass блока)
# https://docs.astral.sh/ruff/rules/#flake8-return-ret
"RET503", # (не ругаться на отсутствие return None в конце функций)
# https://docs.astral.sh/ruff/rules/#flake8-blind-except-ble
"BLE001", # (не ругаться на обработку обычного Exception)
# https://docs.astral.sh/ruff/rules/#flake8-django-dj
# https://docs.djangoproject.com/en/4.2/ref/models/fields/#null
# https://sentry.io/answers/django-difference-between-null-and-blank/
# https://www.django-rest-framework.org/api-guide/fields/#charfield
"DJ001", # (не ругаться на использование null в моделях для текстовых полей)
# https://docs.astral.sh/ruff/rules/#flake8-comprehensions-c4
# {} VS dict() # https://switowski.com/blog/dict-function-vs-literal-syntax/
"C408", # (не ругаться на использование классов коллекций вместо их литералов)
"TD001", # (не ругаться на использование FIXME и XXX)
"TD003", # (не ругаться на отсутствие ссылки на issues)
]
# Не давать исправлять эти ошибки в тултипе, и в том числе автоматически при линте через команду
unfixable = [
]
[tool.ruff.lint.per-file-ignores]
"asgi.py" = ["E402"]
# https://docs.astral.sh/ruff/settings/#lintisort
[tool.ruff.lint.isort]
force-wrap-aliases = true # Записывать импорты с несколькими `as` в кортеже
combine-as-imports = true # Записывать импорты с несколькими `as` в одной строке
# force-sort-within-sections = true # Всегда сортировать импорты по алфавиту, не обращая внимание на порядок import или from
# from-first = true # Записывать from импорты перед import
# length-sort = true # Сортировать импорты по длине строки а не по алфавиту
# lines-after-imports = 2 # Количество пустых строк после последнего импорта
# order-by-type = true # Сортировать по регистру в дополнение к сортировке по алфавиту
# required-imports = ["from __future__ import annotations"] # Добавить импорт во все файлы
[tool.ruff.lint.flake8-quotes]
inline-quotes = "single" # Не ругаться на одинарные кавычки
docstring-quotes = "double" # Ругаться на одинарные кавычки