forked from deepset-ai/haystack-core-integrations
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathpyproject.toml
More file actions
124 lines (105 loc) · 3.91 KB
/
pyproject.toml
File metadata and controls
124 lines (105 loc) · 3.91 KB
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
[build-system]
requires = ["hatchling", "hatch-vcs"]
build-backend = "hatchling.build"
[project]
name = "arcadedb-haystack"
dynamic = ["version"]
description = "An integration of ArcadeDB with Haystack — document storage + HNSW vector search + SQL filtering"
readme = "README.md"
requires-python = ">=3.10"
license = "Apache-2.0"
keywords = ["arcadedb", "haystack", "vector-search", "document-store", "rag"]
authors = [{ name = "deepset GmbH", email = "info@deepset.ai" }, { name = "ArcadeData Ltd", email = "info@arcadedb.com" }]
classifiers = [
"License :: OSI Approved :: Apache Software License",
"Development Status :: 4 - Beta",
"Programming Language :: Python",
"Programming Language :: Python :: 3.10",
"Programming Language :: Python :: 3.11",
"Programming Language :: Python :: 3.12",
"Programming Language :: Python :: 3.13",
"Programming Language :: Python :: 3.14",
"Programming Language :: Python :: Implementation :: CPython",
"Programming Language :: Python :: Implementation :: PyPy",
]
dependencies = [
"haystack-ai>=2.26.1",
"requests>=2.28.0",
]
[project.urls]
Source = "https://github.com/deepset-ai/haystack-core-integrations"
Documentation = "https://github.com/deepset-ai/haystack-core-integrations/blob/main/integrations/arcadedb/README.md"
Issues = "https://github.com/deepset-ai/haystack-core-integrations/issues"
[tool.hatch.build.targets.wheel]
packages = ["src/haystack_integrations"]
[tool.hatch.version]
source = "vcs"
tag-pattern = 'integrations\/arcadedb-v(?P<version>.*)'
[tool.hatch.version.raw-options]
root = "../.."
git_describe_command = 'git describe --tags --match="integrations/arcadedb-v[0-9]*"'
[tool.hatch.envs.default]
installer = "uv"
dependencies = ["haystack-pydoc-tools", "ruff"]
[tool.hatch.envs.default.scripts]
docs = ["haystack-pydoc pydoc/config_docusaurus.yml"]
fmt = "ruff check --fix {args}; ruff format {args}"
fmt-check = "ruff check {args} && ruff format --check {args}"
[tool.hatch.envs.test]
dependencies = [
"pytest",
"pytest-cov",
"pytest-rerunfailures",
"mypy",
"pip",
]
[tool.hatch.envs.test.scripts]
unit = 'pytest -m "not integration" {args:tests}'
integration = 'pytest -m "integration" {args:tests}'
all = 'pytest {args:tests}'
unit-cov-retry = 'pytest --cov=haystack_integrations --reruns 3 --reruns-delay 30 -x -m "not integration" {args:tests}'
integration-cov-append-retry = 'pytest --cov=haystack_integrations --cov-append --reruns 3 --reruns-delay 30 -x -m "integration" {args:tests}'
types = "mypy -p haystack_integrations.document_stores.arcadedb -p haystack_integrations.components.retrievers.arcadedb {args}"
[tool.mypy]
install_types = true
non_interactive = true
check_untyped_defs = true
disallow_incomplete_defs = true
[[tool.mypy.overrides]]
module = ["requests.*"]
ignore_missing_imports = true
[tool.ruff]
line-length = 120
[tool.ruff.lint]
select = [
"A", "ANN", "ARG", "B", "C", "DTZ", "E", "EM", "F", "FBT", "I", "ICN",
"ISC", "N", "PLC", "PLE", "PLR", "PLW", "Q", "RUF", "S", "T",
"TID", "UP", "W", "YTT",
]
ignore = [
"B027", "FBT003", "S105", "S106", "S107",
"C901", "PLR0911", "PLR0912", "PLR0913", "PLR0915",
"B008", "S101",
# Allow `Any` - used legitimately for filter values that can be any comparable type
"ANN401",
# SQL string construction is intentional — ArcadeDB uses HTTP/JSON API with value escaping
"S608",
]
[tool.ruff.lint.isort]
known-first-party = ["haystack_integrations"]
[tool.ruff.lint.flake8-tidy-imports]
ban-relative-imports = "parents"
[tool.ruff.lint.per-file-ignores]
"tests/**/*" = ["PLR2004", "S101", "TID252", "D", "ANN"]
"examples/**/*" = ["T201"]
[tool.coverage.run]
source = ["haystack_integrations"]
branch = true
relative_files = true
parallel = false
[tool.coverage.report]
omit = ["*/tests/*", "*/__init__.py"]
show_missing = true
exclude_lines = ["no cov", "if __name__ == .__main__.:", "if TYPE_CHECKING:"]
[tool.pytest.ini_options]
markers = ["integration: integration tests"]