diff --git a/examples/sexp-conv-test b/examples/sexp-conv-test index 6335dac12bf937c719446bf8d2285b7e86ca1ab6..48ca5acb32216bb604e944d6025fe73cb5f9ae5d 100755 --- a/examples/sexp-conv-test +++ b/examples/sexp-conv-test @@ -4,10 +4,20 @@ if [ -z "$srcdir" ] ; then srcdir=`pwd` fi -test_conv () { - # FIXME: echo -n not portable +# echo -n is not portable + +if [ "`echo -n ''`" = "" ]; then + n='-n'; c='' +elif [ "`echo '\c'`" = "" ]; then + n=''; c='\c' +else + echo >&2 'Neither echo -n nor echo \c seems to work.' + exit 1 +fi + +test_advanced () { echo "$1" > test.in - if ./sexp-conv <test.in >test1.out ; then + if ./sexp-conv -s advanced <test.in >test1.out ; then true else exit 1 @@ -21,18 +31,42 @@ test_conv () { fi } -test_conv "3:foo" "foo" -a -test_conv "4:3des" '"3des"' -a -test_conv '"foo"' "foo" -a -test_conv '4:foo -' '"foo\n"' -test_conv '2:"\' '"\"\\"' -test_conv "()" "()" -test_conv '(foo bar baz)' '(foo bar - baz)' -test_conv '; comment -()' "()" +test_canonical () { + echo "$1" > test.in + if ./sexp-conv -s canonical <test.in >test1.out ; then + true + else + exit 1 + fi + echo $n "$2$c" > test2.out + + if cmp test1.out test2.out ; then + true + else + exit 1; + fi +} + +test_advanced '0:' '""' +test_advanced '3:foo' 'foo' +test_advanced '12:fooooooooooo' 'fooooooooooo' +test_advanced '10:fooooooooo' 'fooooooooo' +test_advanced '4:3des' '"3des"' +test_advanced '"foo"' 'foo' +test_advanced '4:foo +' '"foo\n"' +test_advanced '2:"\' '"\"\\"' +test_advanced '()' '()' +test_advanced '(foo bar baz)' '(foo bar + baz)' +test_advanced '; comment +()' '()' -test_conv "(foo[bar]foo)" "(foo [bar]foo)" -a +test_advanced '(foo[bar]foo)' '(foo [bar]foo)' +test_canonical '""' '0:' +test_canonical 'foo' '3:foo' +test_canonical 'fooooooooooo' '12:fooooooooooo' +test_canonical 'fooooooooo' '10:fooooooooo' +test_canonical '(foo bar baz)' '(3:foo3:bar3:baz)' exit 0