fix: quivr core fix tests (#2935)

# Description
- Update CI
- Fix DockerFile for quivr-core tests
- Tox parallel tests

@StanGirard  @chloedia 
- For running quivr-core tests:
```bash
cd backend/core
./scripts/run_tests.sh
```

---------

Co-authored-by: aminediro <aminedirhoussi@gmail.com>
Co-authored-by: Stan Girard <girard.stanislas@gmail.com>
This commit is contained in:
AmineDiro 2024-08-01 15:54:43 +02:00 committed by GitHub
parent 2d64962ca4
commit d9c1f3add4
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
5 changed files with 63 additions and 6 deletions

View File

@ -33,12 +33,20 @@ jobs:
cd backend/core cd backend/core
python -m pip install --upgrade pip python -m pip install --upgrade pip
pip install poetry pip install poetry
poetry install -E base poetry install -E base --with dev,test
- name: Run pre-commit checks
run: |
cd backend/core
poetry run pre-commit run --files .
- name: Run tests - name: Run tests
env: env:
TIKA_URL: http://localhost:9998/tika TIKA_URL: http://localhost:9998/tika
OPENAI_API_KEY: this-is-a-test-key OPENAI_API_KEY: this-is-a-test-key
run: | run: |
sudo apt-get update
sudo apt-get install -y libmagic-dev poppler-utils libreoffice tesseract-ocr pandoc
tesseract --version
cd backend/core cd backend/core
poetry run pytest tests poetry run tox

View File

@ -5,6 +5,9 @@ FROM python:3.11.6-slim-bullseye
RUN apt-get clean && apt-get update && apt-get install -y \ RUN apt-get clean && apt-get update && apt-get install -y \
curl \ curl \
gcc \ gcc \
autoconf \
automake \
build-essential \
# Additional dependencies for document handling # Additional dependencies for document handling
libmagic-dev \ libmagic-dev \
tesseract-ocr \ tesseract-ocr \
@ -28,7 +31,10 @@ ENV PATH="/root/.local/bin:$PATH"
# Copy the current directory contents into the container at /app # Copy the current directory contents into the container at /app
COPY ./pyproject.toml ./poetry.lock* /code/ COPY ./pyproject.toml ./poetry.lock* /code/
RUN python3 -m pip install nltk && python3 -c "import nltk; nltk.download('punkt')" \
&& python3 -c "import nltk; nltk.download('averaged_perceptron_tagger')"
# Install project dependencies # Install project dependencies
RUN poetry install --no-root --with test RUN poetry install --with test
ENV PYTHONPATH=/code ENV PYTHONPATH=/code

View File

@ -8,7 +8,8 @@ IMAGE_NAME="quivr-core-test"
IMAGE_TAG="latest" IMAGE_TAG="latest"
DOCKERFILE="Dockerfile.test" DOCKERFILE="Dockerfile.test"
VOLUME_MAPPING="$PWD:/code" VOLUME_MAPPING="$PWD:/code"
CMD="poetry run tox" TOX_DIR="/code/.tox-docker"
CMD="poetry run tox -p auto"
# Functions # Functions
build_image() { build_image() {
@ -18,7 +19,10 @@ build_image() {
run_container() { run_container() {
echo "Running tests in Docker container..." echo "Running tests in Docker container..."
docker run -it --rm -v $VOLUME_MAPPING $IMAGE_NAME:$IMAGE_TAG $CMD docker run -it --rm \
-e TOX_WORK_DIR=$TOX_DIR \
-v $VOLUME_MAPPING \
$IMAGE_NAME:$IMAGE_TAG $CMD
} }
# Main script execution # Main script execution

View File

@ -0,0 +1,39 @@
#!/bin/bash
set -e
# Constants
IMAGE_NAME="quivr-core-test"
IMAGE_TAG="latest"
DOCKERFILE="Dockerfile.test"
VOLUME_MAPPING="$PWD:/code"
CMD="poetry run tox"
PLATFORM="linux/amd64"
BUILDER_NAME="amd64_builder"
# Functions
build_image() {
echo "Building Docker image for $PLATFORM..."
EXISTING_BUILDER=$(docker buildx ls | grep -w $BUILDER_NAME)
# Create the builder if it doesn't exist
if [ -z "$EXISTING_BUILDER" ]; then
echo "Creating builder: $BUILDER_NAME"
docker buildx create --use --name $BUILDER_NAME --platform $PLATFORM
else
echo "Builder $BUILDER_NAME already exists. Skipping creation."
fi
docker buildx build --platform $PLATFORM -f $DOCKERFILE -t $IMAGE_NAME:$IMAGE_TAG --load .
}
run_container() {
echo "Running tests in Docker container..."
docker run -it --rm --platform $PLATFORM -v $VOLUME_MAPPING $IMAGE_NAME:$IMAGE_TAG $CMD
}
# Main script execution
build_image
run_container
echo "Tests completed successfully."

View File

@ -14,7 +14,7 @@ allowlist_externals =
commands_pre = commands_pre =
poetry install --no-root --with test poetry install --no-root --with test
commands = commands =
poetry run pytest tests/ -m "not base and not tika" \ poetry run pytest tests/ -m "not base" \
--ignore=./tests/processor/epub \ --ignore=./tests/processor/epub \
--ignore=./tests/processor/docx \ --ignore=./tests/processor/docx \
--ignore=./tests/processor/odt \ --ignore=./tests/processor/odt \