forked from Archives/langchain
6dc86ad48f
Using `pytest-vcr` in integration tests has several benefits. Firstly, it removes the need to mock external services, as VCR records and replays HTTP interactions on the fly. Secondly, it simplifies the integration test setup by eliminating the need to set up and tear down external services in some cases. Finally, it allows for more reliable and deterministic integration tests by ensuring that HTTP interactions are always replayed with the same response. Overall, `pytest-vcr` is a valuable tool for simplifying integration test setup and improving their reliability This commit adds the `pytest-vcr` package as a dependency for integration tests in the `pyproject.toml` file. It also introduces two new fixtures in `tests/integration_tests/conftest.py` files for managing cassette directories and VCR configurations. In addition, the `tests/integration_tests/vectorstores/test_elasticsearch.py` file has been updated to use the `@pytest.mark.vcr` decorator for recording and replaying HTTP interactions. Finally, this commit removes the `documents` fixture from the `test_elasticsearch.py` file and replaces it with a new fixture defined in `tests/integration_tests/vectorstores/conftest.py` that yields a list of documents to use in any other tests. This also includes my second attempt to fix issue : https://github.com/hwchase17/langchain/issues/2386 Maybe related https://github.com/hwchase17/langchain/issues/2484
45 lines
1.5 KiB
Docker
45 lines
1.5 KiB
Docker
# This is a Dockerfile for running unit tests
|
|
|
|
# Use the Python base image
|
|
FROM python:3.11.2-bullseye AS builder
|
|
|
|
# Define the version of Poetry to install (default is 1.4.2)
|
|
ARG POETRY_VERSION=1.4.2
|
|
|
|
# Define the directory to install Poetry to (default is /opt/poetry)
|
|
ARG POETRY_HOME=/opt/poetry
|
|
|
|
# Create a Python virtual environment for Poetry and install it
|
|
RUN python3 -m venv ${POETRY_HOME} && \
|
|
$POETRY_HOME/bin/pip install --upgrade pip && \
|
|
$POETRY_HOME/bin/pip install poetry==${POETRY_VERSION}
|
|
|
|
# Test if Poetry is installed in the expected path
|
|
RUN echo "Poetry version:" && $POETRY_HOME/bin/poetry --version
|
|
|
|
# Set the working directory for the app
|
|
WORKDIR /app
|
|
|
|
# Use a multi-stage build to install dependencies
|
|
FROM builder AS dependencies
|
|
|
|
# Copy only the dependency files for installation
|
|
COPY pyproject.toml poetry.lock poetry.toml ./
|
|
|
|
# Install the Poetry dependencies (this layer will be cached as long as the dependencies don't change)
|
|
RUN $POETRY_HOME/bin/poetry install --no-interaction --no-ansi --with test
|
|
|
|
# Use a multi-stage build to run tests
|
|
FROM dependencies AS tests
|
|
|
|
# Copy the rest of the app source code (this layer will be invalidated and rebuilt whenever the source code changes)
|
|
COPY . .
|
|
|
|
RUN /opt/poetry/bin/poetry install --no-interaction --no-ansi --with test
|
|
|
|
# Set the entrypoint to run tests using Poetry
|
|
ENTRYPOINT ["/opt/poetry/bin/poetry", "run", "pytest"]
|
|
|
|
# Set the default command to run all unit tests
|
|
CMD ["tests/unit_tests"]
|