2023-07-18 19:29:41 +01:00
|
|
|
#!/usr/bin/env bash
|
|
|
|
set -e
|
|
|
|
|
|
|
|
# Description: This test checks if the number of spaces and documents processed are as expected.
|
|
|
|
# Each space shows up as a directory in the output folder, hence check-num-dirs-output.sh
|
|
|
|
# Each document shows up as a file in a space directory, hence check-num-files-output.sh
|
|
|
|
|
|
|
|
SCRIPT_DIR=$(dirname "$(realpath "$0")")
|
|
|
|
cd "$SCRIPT_DIR"/.. || exit 1
|
|
|
|
|
|
|
|
OUTPUT_FOLDER_NAME=confluence-large
|
|
|
|
OUTPUT_DIR=$SCRIPT_DIR/structured-output/$OUTPUT_FOLDER_NAME
|
|
|
|
DOWNLOAD_DIR=$SCRIPT_DIR/download/$OUTPUT_FOLDER_NAME
|
|
|
|
|
|
|
|
if [ -z "$CONFLUENCE_USER_EMAIL" ] || [ -z "$CONFLUENCE_API_TOKEN" ]; then
|
|
|
|
echo "Skipping Confluence ingest test because the CONFLUENCE_USER_EMAIL or CONFLUENCE_API_TOKEN env var is not set."
|
|
|
|
exit 0
|
|
|
|
fi
|
|
|
|
|
|
|
|
# The test checks the scenario where --confluence-list-of-spaces and --confluence-num-of-spaces
|
|
|
|
# are being provided at the same time, which is a wrong way to use the connector.
|
|
|
|
|
|
|
|
# We expect the test to ignore --confluence-num-of-spaces and use --confluence-list-of-spaces.
|
|
|
|
PYTHONPATH=. ./unstructured/ingest/main.py \
|
2023-07-31 13:20:10 -04:00
|
|
|
confluence \
|
2023-07-18 19:29:41 +01:00
|
|
|
--download-dir "$DOWNLOAD_DIR" \
|
2023-09-07 22:56:43 -04:00
|
|
|
--metadata-exclude filename,file_directory,metadata.data_source.date_processed,metadata.last_modified,metadata.detection_class_prob \
|
2023-07-18 19:29:41 +01:00
|
|
|
--num-processes 2 \
|
|
|
|
--preserve-downloads \
|
|
|
|
--reprocess \
|
2023-09-11 11:40:56 -04:00
|
|
|
--output-dir "$OUTPUT_DIR" \
|
2023-07-31 13:20:10 -04:00
|
|
|
--verbose \
|
|
|
|
--url https://unstructured-ingest-test.atlassian.net \
|
|
|
|
--user-email "$CONFLUENCE_USER_EMAIL" \
|
|
|
|
--api-token "$CONFLUENCE_API_TOKEN" \
|
|
|
|
--max-num-of-spaces 10 \
|
2023-09-11 11:40:56 -04:00
|
|
|
--spaces testteamsp1 \
|
2023-07-31 13:20:10 -04:00
|
|
|
--max-num-of-docs-from-each-space 250 \
|
2023-07-18 19:29:41 +01:00
|
|
|
|
|
|
|
OUTPUT_SUBFOLDER_NAME=testteamsp1
|
|
|
|
|
|
|
|
# We are expecting two directories: one for the space, and one is the output directory itself
|
|
|
|
# Example:
|
|
|
|
# Output dir: unstructured/test_unstructured_ingest/structured-output/confluence-large
|
|
|
|
# Space dir: unstructured/test_unstructured_ingest/structured-output/confluence-large/testteamsp1
|
|
|
|
sh "$SCRIPT_DIR"/check-num-dirs-output.sh 2 "$OUTPUT_FOLDER_NAME"
|
|
|
|
|
|
|
|
# We are expecting 250 files due to the --confluence-num-of-docs-from-each-space 250 that we provided.
|
|
|
|
sh "$SCRIPT_DIR"/check-num-files-output.sh 250 "$OUTPUT_FOLDER_NAME"/"$OUTPUT_SUBFOLDER_NAME"/
|