Skip to content

Commit 3170670

Browse files
authored
Merge pull request #8041 from jketema/prepare-db-upgrade-script
Add version of `prepare-db-upgrade.sh` supporting multiple languages
2 parents ebb87c4 + 671528b commit 3170670

File tree

1 file changed

+160
-0
lines changed

1 file changed

+160
-0
lines changed

misc/scripts/prepare-db-upgrade.sh

Lines changed: 160 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,160 @@
1+
#!/bin/sh
2+
#
3+
# Prepare the upgrade and downgrade script directories for a DB Schema upgrade.
4+
5+
set -e
6+
set -u
7+
8+
app_name="$(basename "$0")"
9+
app_dir="$(dirname "$0")"
10+
11+
usage()
12+
{
13+
exit_code="$1"
14+
shift
15+
16+
cat >&2 <<EOF
17+
${app_name}: $@
18+
${app_name}: Generate skeleton upgrade script.
19+
Usage: ${app_name} --lang <LANG> [--prev_hash <COMMITISH>]"
20+
21+
--lang <LANG>
22+
Language to update the schema for.
23+
24+
--prev-hash <COMMITISH>
25+
Hash/branch to use to get SHA1 for previous DB scheme.
26+
Default: origin/main
27+
28+
Must be run within the git repo needing an update.
29+
EOF
30+
exit "${exit_code}"
31+
}
32+
33+
prev_hash="origin/main"
34+
35+
while [ $# -gt 0 ]; do
36+
case "$1" in
37+
-x)
38+
set -x
39+
;;
40+
-h | --help)
41+
usage 0
42+
;;
43+
--prev-hash)
44+
if [ $# -eq 1 ]; then
45+
usage 2 "--prev-hash requires Commit/Branch option"
46+
fi
47+
shift
48+
prev_hash="$1"
49+
;;
50+
--lang)
51+
if [ $# -eq 1 ]; then
52+
usage 2 "--lang requires a language option"
53+
fi
54+
shift
55+
lang="$1"
56+
;;
57+
--)
58+
shift
59+
break
60+
;;
61+
-*)
62+
usage 2 "Unrecognised option: $1"
63+
;;
64+
*)
65+
break
66+
;;
67+
esac
68+
shift
69+
done
70+
71+
if [ $# -gt 0 ]; then
72+
usage 2 "Unrecognised operand: $1"
73+
fi
74+
75+
if [ -z ${lang+x} ]; then
76+
usage 2 "No language specified"
77+
fi
78+
79+
case "${lang}" in
80+
java)
81+
scheme_file="${lang}/ql/lib/config/semmlecode.dbscheme"
82+
;;
83+
csharp | cpp | javascript | python)
84+
scheme_file="${lang}/ql/lib/semmlecode.${lang}.dbscheme"
85+
;;
86+
ruby)
87+
scheme_file="${lang}/ql/lib/${lang}.dbscheme"
88+
;;
89+
*)
90+
usage 2 "Unrecognised language: ${lang}"
91+
;;
92+
esac
93+
94+
cd ${app_dir}
95+
qldir="$(git rev-parse --show-toplevel)"
96+
97+
if [ "x${qldir}" = "x" ]; then
98+
usage 2 "Script not in a code repository."
99+
fi
100+
101+
upgrade_root="${qldir}/${lang}/ql/lib/upgrades"
102+
downgrade_root="${qldir}/${lang}/downgrades"
103+
104+
check_hash_valid()
105+
{
106+
if [ ${#2} -ne 40 ]; then
107+
echo "Did not get expected $1 hash: $2" >&2
108+
exit 2
109+
fi
110+
}
111+
112+
# Get the hash of the previous and current DB Schema files
113+
cd "${qldir}"
114+
prev_hash="$(git show "${prev_hash}:${scheme_file}" | git hash-object --stdin)"
115+
check_hash_valid previous "${prev_hash}"
116+
current_hash="$(git hash-object "${scheme_file}")"
117+
check_hash_valid current "${current_hash}"
118+
if [ "${current_hash}" = "${prev_hash}" ]; then
119+
echo "No work to be done."
120+
exit
121+
fi
122+
123+
create_upgrade_properties()
124+
{
125+
cat <<EOF > "$1/upgrade.properties"
126+
description: <INSERT DESCRIPTION HERE>
127+
compatibility: full|backwards|partial|breaking
128+
EOF
129+
}
130+
131+
# Copy current and new dbscheme into the upgrade dir
132+
upgradedir="${upgrade_root}/${prev_hash}"
133+
mkdir -p "${upgradedir}"
134+
135+
cp "${scheme_file}" "${upgradedir}"
136+
git cat-file blob "${prev_hash}" > "${upgradedir}/old.dbscheme"
137+
138+
create_upgrade_properties "${upgradedir}"
139+
140+
# Copy current and new dbscheme into the downgrade dir
141+
downgradedir="${downgrade_root}/${current_hash}"
142+
mkdir -p "${downgradedir}"
143+
144+
cp "${scheme_file}" "${downgradedir}/old.dbscheme"
145+
git cat-file blob "${prev_hash}" > "${downgradedir}/$(basename "${scheme_file}")"
146+
147+
create_upgrade_properties "${downgradedir}"
148+
149+
# Tell user what we've done
150+
cat <<EOF
151+
Created upgrade directory here:
152+
${upgradedir}
153+
Created downgrade directory here:
154+
${downgradedir}
155+
156+
Please update:
157+
${upgradedir}/upgrade.properties
158+
${downgradedir}/upgrade.properties
159+
with appropriate instructions
160+
EOF

0 commit comments

Comments
 (0)