forked from pyscaffold/pyscaffold
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsetup.cfg
175 lines (165 loc) · 5.55 KB
/
setup.cfg
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
[metadata]
name = PyScaffold
description = Template tool for putting up the scaffold of a Python project
author = Florian Wilhelm
author_email = [email protected]
license = MIT
url = https://github.com/pyscaffold/pyscaffold/
project_urls =
Documentation = https://pyscaffold.org/
Source = https://github.com/pyscaffold/pyscaffold/
Tracker = https://github.com/pyscaffold/pyscaffold/issues
Changelog = https://pyscaffold.org/en/latest/changelog.html
Conda-Forge = https://anaconda.org/conda-forge/pyscaffold
Download = https://pypi.org/project/PyScaffold/#files
Twitter = https://twitter.com/PyScaffold
long_description = file: README.rst
long_description_content_type = text/x-rst; charset=UTF-8
platforms = any
classifiers =
Development Status :: 5 - Production/Stable
Topic :: Utilities
Programming Language :: Python
Programming Language :: Python :: 3
Programming Language :: Python :: 3 :: Only
Environment :: Console
Intended Audience :: Developers
License :: OSI Approved :: MIT License
Operating System :: POSIX :: Linux
Operating System :: Unix
Operating System :: MacOS
Operating System :: Microsoft :: Windows
[options]
zip_safe = False
packages = find_namespace:
python_requires = >=3.6
include_package_data = True
package_dir =
=src
install_requires =
importlib-metadata; python_version<"3.8"
platformdirs>=2,<3
configupdater>=3.0,<4 # pyscaffoldext-custom-extension should have a compatible range
setuptools>=46.1.0
setuptools_scm>=5
tomlkit>=0.7.0,<2
packaging>=20.7
colorama>=0.4.4; sys_platform == "win32"
# packaging is versioned by year, not SemVer
# Notes about setuptools versions:
# - 40.1: required for `find_namespace`
# - 45: required for `setuptools_scm` v6
# However we specify a higher version so we encourage users to update the
# version they have installed...
[options.packages.find]
where = src
exclude =
tests
[options.extras_require]
# Add here additional requirements for extra features, like:
all =
pyscaffoldext-markdown>=0.4
pyscaffoldext-custom-extension>=0.6
pyscaffoldext-dsproject>=0.5
pyscaffoldext-django>=0.1.1
pyscaffoldext-cookiecutter>=0.1
pyscaffoldext-travis>=0.3
virtualenv
pre-commit
md =
pyscaffoldext-markdown>=0.4
ds =
pyscaffoldext-dsproject>=0.5
# Add here test dependencies (used by tox)
testing =
# Used for building/installing during tests
setuptools
setuptools_scm[toml]
wheel
build
#
tomlkit # as dependency in `-e fast`
certifi # tries to prevent certificate problems on windows
tox # system tests use tox inside tox
pre-commit # system tests run pre-commit
sphinx # system tests build docs
flake8 # system tests run flake8
virtualenv # virtualenv as dependency for the venv extension in `-e fast`
pytest
pytest-cov
pytest-shutil
pytest-virtualenv
pytest-fixture-config
pytest-xdist
pytest-randomly
# We keep pytest-xdist in the test dependencies, so the developer can
# easily opt-in for distributed tests by adding, for example, the `-n 15`
# arguments in the command-line.
[options.entry_points]
console_scripts =
putup = pyscaffold.cli:run
pyscaffold.cli =
config = pyscaffold.extensions.config:Config
interactive = pyscaffold.extensions.interactive:Interactive
venv = pyscaffold.extensions.venv:Venv
namespace = pyscaffold.extensions.namespace:Namespace
no_skeleton = pyscaffold.extensions.no_skeleton:NoSkeleton
pre_commit = pyscaffold.extensions.pre_commit:PreCommit
no_tox = pyscaffold.extensions.no_tox:NoTox
cirrus = pyscaffold.extensions.cirrus:Cirrus
gitlab = pyscaffold.extensions.gitlab_ci:GitLab
github_actions = pyscaffold.extensions.github_actions:GithubActions
no_pyproject = pyscaffold.extensions.no_pyproject:NoPyProject
[tool:pytest]
# Options for pytest:
# Specify command line options as you would do when invoking pytest directly.
# e.g. --cov-report html (or xml) for html/xml output or --junit-xml junit.xml
# in order to write a coverage file that can be read by Jenkins.
# CAUTION: --cov flags may prohibit setting breakpoints while debugging.
# Comment those flags to avoid this pytest issue.
addopts =
--cov pyscaffold --cov-config .coveragerc --cov-report term-missing
--verbose
# In order to use xdist, the developer can add, for example, the following
# arguments:
# --numprocesses=auto
norecursedirs =
dist
build
.tox
testpaths = tests
markers =
only: for debugging purposes, a single, failing, test can be required to run
slow: mark tests as slow (deselect with '-m "not slow"')
system: mark system tests
original_logger: do not isolate logger in specific tests
no_fake_config_dir: avoid the autofixture fake_config_dir to take effect
requires_src: tests that require the raw source of PyScaffold and assume our default CI environment
log_level = DEBUG
log_cli = True
log_cli_level = CRITICAL
junit_family = xunit2
[devpi:upload]
# Options for the devpi: PyPI server and packaging tool
# VCS export must be deactivated since we are using setuptools-scm
no_vcs = 1
formats = bdist_wheel
[flake8]
# Some sane defaults for the code style checker flake8
# black compatibility
max_line_length = 88
# E203 and W503 have edge cases handled by black
extend_ignore = E203, W503
exclude =
src/pyscaffold/contrib
.tox
build
dist
.eggs
docs/conf.py
[mypy]
ignore_missing_imports = True
pretty = True
show_error_codes = True
show_error_context = True
show_traceback = True