From 5e63d46f3ac6e54394bb8ceba8ab2743786e1723 Mon Sep 17 00:00:00 2001 From: Jeremy McCormick Date: Thu, 8 Aug 2024 15:33:37 -0500 Subject: [PATCH] Add script for test loading SQL in MySQL --- scripts/test-load-sql-mysql.sh | 43 ++++++++++++++++++++++++++++++++++ 1 file changed, 43 insertions(+) create mode 100755 scripts/test-load-sql-mysql.sh diff --git a/scripts/test-load-sql-mysql.sh b/scripts/test-load-sql-mysql.sh new file mode 100755 index 00000000..fc1a6fd2 --- /dev/null +++ b/scripts/test-load-sql-mysql.sh @@ -0,0 +1,43 @@ +#!/bin/bash + +if [[ -z "$1" ]]; +then + sql_dir="sql" +else + sql_dir=$1 +fi + +if [[ ! -d "$sql_dir" ]]; +then + echo "Error: SQL directory $sql_dir does not exist. Please run scripts/generate-sql-files.sh first." + exit 1 +fi + +# Initialize a variable to track if any command fails +error_occurred=0 + +for yaml_file in yml/*.yaml; do + echo "Loading SQL for ${yaml_file}..." + sql_file="$sql_dir/$(basename "$yaml_file" .yaml).sql" + if [[ ! -f "$sql_file" ]]; then + echo "SQL file $sql_file does not exist. Skipping." + continue + fi + db_name=$(yq e '.name' "$yaml_file") + mysql -e "DROP DATABASE IF EXISTS ${db_name};" + mysql -e "CREATE DATABASE ${db_name};" + mysql -q < "$sql_file" + # Check if the mysql command was successful + if [ $? -ne 0 ]; then + echo "Error: Failed to load SQL from $sql_file" + error_occurred=1 + else + echo "Done loading SQL from $sql_file" + fi +done + +# Exit with non-zero status if any command failed +if [ $error_occurred -ne 0 ]; then + echo "Error: Failed to load all SQL files into MySQL" + exit 1 +fi