Skip to content

Commit

Permalink
Add pyproject.toml file (#11348)
Browse files Browse the repository at this point in the history
  • Loading branch information
ofek authored Feb 17, 2022
1 parent 1d5e743 commit fe0beea
Show file tree
Hide file tree
Showing 5 changed files with 83 additions and 15 deletions.
10 changes: 0 additions & 10 deletions exchange_server/MANIFEST.in

This file was deleted.

65 changes: 65 additions & 0 deletions exchange_server/pyproject.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,65 @@
[build-system]
requires = [
"hatchling>=0.11.2",
"setuptools; python_version < '3.0'",
]
build-backend = "hatchling.build"

[project]
name = "datadog-exchange-server"
description = "The Exchange Server check"
readme = "README.md"
license = "BSD-3-Clause"
keywords = [
"datadog",
"datadog agent",
"datadog check",
"exchange_server",
]
authors = [
{ name = "Datadog", email = "packages@datadoghq.com" },
]
classifiers = [
"Development Status :: 5 - Production/Stable",
"Intended Audience :: Developers",
"Intended Audience :: System Administrators",
"License :: OSI Approved :: BSD License",
"Programming Language :: Python :: 2.7",
"Programming Language :: Python :: 3.8",
"Topic :: System :: Monitoring",
]
dependencies = [
"datadog-checks-base>=23.3.2",
]
dynamic = [
"version",
]

[project.optional-dependencies]
deps = [
"pywin32==228; sys_platform == 'win32' and python_version < '3.0'",
"pywin32==300; sys_platform == 'win32' and python_version > '3.0'",
]

[project.urls]
Source = "https://github.com/DataDog/integrations-core"

[tool.hatch.version]
path = "datadog_checks/exchange_server/__about__.py"

[tool.hatch.build.targets.sdist]
include = [
"/datadog_checks",
"/tests",
"/manifest.json",
"/requirements-dev.txt",
"/tox.ini",
]

[tool.hatch.build.targets.wheel]
include = [
"/datadog_checks",
]
dev-mode-dirs = [
".",
]
2 changes: 0 additions & 2 deletions exchange_server/requirements.in

This file was deleted.

19 changes: 17 additions & 2 deletions exchange_server/setup.py
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,22 @@ def get_dependencies():
return f.readlines()


CHECKS_BASE_REQ = 'datadog-checks-base>=23.3.2'
def parse_pyproject_array(name):
import os
import re
from ast import literal_eval

pattern = r'^{} = (\[.*?\])$'.format(name)

with open(os.path.join(HERE, 'pyproject.toml'), 'r', encoding='utf-8') as f:
# Windows \r\n prevents match
contents = '\n'.join(line.rstrip() for line in f.readlines())

array = re.search(pattern, contents, flags=re.MULTILINE | re.DOTALL).group(1)
return literal_eval(array)


CHECKS_BASE_REQ = parse_pyproject_array('dependencies')[0]

setup(
name='datadog-exchange_server',
Expand Down Expand Up @@ -59,7 +74,7 @@ def get_dependencies():
packages=['datadog_checks.exchange_server'],
# Run-time dependencies
install_requires=[CHECKS_BASE_REQ],
extras_require={'deps': get_dependencies()},
extras_require={'deps': parse_pyproject_array('deps')},
# Extra files to ship with the wheel package
include_package_data=True,
)
2 changes: 1 addition & 1 deletion exchange_server/tox.ini
Original file line number Diff line number Diff line change
Expand Up @@ -12,10 +12,10 @@ envdir =
dd_check_style = true
usedevelop = true
platform = win32
extras = deps
deps =
-e../datadog_checks_base[deps]
../datadog_checks_tests_helper
-rrequirements-dev.txt
commands =
pip install -r requirements.in
pytest -v {posargs}

0 comments on commit fe0beea

Please sign in to comment.