2023-12-11 21:53:30 +00:00
|
|
|
.PHONY: all format lint test tests test_watch integration_tests docker_tests help extended_tests
|
|
|
|
|
|
|
|
# Default target executed when no arguments are given to make.
|
|
|
|
all: help
|
|
|
|
|
|
|
|
# Define a variable for the test file path.
|
|
|
|
TEST_FILE ?= tests/unit_tests/
|
2024-02-06 00:39:55 +00:00
|
|
|
integration_tests: TEST_FILE = tests/integration_tests/
|
2023-12-11 21:53:30 +00:00
|
|
|
|
2024-02-06 00:39:55 +00:00
|
|
|
# Run unit tests and generate a coverage report.
|
|
|
|
coverage:
|
|
|
|
poetry run pytest --cov \
|
|
|
|
--cov-config=.coveragerc \
|
|
|
|
--cov-report xml \
|
|
|
|
--cov-report term-missing:skip-covered \
|
|
|
|
$(TEST_FILE)
|
2023-12-11 21:53:30 +00:00
|
|
|
|
2024-06-19 14:56:30 +00:00
|
|
|
test tests:
|
|
|
|
poetry run pytest --disable-socket --allow-unix-socket $(TEST_FILE)
|
|
|
|
|
|
|
|
integration_tests:
|
2023-12-11 21:53:30 +00:00
|
|
|
poetry run pytest $(TEST_FILE)
|
|
|
|
|
|
|
|
test_watch:
|
2024-06-19 14:56:30 +00:00
|
|
|
poetry run ptw --disable-socket --allow-unix-socket --snapshot-update --now . -- -vv -x tests/unit_tests
|
2023-12-11 21:53:30 +00:00
|
|
|
|
2023-12-11 22:59:10 +00:00
|
|
|
check_imports: $(shell find langchain_community -name '*.py')
|
2023-12-11 23:19:21 +00:00
|
|
|
poetry run python ./scripts/check_imports.py $^
|
2023-12-11 21:53:30 +00:00
|
|
|
|
|
|
|
extended_tests:
|
2024-06-19 14:56:30 +00:00
|
|
|
poetry run pytest --disable-socket --allow-unix-socket --only-extended tests/unit_tests
|
2023-12-11 21:53:30 +00:00
|
|
|
|
|
|
|
|
|
|
|
######################
|
|
|
|
# LINTING AND FORMATTING
|
|
|
|
######################
|
|
|
|
|
|
|
|
# Define a variable for Python and notebook files.
|
|
|
|
PYTHON_FILES=.
|
|
|
|
MYPY_CACHE=.mypy_cache
|
|
|
|
lint format: PYTHON_FILES=.
|
2024-02-23 00:02:00 +00:00
|
|
|
lint_diff format_diff: PYTHON_FILES=$(shell git diff --relative=libs/community --name-only --diff-filter=d master | grep -E '\.py$$|\.ipynb$$')
|
2023-12-11 21:53:30 +00:00
|
|
|
lint_package: PYTHON_FILES=langchain_community
|
|
|
|
lint_tests: PYTHON_FILES=tests
|
|
|
|
lint_tests: MYPY_CACHE=.mypy_cache_test
|
|
|
|
|
|
|
|
lint lint_diff lint_package lint_tests:
|
|
|
|
./scripts/check_pydantic.sh .
|
2024-07-11 16:22:08 +00:00
|
|
|
./scripts/lint_imports.sh .
|
2024-06-13 20:13:15 +00:00
|
|
|
./scripts/check_pickle.sh .
|
infra: update mypy 1.10, ruff 0.5 (#23721)
```python
"""python scripts/update_mypy_ruff.py"""
import glob
import tomllib
from pathlib import Path
import toml
import subprocess
import re
ROOT_DIR = Path(__file__).parents[1]
def main():
for path in glob.glob(str(ROOT_DIR / "libs/**/pyproject.toml"), recursive=True):
print(path)
with open(path, "rb") as f:
pyproject = tomllib.load(f)
try:
pyproject["tool"]["poetry"]["group"]["typing"]["dependencies"]["mypy"] = (
"^1.10"
)
pyproject["tool"]["poetry"]["group"]["lint"]["dependencies"]["ruff"] = (
"^0.5"
)
except KeyError:
continue
with open(path, "w") as f:
toml.dump(pyproject, f)
cwd = "/".join(path.split("/")[:-1])
completed = subprocess.run(
"poetry lock --no-update; poetry install --with typing; poetry run mypy . --no-color",
cwd=cwd,
shell=True,
capture_output=True,
text=True,
)
logs = completed.stdout.split("\n")
to_ignore = {}
for l in logs:
if re.match("^(.*)\:(\d+)\: error:.*\[(.*)\]", l):
path, line_no, error_type = re.match(
"^(.*)\:(\d+)\: error:.*\[(.*)\]", l
).groups()
if (path, line_no) in to_ignore:
to_ignore[(path, line_no)].append(error_type)
else:
to_ignore[(path, line_no)] = [error_type]
print(len(to_ignore))
for (error_path, line_no), error_types in to_ignore.items():
all_errors = ", ".join(error_types)
full_path = f"{cwd}/{error_path}"
try:
with open(full_path, "r") as f:
file_lines = f.readlines()
except FileNotFoundError:
continue
file_lines[int(line_no) - 1] = (
file_lines[int(line_no) - 1][:-1] + f" # type: ignore[{all_errors}]\n"
)
with open(full_path, "w") as f:
f.write("".join(file_lines))
subprocess.run(
"poetry run ruff format .; poetry run ruff --select I --fix .",
cwd=cwd,
shell=True,
capture_output=True,
text=True,
)
if __name__ == "__main__":
main()
```
2024-07-03 17:33:27 +00:00
|
|
|
poetry run ruff check .
|
2023-12-11 21:53:30 +00:00
|
|
|
[ "$(PYTHON_FILES)" = "" ] || poetry run ruff format $(PYTHON_FILES) --diff
|
infra: update mypy 1.10, ruff 0.5 (#23721)
```python
"""python scripts/update_mypy_ruff.py"""
import glob
import tomllib
from pathlib import Path
import toml
import subprocess
import re
ROOT_DIR = Path(__file__).parents[1]
def main():
for path in glob.glob(str(ROOT_DIR / "libs/**/pyproject.toml"), recursive=True):
print(path)
with open(path, "rb") as f:
pyproject = tomllib.load(f)
try:
pyproject["tool"]["poetry"]["group"]["typing"]["dependencies"]["mypy"] = (
"^1.10"
)
pyproject["tool"]["poetry"]["group"]["lint"]["dependencies"]["ruff"] = (
"^0.5"
)
except KeyError:
continue
with open(path, "w") as f:
toml.dump(pyproject, f)
cwd = "/".join(path.split("/")[:-1])
completed = subprocess.run(
"poetry lock --no-update; poetry install --with typing; poetry run mypy . --no-color",
cwd=cwd,
shell=True,
capture_output=True,
text=True,
)
logs = completed.stdout.split("\n")
to_ignore = {}
for l in logs:
if re.match("^(.*)\:(\d+)\: error:.*\[(.*)\]", l):
path, line_no, error_type = re.match(
"^(.*)\:(\d+)\: error:.*\[(.*)\]", l
).groups()
if (path, line_no) in to_ignore:
to_ignore[(path, line_no)].append(error_type)
else:
to_ignore[(path, line_no)] = [error_type]
print(len(to_ignore))
for (error_path, line_no), error_types in to_ignore.items():
all_errors = ", ".join(error_types)
full_path = f"{cwd}/{error_path}"
try:
with open(full_path, "r") as f:
file_lines = f.readlines()
except FileNotFoundError:
continue
file_lines[int(line_no) - 1] = (
file_lines[int(line_no) - 1][:-1] + f" # type: ignore[{all_errors}]\n"
)
with open(full_path, "w") as f:
f.write("".join(file_lines))
subprocess.run(
"poetry run ruff format .; poetry run ruff --select I --fix .",
cwd=cwd,
shell=True,
capture_output=True,
text=True,
)
if __name__ == "__main__":
main()
```
2024-07-03 17:33:27 +00:00
|
|
|
[ "$(PYTHON_FILES)" = "" ] || poetry run ruff check --select I $(PYTHON_FILES)
|
2024-02-05 19:22:06 +00:00
|
|
|
[ "$(PYTHON_FILES)" = "" ] || mkdir -p $(MYPY_CACHE) && poetry run mypy $(PYTHON_FILES) --cache-dir $(MYPY_CACHE)
|
2023-12-11 21:53:30 +00:00
|
|
|
|
|
|
|
format format_diff:
|
|
|
|
poetry run ruff format $(PYTHON_FILES)
|
infra: update mypy 1.10, ruff 0.5 (#23721)
```python
"""python scripts/update_mypy_ruff.py"""
import glob
import tomllib
from pathlib import Path
import toml
import subprocess
import re
ROOT_DIR = Path(__file__).parents[1]
def main():
for path in glob.glob(str(ROOT_DIR / "libs/**/pyproject.toml"), recursive=True):
print(path)
with open(path, "rb") as f:
pyproject = tomllib.load(f)
try:
pyproject["tool"]["poetry"]["group"]["typing"]["dependencies"]["mypy"] = (
"^1.10"
)
pyproject["tool"]["poetry"]["group"]["lint"]["dependencies"]["ruff"] = (
"^0.5"
)
except KeyError:
continue
with open(path, "w") as f:
toml.dump(pyproject, f)
cwd = "/".join(path.split("/")[:-1])
completed = subprocess.run(
"poetry lock --no-update; poetry install --with typing; poetry run mypy . --no-color",
cwd=cwd,
shell=True,
capture_output=True,
text=True,
)
logs = completed.stdout.split("\n")
to_ignore = {}
for l in logs:
if re.match("^(.*)\:(\d+)\: error:.*\[(.*)\]", l):
path, line_no, error_type = re.match(
"^(.*)\:(\d+)\: error:.*\[(.*)\]", l
).groups()
if (path, line_no) in to_ignore:
to_ignore[(path, line_no)].append(error_type)
else:
to_ignore[(path, line_no)] = [error_type]
print(len(to_ignore))
for (error_path, line_no), error_types in to_ignore.items():
all_errors = ", ".join(error_types)
full_path = f"{cwd}/{error_path}"
try:
with open(full_path, "r") as f:
file_lines = f.readlines()
except FileNotFoundError:
continue
file_lines[int(line_no) - 1] = (
file_lines[int(line_no) - 1][:-1] + f" # type: ignore[{all_errors}]\n"
)
with open(full_path, "w") as f:
f.write("".join(file_lines))
subprocess.run(
"poetry run ruff format .; poetry run ruff --select I --fix .",
cwd=cwd,
shell=True,
capture_output=True,
text=True,
)
if __name__ == "__main__":
main()
```
2024-07-03 17:33:27 +00:00
|
|
|
poetry run ruff check --select I --fix $(PYTHON_FILES)
|
2023-12-11 21:53:30 +00:00
|
|
|
|
|
|
|
spell_check:
|
|
|
|
poetry run codespell --toml pyproject.toml
|
|
|
|
|
|
|
|
spell_fix:
|
|
|
|
poetry run codespell --toml pyproject.toml -w
|
|
|
|
|
|
|
|
######################
|
|
|
|
# HELP
|
|
|
|
######################
|
|
|
|
|
|
|
|
help:
|
|
|
|
@echo '----'
|
|
|
|
@echo 'format - run code formatters'
|
|
|
|
@echo 'lint - run linters'
|
|
|
|
@echo 'test - run unit tests'
|
|
|
|
@echo 'tests - run unit tests'
|
|
|
|
@echo 'test TEST_FILE=<test_file> - run all tests in file'
|
|
|
|
@echo 'test_watch - run unit tests in watch mode'
|