Mercurial > hg > audiodb
annotate tests/0010/run-test.sh @ 383:6cef34d6fc48 api-inversion
Create a branch for trying to "invert" the command-line program and
library. That is, instead of having the library functions effectively
"call" the command-line client (by faking up an argv[] and abusing the
multiple constructors), have the functionality be contained in the API
function itself, and have the command-line/C++ audioDB client call those
functions.
Eventually, each API function (and perhaps tightly-focused helper
functions) will be in its own file (e.g. audiodb_create() will end up in
create.cpp), and (hopefully) the command-line client will be so trivial
as to be fully contained in a rather shortened audioDB.cpp file.
This inversion should also solve the
double-compilation-with-preprocessor-#defines of audioDB.cpp, and the
position of soap.cpp: the soap calls and their callers will be entirely
specific to the command-line binary, and will have all their hooks into
the API removed.
That's the plan, anyway. Anyone is welcome to play along.
author | mas01cr |
---|---|
date | Fri, 21 Nov 2008 15:05:56 +0000 |
parents | fe4dc39b2dd7 |
children | b09d2eb1a2b2 |
rev | line source |
---|---|
mas01cr@252 | 1 #! /bin/bash |
mas01cr@69 | 2 |
mas01cr@69 | 3 . ../test-utils.sh |
mas01cr@69 | 4 |
mas01cr@69 | 5 if [ -f testdb ]; then rm -f testdb; fi |
mas01cr@69 | 6 |
mas01cr@69 | 7 ${AUDIODB} -d testdb -N |
mas01cr@69 | 8 |
mas01cr@69 | 9 intstring 2 > testfeature01 |
mas01cr@69 | 10 floatstring 0 1 >> testfeature01 |
mas01cr@69 | 11 intstring 2 > testfeature10 |
mas01cr@69 | 12 floatstring 1 0 >> testfeature10 |
mas01cr@69 | 13 |
mas01cr@69 | 14 ${AUDIODB} -d testdb -I -f testfeature01 |
mas01cr@69 | 15 ${AUDIODB} -d testdb -I -f testfeature10 |
mas01cr@69 | 16 |
mas01cr@69 | 17 # sequence queries require L2NORM |
mas01cr@69 | 18 ${AUDIODB} -d testdb -L |
mas01cr@69 | 19 |
mas01cr@69 | 20 echo "query point (0.0,0.5)" |
mas01cr@69 | 21 intstring 2 > testquery |
mas01cr@69 | 22 floatstring 0 0.5 >> testquery |
mas01cr@69 | 23 |
mas01cr@69 | 24 ${AUDIODB} -d testdb -Q sequence -l 1 -f testquery -R 5 > testoutput |
mas01cr@69 | 25 echo testfeature01 1 > test-expected-output |
mas01cr@69 | 26 echo testfeature10 1 >> test-expected-output |
mas01cr@69 | 27 cmp testoutput test-expected-output |
mas01cr@69 | 28 ${AUDIODB} -d testdb -Q sequence -l 1 -f testquery -r 1 -R 5 > testoutput |
mas01cr@69 | 29 echo testfeature01 1 > test-expected-output |
mas01cr@69 | 30 cmp testoutput test-expected-output |
mas01cr@69 | 31 |
mas01cr@69 | 32 echo "query point (0.5,0.0)" |
mas01cr@69 | 33 intstring 2 > testquery |
mas01cr@69 | 34 floatstring 0.5 0 >> testquery |
mas01cr@69 | 35 |
mas01cr@69 | 36 # FIXME: because there's only one point in each track (and the query), |
mas01cr@69 | 37 # the ordering is essentially database order. We need these test |
mas01cr@69 | 38 # cases anyway because we need to test non-segfaulting, non-empty |
mas01cr@69 | 39 # results... |
mas01cr@69 | 40 |
mas01cr@69 | 41 ${AUDIODB} -d testdb -Q sequence -l 1 -f testquery -R 5 > testoutput |
mas01cr@69 | 42 echo testfeature01 1 > test-expected-output |
mas01cr@69 | 43 echo testfeature10 1 >> test-expected-output |
mas01cr@69 | 44 cmp testoutput test-expected-output |
mas01cr@69 | 45 ${AUDIODB} -d testdb -Q sequence -l 1 -f testquery -r 1 -R 5 > testoutput |
mas01cr@69 | 46 echo testfeature01 1 > test-expected-output |
mas01cr@69 | 47 cmp testoutput test-expected-output |
mas01cr@69 | 48 |
mas01cr@69 | 49 exit 104 |