Project

General

Profile

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