mirror of
https://github.com/Unstructured-IO/unstructured.git
synced 2025-10-23 22:10:52 +00:00
51 lines
1.9 KiB
Bash
51 lines
1.9 KiB
Bash
![]() |
#!/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" \
|
||
|
--metadata-exclude filename,file_directory,metadata.data_source.date_processed,metadata.date \
|
||
|
--num-processes 2 \
|
||
|
--preserve-downloads \
|
||
|
--reprocess \
|
||
|
--structured-output-dir "$OUTPUT_DIR"
|
||
|
|
||
|
|
||
|
# 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
|