1 |
183
|
aaronmk
|
#!/bin/bash
|
2 |
106
|
aaronmk
|
# Tests map on all input/*.csv
|
3 |
|
|
# Usage: env [n=<num-rows>] self
|
4 |
53
|
aaronmk
|
|
5 |
|
|
selfDir="$(dirname -- "$0")"
|
6 |
|
|
cd "$selfDir"
|
7 |
|
|
|
8 |
183
|
aaronmk
|
shopt -s nullglob
|
9 |
|
|
|
10 |
175
|
aaronmk
|
tests_n=2
|
11 |
181
|
aaronmk
|
testMode=
|
12 |
|
|
test -n "$n" || export n="$tests_n" testMode=1
|
13 |
175
|
aaronmk
|
|
14 |
252
|
aaronmk
|
test "$(hostname)" = nimoy && isNimoy=t || isNimoy=
|
15 |
|
|
test -n "$isNimoy" && . ../util/env_password mysql_password "your MySQL"
|
16 |
|
|
|
17 |
243
|
aaronmk
|
bien_password="$(cat ../util/bien_password)"
|
18 |
131
|
aaronmk
|
|
19 |
161
|
aaronmk
|
make --directory=../../mappings
|
20 |
185
|
aaronmk
|
mkdir -p output
|
21 |
|
|
|
22 |
135
|
aaronmk
|
function trace()
|
23 |
118
|
aaronmk
|
{
|
24 |
135
|
aaronmk
|
(
|
25 |
181
|
aaronmk
|
env echo -n "$PS4" # bug in sh's built-in echo prints the -n
|
26 |
135
|
aaronmk
|
for arg in "$@"; do printf "%q " "$arg"; done
|
27 |
|
|
echo "${_in+<$_in}" "${_out+>$_out}"
|
28 |
|
|
) >&2
|
29 |
118
|
aaronmk
|
}
|
30 |
|
|
|
31 |
161
|
aaronmk
|
function map()
|
32 |
132
|
aaronmk
|
{
|
33 |
169
|
aaronmk
|
test -e "$in" || return 1
|
34 |
|
|
local ext="${in##*.}" # after last "."
|
35 |
|
|
for map in "../../mappings/$src-$out_fmt."$table".csv"; do
|
36 |
|
|
table="${map%.*}" # remove extension
|
37 |
|
|
table="${table##*.}" # after last "."
|
38 |
252
|
aaronmk
|
{
|
39 |
161
|
aaronmk
|
if test "$ext" == "sh"; then
|
40 |
|
|
trace . "$in"
|
41 |
252
|
aaronmk
|
(
|
42 |
|
|
. "$in"
|
43 |
257
|
aaronmk
|
|
44 |
|
|
# defaults
|
45 |
|
|
test -n "$host" || host=localhost
|
46 |
|
|
if test -z "$user"; then
|
47 |
|
|
if test -n "$isNimoy" -a "$engine" = MySQL; then
|
48 |
|
|
user="$USER" password="$mysql_password"
|
49 |
|
|
else
|
50 |
|
|
user=bien password="$bien_password"
|
51 |
|
|
fi
|
52 |
252
|
aaronmk
|
fi
|
53 |
257
|
aaronmk
|
|
54 |
|
|
for var in engine host user password database; do
|
55 |
|
|
export in_$var="${!var}"
|
56 |
|
|
done
|
57 |
252
|
aaronmk
|
"$1"
|
58 |
|
|
)
|
59 |
161
|
aaronmk
|
else
|
60 |
|
|
(_in="$in"; trace)
|
61 |
|
|
"$1" <"$in"
|
62 |
|
|
fi
|
63 |
252
|
aaronmk
|
} || exit # abort tester
|
64 |
169
|
aaronmk
|
done
|
65 |
132
|
aaronmk
|
}
|
66 |
|
|
|
67 |
135
|
aaronmk
|
function toXml()
|
68 |
|
|
{
|
69 |
169
|
aaronmk
|
local stem="$orig_src.$table.$out_fmt"
|
70 |
|
|
local out="output/$stem${method+.$method}.xml"
|
71 |
|
|
local accepted="accepted_output/$stem.xml"
|
72 |
266
|
aaronmk
|
(set -x; ../bien_map "$map" >"$out") || exit # abort tester
|
73 |
181
|
aaronmk
|
(set -x; ${testMode:+diff "$accepted" "$out"})
|
74 |
175
|
aaronmk
|
true # ignore last command's exit status
|
75 |
118
|
aaronmk
|
}
|
76 |
|
|
|
77 |
230
|
aaronmk
|
vegbienDest=../util/vegbien_dest
|
78 |
222
|
aaronmk
|
|
79 |
135
|
aaronmk
|
function toDb()
|
80 |
118
|
aaronmk
|
{
|
81 |
222
|
aaronmk
|
trace . "$vegbienDest"
|
82 |
266
|
aaronmk
|
(. "$vegbienDest"; set -x; ../bien_map "$map") || exit # abort tester
|
83 |
118
|
aaronmk
|
}
|
84 |
|
|
|
85 |
161
|
aaronmk
|
for in in input/*; do
|
86 |
118
|
aaronmk
|
stem="$(basename -- "${in%.*}")" # remove extension and dir
|
87 |
169
|
aaronmk
|
ext="${in##*.}" # after last "."
|
88 |
|
|
src="${stem%.*}" # before last ".", if any
|
89 |
|
|
orig_src="$src"
|
90 |
|
|
if test "$ext" == "sh"; then table="*" # use all tables with a mapping
|
91 |
|
|
else table="${stem##*.}" # after last "."
|
92 |
|
|
fi
|
93 |
106
|
aaronmk
|
|
94 |
222
|
aaronmk
|
for out_fmt in VegX VegBIEN; do map toXml; done # source to XML
|
95 |
|
|
out_fmt=VegBIEN
|
96 |
|
|
# VegX to VegBIEN
|
97 |
169
|
aaronmk
|
(
|
98 |
|
|
src=VegX method=via_$src
|
99 |
|
|
for in in "output/$orig_src."$table".$src.xml"; do
|
100 |
|
|
table="${in#*.}" # after first "."
|
101 |
|
|
table="${table%%.*}" # before second "."
|
102 |
|
|
map toXml
|
103 |
|
|
done
|
104 |
175
|
aaronmk
|
) || exit # subshell error also interrupts main shell
|
105 |
222
|
aaronmk
|
map toDb # source to VegBIEN db
|
106 |
106
|
aaronmk
|
done
|