-
Notifications
You must be signed in to change notification settings - Fork 44
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #299 from ibrarahmad/master
Issue (#298) - System is not generating proper SQL file, compatible w…
- Loading branch information
Showing
1 changed file
with
91 additions
and
14 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,32 +1,109 @@ | ||
#!/bin/bash | ||
# Created by Ramesh Sivaraman, Percona LLC | ||
# Special thansks to unix.com | ||
# https://www.unix.com/shell-programming-and-scripting/80633-sed-combining-multiple-lines-into-one.html | ||
|
||
echoit(){ | ||
echo "[$(date +'%T')] $1" | ||
echo "[$(date +'%T')] $1" | ||
} | ||
|
||
# User configurable variables | ||
BASEDIR="/home/vagrant/postgresql-10.3" # Postgress source directory (should contain src directory as a first level subdirectory, see TESTS_PATH) | ||
|
||
FINAL_SQL=/tmp/ptr_to_sql.sql # pquery final SQL grammar (i.e. file name for output generated by this script) | ||
# Postgress source directory | ||
# should contain src directory as a first level subdirectory, see TESTS_PATH. | ||
BASEDIR="/home/vagrant/postgresql" | ||
|
||
# PostgreSQL lib directlry, conatains the PostgreSQL modules and libraries so's | ||
PG_LIBDIR="$(pg_config --libdir)" | ||
|
||
# pquery final SQL grammar (i.e. file name for output generated by this script) | ||
FINAL_SQL=/tmp/ptr_to_sql.sql | ||
|
||
|
||
TESTS_PATH=$(echo ${BASEDIR} | sed 's|$|/src|;s|//||g') | ||
|
||
if [[ $(ls $TESTS_PATH/test/regress/sql/*.sql 2>/dev/null | wc -l ) -eq 0 ]]; then | ||
echoit "Assert: this script cannot locate sql files in ${TESTS_PATH}/test/regress/sql" | ||
exit 1 | ||
echoit "Assert: this script cannot locate sql files in ${TESTS_PATH}/test/regress/sql" | ||
exit 1 | ||
fi | ||
|
||
echoit "> Generating SQL" | ||
|
||
# with thanks https://www.unix.com/shell-programming-and-scripting/80633-sed-combining-multiple-lines-into-one.html | ||
cat $TESTS_PATH/test/*/*.sql $TESTS_PATH/test/*/*/*.sql $TESTS_PATH/test/*/*/*/*.sql | \ | ||
sed '/^[ \t]*$/d' | \ | ||
sed '/^--.*/d' | \ | ||
sed 's|;.*.\-\-.*|;|' | \ | ||
sed '/^\\d/d' | \ | ||
sed -e :x -e '/;$/b' -e N -e 's/\n//' -e bx | \ | ||
sed 's|/\*.*.\*/||' | \ | ||
sed 's|\\echo.*.\\quit||' > $FINAL_SQL | ||
rm -f "$FINAL_SQL" | ||
|
||
generate_sql() | ||
{ | ||
f=$1 | ||
input_encoding=" " | ||
|
||
# Need to convert the multibye file to UTF-8 encoding, before concatinating to main SQL file. | ||
if [[ $(echo $f | grep -c "/mb/") -gt 0 ]]; | ||
then | ||
input_encoding="-f " | ||
if [[ $(echo $f | grep -c "mule_internal.sql$") -gt 0 ]]; | ||
then | ||
input_encoding+="CSPC858MULTILINGUAL" | ||
elif [[ $(echo $f | grep -c "sjis.sql$") -gt 0 ]]; | ||
then | ||
input_encoding+="SJIS-OPEN" | ||
else | ||
# Pickup encoding from the filename | ||
input_encoding+="$(echo $f | sed "s:.*/::g" | sed "s:\.sql::g" | sed "s:\(-\|\_\)::g" | awk '{print toupper($0)}')" | ||
fi | ||
fi | ||
|
||
# We cannot execute module files directly, CREATE EXTENSION | ||
# command execute all the sql files in sequence. | ||
if [[ $(echo $f | grep -c "/modules/") -gt 0 ]]; | ||
then | ||
echo "-- $f" >> $FINAL_SQL | ||
echo "create extension if not exists $(dirname $f | sed 's:.*/modules/::g' | cut -f1 -d"/");" >> $FINAL_SQL | ||
|
||
# Currently we don't support COPY command syntax, which involve external file. | ||
elif [[ $(echo $f | grep -c ".*/copy.*.sql$") -gt 0 ]]; | ||
then | ||
echo "-- Ignoring file $f" >> $FINAL_SQL | ||
|
||
# The xml.sql file contain lot of comments and special characters and difficult to parse. | ||
elif [[ $(echo $f | grep -c "xml.sql$") -gt 0 ]]; | ||
then | ||
echo "-- Ignoring file $f" >> $FINAL_SQL | ||
else | ||
echo "-- $f" >> $FINAL_SQL | ||
iconv $input_encoding -t UTF-8 $f | \ | ||
sed "s|-->|==>|g" | \ | ||
sed "s|HH24--text--MI--text--SS|HH24textMItextSS|g" | \ | ||
sed '/^[ \t]*$/d' | \ | ||
sed '/^ *--.*/d' | \ | ||
sed "s: *--.*$::g" | \ | ||
sed 's|;.*.\-\-.*|;|' | \ | ||
sed '/^\\d/d' | \ | ||
sed -e :x -e '/;$/b' -e N -e 's/\n/ /' -e bx | \ | ||
sed "s|==>|-->|g" | \ | ||
sed "s|HH24textMItextSS|HH24--text--MI--text--SS|g" | \ | ||
sed 's|\\echo.*.\\quit||' | \ | ||
sed "s|\\gset|\\gset\n|g" | \ | ||
sed "s|set QUIET true|set QUIET true\n|g" | \ | ||
sed "s|set QUIET false|set QUIET false\n|g" | \ | ||
sed "s|set VERBOSITY terse|set VERBOSITY terse\n|g" | \ | ||
awk '{ if ( $0 ~ /\\\./ ) { gsub(/\\./, "\\.\n"); print; } else print;}' | \ | ||
awk '{ if ( $0 ~ /\\\./ ) { gsub(" ", "\n"); print; } else print;}' | \ | ||
sed 's|^//|-- |g' >> $FINAL_SQL | ||
fi | ||
} | ||
|
||
# Traverse whole PostgreSQL's test directory, except the regress. | ||
for f in $(find $TESTS_PATH/test/*/*.sql $TESTS_PATH/test/*/*/*.sql $TESTS_PATH/test/*/*/*/*.sql| grep -v regress) | ||
do | ||
generate_sql $f | ||
done | ||
|
||
# Read serial_scheduale file for the file listing for sequence execution. | ||
while read p; do | ||
cmd="$(echo "$p" | awk '{print $2}')" | ||
f="$TESTS_PATH/test/regress/sql/$cmd.sql" | ||
generate_sql $f | ||
done <$TESTS_PATH/test/regress/serial_schedule | ||
|
||
echoit "Done! Generated ${FINAL_SQL}" | ||
|