2023-12-19 08:58:23 -08:00
|
|
|
#!/usr/bin/env bash
|
|
|
|
|
|
|
|
set -e
|
|
|
|
|
|
|
|
SRC_PATH=$(dirname "$(realpath "$0")")
|
|
|
|
SCRIPT_DIR=$(dirname "$SRC_PATH")
|
|
|
|
cd "$SCRIPT_DIR"/.. || exit 1
|
|
|
|
OUTPUT_FOLDER_NAME=chroma-dest
|
|
|
|
OUTPUT_DIR=$SCRIPT_DIR/structured-output/$OUTPUT_FOLDER_NAME
|
|
|
|
WORK_DIR=$SCRIPT_DIR/workdir/$OUTPUT_FOLDER_NAME
|
|
|
|
DOWNLOAD_DIR=$SCRIPT_DIR/download/$OUTPUT_FOLDER_NAME
|
|
|
|
DESTINATION_PATH=$SCRIPT_DIR/chroma-dest
|
|
|
|
max_processes=${MAX_PROCESSES:=$(python3 -c "import os; print(os.cpu_count())")}
|
|
|
|
CI=${CI:-"false"}
|
|
|
|
|
|
|
|
RANDOM_SUFFIX=$((RANDOM % 100000 + 1))
|
|
|
|
|
|
|
|
COLLECTION_NAME="chroma-test-output-$RANDOM_SUFFIX"
|
|
|
|
|
|
|
|
# shellcheck disable=SC1091
|
|
|
|
source "$SCRIPT_DIR"/cleanup.sh
|
|
|
|
|
|
|
|
function cleanup() {
|
|
|
|
# Kill chroma background process
|
|
|
|
pgrep -f chroma-dest | xargs kill
|
|
|
|
cleanup_dir "$DESTINATION_PATH"
|
|
|
|
cleanup_dir "$OUTPUT_DIR"
|
|
|
|
cleanup_dir "$WORK_DIR"
|
|
|
|
if [ "$CI" == "true" ]; then
|
|
|
|
cleanup_dir "$DOWNLOAD_DIR"
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
trap cleanup EXIT
|
|
|
|
|
|
|
|
# Run chroma from different script so it can be forced into background
|
|
|
|
scripts/chroma-test-helpers/create-and-check-chroma.sh "$DESTINATION_PATH"
|
|
|
|
wait
|
|
|
|
|
|
|
|
PYTHONPATH=. ./unstructured/ingest/main.py \
|
|
|
|
local \
|
|
|
|
--num-processes "$max_processes" \
|
|
|
|
--output-dir "$OUTPUT_DIR" \
|
|
|
|
--strategy fast \
|
|
|
|
--verbose \
|
|
|
|
--input-path example-docs/book-war-and-peace-1p.txt \
|
|
|
|
--work-dir "$WORK_DIR" \
|
2024-05-21 13:01:49 -04:00
|
|
|
--chunking-strategy by_title \
|
2024-01-16 13:48:36 -08:00
|
|
|
--chunk-max-characters 1500 \
|
2023-12-19 08:58:23 -08:00
|
|
|
--chunk-multipage-sections \
|
|
|
|
--embedding-provider "langchain-huggingface" \
|
|
|
|
chroma \
|
|
|
|
--host "localhost" \
|
|
|
|
--port 8000 \
|
|
|
|
--collection-name "$COLLECTION_NAME" \
|
2024-01-16 17:53:52 -08:00
|
|
|
--tenant "default_tenant" \
|
|
|
|
--database "default_database" \
|
2023-12-19 08:58:23 -08:00
|
|
|
--batch-size 80
|
|
|
|
|
|
|
|
python "$SCRIPT_DIR"/python/test-ingest-chroma-output.py --collection-name "$COLLECTION_NAME"
|