view tests/0023/run-test.sh @ 596:6ad0a6e67d4c

Take advantage of those new handy _or_goto_error macros Use them in various places where previously we either elided the error checking (various lseek() calls) or used a combination of calls (replaced by malloc_and_fill_or_goto_error()). In the process, fix what is probably a bug (or else introduce one, but I don't think so): audiodb_track_id_datum() computed the offset into the timesTable wrongly, forgetting to multiply by 2. (TODO: this should be easily testable using the API). Now all of LIBOBJS can be produced by my (Debian's) mingw32 cross-compiler, except for lshlib.o.
author mas01cr
date Tue, 11 Aug 2009 21:42:49 +0000
parents fe4dc39b2dd7
children
line wrap: on
line source
#! /bin/bash

. ../test-utils.sh

if [ -f testdb ]; then rm -f testdb; fi

${AUDIODB} -d testdb -N

intstring 2 > testfeature01
floatstring 0 1 >> testfeature01
intstring 2 > testfeature10
floatstring 1 0 >> testfeature10

cat > testfeaturefiles <<EOF
testfeature01
testfeature10
EOF

${AUDIODB} -d testdb -B -F testfeaturefiles

# sequence queries require L2NORM
${AUDIODB} -d testdb -L

echo "query point (0.0,0.5)"
intstring 2 > testquery
floatstring 0 0.5 >> testquery
floatstring 0.5 0 >> testquery

${AUDIODB} -d testdb -Q sequence -l 1 -f testquery -p 0 > testoutput
echo testfeature01 0 0 0 > test-expected-output
echo testfeature10 2 0 0 >> test-expected-output
cmp testoutput test-expected-output
${AUDIODB} -d testdb -Q sequence -l 1 -f testquery -r 1 -p 0 > testoutput
echo testfeature01 0 0 0 > test-expected-output
cmp testoutput test-expected-output

echo "query point (0.5,0.0)"

${AUDIODB} -d testdb -Q sequence -l 1 -f testquery -p 1 > testoutput
echo testfeature10 0 1 0 > test-expected-output
echo testfeature01 2 1 0 >> test-expected-output
cmp testoutput test-expected-output
${AUDIODB} -d testdb -Q sequence -l 1 -f testquery -r 1 -p 1 > testoutput
echo testfeature10 0 1 0 > test-expected-output
cmp testoutput test-expected-output

exit 104