2023-08-11 22:02:51 +03:00
|
|
|
#!/usr/bin/env bash
|
|
|
|
set -e
|
|
|
|
|
|
|
|
# Description: This test checks if the number of bases and tables processed are as expected.
|
|
|
|
# Each base shows up as a directory in the output folder, hence check-num-dirs-output.sh
|
|
|
|
# Each table shows up as a file in a base directory, hence check-num-files-output.sh
|
|
|
|
|
|
|
|
SCRIPT_DIR=$(dirname "$(realpath "$0")")
|
|
|
|
cd "$SCRIPT_DIR"/.. || exit 1
|
|
|
|
|
|
|
|
OUTPUT_FOLDER_NAME=airtable-large
|
|
|
|
OUTPUT_DIR=$SCRIPT_DIR/structured-output/$OUTPUT_FOLDER_NAME
|
|
|
|
DOWNLOAD_DIR=$SCRIPT_DIR/download/$OUTPUT_FOLDER_NAME
|
|
|
|
|
|
|
|
if [ -z "$AIRTABLE_PERSONAL_ACCESS_TOKEN" ]; then
|
|
|
|
echo "Skipping Airtable ingest test because the AIRTABLE_PERSONAL_ACCESS_TOKEN is not set."
|
|
|
|
exit 0
|
|
|
|
fi
|
|
|
|
|
|
|
|
# Provides component IDs such as LARGE_TEST_LIST_OF_PATHS,
|
|
|
|
# LARGE_TABLE_BASE_ID, LARGE_TABLE_TABLE_ID, and LARGE_BASE_BASE_ID
|
|
|
|
# shellcheck disable=SC1091
|
|
|
|
source ./scripts/airtable-test-helpers/component_ids.sh
|
|
|
|
|
|
|
|
PYTHONPATH=. ./unstructured/ingest/main.py \
|
|
|
|
airtable \
|
|
|
|
--download-dir "$DOWNLOAD_DIR" \
|
|
|
|
--personal-access-token "$AIRTABLE_PERSONAL_ACCESS_TOKEN" \
|
|
|
|
--list-of-paths "$LARGE_TEST_LIST_OF_PATHS" \
|
2023-09-07 22:56:43 -04:00
|
|
|
--metadata-exclude filename,file_directory,metadata.data_source.date_processed,metadata.date,metadata.detection_class_prob \
|
2023-08-11 22:02:51 +03:00
|
|
|
--num-processes 2 \
|
|
|
|
--preserve-downloads \
|
|
|
|
--reprocess \
|
2023-09-11 11:40:56 -04:00
|
|
|
--output-dir "$OUTPUT_DIR"
|
2023-08-11 22:02:51 +03:00
|
|
|
|
|
|
|
|
|
|
|
# We are expecting fifteen directories: fourteen bases and the parent directory
|
|
|
|
sh "$SCRIPT_DIR"/check-num-dirs-output.sh 15 "$OUTPUT_FOLDER_NAME"
|
|
|
|
|
|
|
|
# We are expecting 101 files: 100 tables and the parent directory
|
|
|
|
sh "$SCRIPT_DIR"/check-num-files-output.sh 101 "$OUTPUT_FOLDER_NAME"/"$LARGE_BASE_BASE_ID"/
|
|
|
|
|
|
|
|
# Test on ingesting a large number of bases
|
|
|
|
for i in {1..12}; do
|
|
|
|
var="LARGE_WORKSPACE_BASE_ID_$i"
|
|
|
|
sh "$SCRIPT_DIR"/check-num-files-output.sh 12 "$OUTPUT_FOLDER_NAME"/"${!var}"
|
|
|
|
done
|
|
|
|
|
|
|
|
# Test on ingesting a table with lots of rows
|
|
|
|
sh "$SCRIPT_DIR"/check-num-rows-and-columns-output.sh 39999 "$OUTPUT_DIR"/"$LARGE_TABLE_BASE_ID"/"$LARGE_TABLE_TABLE_ID".json
|