diff options
author | Russell Bryant <russell@ovn.org> | 2015-12-18 10:52:31 -0500 |
---|---|---|
committer | Russell Bryant <russell@ovn.org> | 2016-02-22 15:17:45 -0500 |
commit | 58bed3df484b777dd7362053eee00c79504be2e0 (patch) | |
tree | acfb4cec0dbe27853a5f033d412e3de468f5c424 | |
parent | d5da6c53ca75df14d698c5355afb492057e2b814 (diff) | |
download | openvswitch-58bed3df484b777dd7362053eee00c79504be2e0.tar.gz |
jsonrpc-py.at: Run tests with Python 2 and 3.
Convert these Python tests to run with both Python 2 and 3.
Signed-off-by: Russell Bryant <russell@ovn.org>
Acked-by: Ben Pfaff <blp@ovn.org>
-rw-r--r-- | tests/jsonrpc-py.at | 79 |
1 files changed, 47 insertions, 32 deletions
diff --git a/tests/jsonrpc-py.at b/tests/jsonrpc-py.at index 3d3bd3b10..966741d0e 100644 --- a/tests/jsonrpc-py.at +++ b/tests/jsonrpc-py.at @@ -1,39 +1,51 @@ AT_BANNER([JSON-RPC - Python]) -AT_SETUP([JSON-RPC request and successful reply - Python]) -AT_SKIP_IF([test $HAVE_PYTHON = no]) -AT_CHECK([$PYTHON $srcdir/test-jsonrpc.py --detach --pidfile=`pwd`/pid listen punix:socket]) -AT_CHECK([test -s pid]) -AT_CHECK([kill -0 `cat pid`]) -AT_CHECK( - [[$PYTHON $srcdir/test-jsonrpc.py request unix:socket echo '[{"a": "b", "x": null}]']], [0], - [[{"error":null,"id":0,"result":[{"a":"b","x":null}]} +m4_define([JSONRPC_REQ_REPLY_SUCCESS_PYN], + [AT_SETUP([JSON-RPC request and successful reply - $1]) + AT_SKIP_IF([test $2 = no]) + AT_KEYWORDS([python jsonrpc]) + AT_CHECK([$PYTHON $srcdir/test-jsonrpc.py --detach --pidfile=`pwd`/pid listen punix:socket]) + AT_CHECK([test -s pid]) + AT_CHECK([kill -0 `cat pid`]) + AT_CHECK( + [[$3 $srcdir/test-jsonrpc.py request unix:socket echo '[{"a": "b", "x": null}]']], [0], + [[{"error":null,"id":0,"result":[{"a":"b","x":null}]} ]], [], [test ! -e pid || kill `cat pid`]) -AT_CHECK([kill `cat pid`]) -AT_CLEANUP + AT_CHECK([kill `cat pid`]) + AT_CLEANUP]) -AT_SETUP([JSON-RPC request and error reply - Python]) -AT_SKIP_IF([test $HAVE_PYTHON = no]) -AT_CHECK([$PYTHON $srcdir/test-jsonrpc.py --detach --pidfile=`pwd`/pid listen punix:socket]) -AT_CHECK([test -s pid]) -AT_CHECK([kill -0 `cat pid`]) -AT_CHECK( - [[$PYTHON $srcdir/test-jsonrpc.py request unix:socket bad-request '[]']], [0], - [[{"error":{"error":"unknown method"},"id":0,"result":null} +JSONRPC_REQ_REPLY_SUCCESS_PYN([Python2], [$HAVE_PYTHON], [$PYTHON]) +JSONRPC_REQ_REPLY_SUCCESS_PYN([Python3], [$HAVE_PYTHON3], [$PYTHON3]) + +m4_define([JSONRPC_REQ_REPLY_ERROR_PYN], + [AT_SETUP([JSON-RPC request and error reply - $1]) + AT_SKIP_IF([test $2 = no]) + AT_KEYWORDS([python jsonrpc]) + AT_CHECK([$PYTHON $srcdir/test-jsonrpc.py --detach --pidfile=`pwd`/pid listen punix:socket]) + AT_CHECK([test -s pid]) + AT_CHECK([kill -0 `cat pid`]) + AT_CHECK( + [[$3 $srcdir/test-jsonrpc.py request unix:socket bad-request '[]']], [0], + [[{"error":{"error":"unknown method"},"id":0,"result":null} ]], [], [test ! -e pid || kill `cat pid`]) -AT_CHECK([kill `cat pid`]) -AT_CLEANUP + AT_CHECK([kill `cat pid`]) + AT_CLEANUP]) + +JSONRPC_REQ_REPLY_ERROR_PYN([Python2], [$HAVE_PYTHON], [$PYTHON]) +JSONRPC_REQ_REPLY_ERROR_PYN([Python3], [$HAVE_PYTHON3], [$PYTHON3]) -AT_SETUP([JSON-RPC notification - Python]) -AT_SKIP_IF([test $HAVE_PYTHON = no]) -AT_CHECK([$PYTHON $srcdir/test-jsonrpc.py --detach --pidfile=`pwd`/pid listen punix:socket]) -AT_CHECK([test -s pid]) -# When a daemon dies it deletes its pidfile, so make a copy. -AT_CHECK([cp pid pid2]) -AT_CHECK([kill -0 `cat pid2`]) -AT_CHECK([[$PYTHON $srcdir/test-jsonrpc.py notify unix:socket shutdown '[]']], [0], [], - [], [kill `cat pid2`]) -AT_CHECK( +m4_define([JSONRPC_NOTIFICATION_PYN], + [AT_SETUP([JSON-RPC notification - $1]) + AT_SKIP_IF([test $2 = no]) + AT_KEYWORDS([python jsonrpc]) + AT_CHECK([$3 $srcdir/test-jsonrpc.py --detach --pidfile=`pwd`/pid listen punix:socket]) + AT_CHECK([test -s pid]) + # When a daemon dies it deletes its pidfile, so make a copy. + AT_CHECK([cp pid pid2]) + AT_CHECK([kill -0 `cat pid2`]) + AT_CHECK([[$3 $srcdir/test-jsonrpc.py notify unix:socket shutdown '[]']], [0], [], + [], [kill `cat pid2`]) + AT_CHECK( [pid=`cat pid2` # First try a quick sleep, so that the test completes very quickly # in the normal case. POSIX doesn't require fractional times to @@ -44,5 +56,8 @@ AT_CHECK( sleep 1; if kill -0 $pid; then :; else echo success; exit 0; fi echo failure; exit 1], [0], [success ], [ignore]) -AT_CHECK([test ! -e pid]) -AT_CLEANUP + AT_CHECK([test ! -e pid]) + AT_CLEANUP]) + +JSONRPC_NOTIFICATION_PYN([Python2], [$HAVE_PYTHON], [$PYTHON]) +JSONRPC_NOTIFICATION_PYN([Python3], [$HAVE_PYTHON3], [$PYTHON3]) |