blob: 2e53fb0213862c242ca3e33336f855c4d28adcd1 [file] [log] [blame]
Roger Meier4d5157d2012-01-09 21:23:19 +00001#!/bin/sh
2#
3# Licensed to the Apache Software Foundation (ASF) under one
4# or more contributor license agreements. See the NOTICE file
5# distributed with this work for additional information
6# regarding copyright ownership. The ASF licenses this file
7# to you under the Apache License, Version 2.0 (the
8# "License"); you may not use this file except in compliance
9# with the License. You may obtain a copy of the License at
10#
11# http://www.apache.org/licenses/LICENSE-2.0
12#
13# Unless required by applicable law or agreed to in writing,
14# software distributed under the License is distributed on an
15# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16# KIND, either express or implied. See the License for the
17# specific language governing permissions and limitations
18# under the License.
19#
20
21# Apache Thrift - integration test suite
22#
23# tests different client-server, protocol and transport combinations
24
25# related issues:
26# THRIFT-847 Test Framework harmonization across all languages
27# THRIFT-819 add Enumeration for protocol, transport and server types
28
29
30print_header() {
31 printf "%-16s %-11s %-17s %-s\n" "client-server:" "protocol:" "transport:" "result:"
32}
33
34do_test () {
35 client_server=$1
36 protocol=$2
37 transport=$3
38 client_exec=$4
39 server_exec=$5
40 server_startup_time=$6
41
42 testname=${client_server}_${protocol}_${transport}
43 server_timeout=$((${server_startup_time}+10))
44 printf "%-16s %-11s %-17s" ${client_server} ${protocol} ${transport}
45 timeout $server_timeout $server_exec > log/${testname}_server.log 2>&1 &
46 sleep $server_startup_time
47 $client_exec > log/${testname}_client.log 2>&1
48
49 if [ "$?" -eq "0" ]; then
50 echo " success"
51 else
52 echo " failure"
53 echo "=================== server message ==================="
54 tail log/${testname}_server.log
55 echo "=================== client message ==================="
56 tail log/${testname}_client.log
57 echo "======================================================"
Roger Meier85fb6de2012-11-02 00:05:42 +000058 echo ""
Roger Meier4d5157d2012-01-09 21:23:19 +000059 print_header
60 fi
61 sleep 10
62}
63
64echo "Apache Thrift - integration test suite"
65date
66echo "======================================================"
67
68rm -rf log
69mkdir -p log
70
71print_header
72
73
74protocols="binary json"
75transports="buffered framed http"
76sockets="ip domain"
77# we need a test certificate first
78#sockets="ip ip-ssl domain"
79
Roger Meiereaa61d82012-01-12 21:38:29 +000080
Roger Meier4d5157d2012-01-09 21:23:19 +000081for proto in $protocols; do
82 for trans in $transports; do
83 for sock in $sockets; do
84 case "$sock" in
85 "ip" ) extraparam="";;
86 "ip-ssl" ) extraparam="--ssl";;
87 "domain" ) extraparam="--domain-socket=/tmp/ThriftTest.thrift";;
88 esac
89 do_test "cpp-cpp" "${proto}" "${trans}-${sock}" \
90 "cpp/TestClient --protocol=${proto} --transport=${trans} ${extraparam}" \
91 "cpp/TestServer --protocol=${proto} --transport=${trans} ${extraparam}" \
92 "10"
93 done;
94 done;
95done;
96
Roger Meier691ec002012-11-02 07:50:24 +000097# delete Unix Domain Socket used by cpp tests
98rm -f /tmp/ThriftTest.thrift
99
Roger Meier85fb6de2012-11-02 00:05:42 +0000100do_test "py-py" "binary" "buffered-ip" \
101 "py/TestClient.py --proto=binary --port=9090 --host=localhost --genpydir=py/gen-py" \
102 "py/TestServer.py --proto=binary --port=9090 --genpydir=py/gen-py TSimpleServer" \
103 "10"
104do_test "py-py" "json" "buffered-ip" \
105 "py/TestClient.py --proto=json --port=9090 --host=localhost --genpydir=py/gen-py" \
106 "py/TestServer.py --proto=json --port=9090 --genpydir=py/gen-py TSimpleServer" \
107 "10"
108do_test "py-cpp" "binary" "buffered-ip" \
109 "py/TestClient.py --proto=binary --port=9090 --host=localhost --genpydir=py/gen-py" \
110 "cpp/TestServer" \
111 "10"
112do_test "py-cpp" "json" "buffered-ip" \
113 "py/TestClient.py --proto=json --port=9090 --host=localhost --genpydir=py/gen-py" \
114 "cpp/TestServer --protocol=json" \
115 "10"
116do_test "cpp-py" "binary" "buffered-ip" \
117 "cpp/TestClient --protocol=binary --port=9090" \
118 "py/TestServer.py --proto=binary --port=9090 --genpydir=py/gen-py TSimpleServer" \
119 "10"
120do_test "cpp-py" "json" "buffered-ip" \
121 "cpp/TestClient --protocol=json --port=9090" \
122 "py/TestServer.py --proto=json --port=9090 --genpydir=py/gen-py TSimpleServer" \
123 "10"
124do_test "py-java" "binary" "buffered-ip" \
125 "py/TestClient.py --proto=binary --port=9090 --host=localhost --genpydir=py/gen-py" \
126 "ant -f ../lib/java/build.xml testserver" \
127 "100"
128do_test "py-java" "json" "buffered-ip" \
129 "py/TestClient.py --proto=json --port=9090 --host=localhost --genpydir=py/gen-py" \
130 "ant -f ../lib/java/build.xml testserver" \
131 "100"
132do_test "java-py" "binary" "buffered-ip" \
133 "ant -f ../lib/java/build.xml testclient" \
134 "py/TestServer.py --proto=binary --port=9090 --genpydir=py/gen-py TSimpleServer" \
135 "10"
Roger Meier4d5157d2012-01-09 21:23:19 +0000136do_test "java-java" "binary" "buffered-ip" \
137 "ant -f ../lib/java/build.xml testclient" \
138 "ant -f ../lib/java/build.xml testserver" \
139 "100"
140do_test "cpp-java" "binary" "buffered-ip" \
141 "cpp/TestClient" \
142 "ant -f ../lib/java/build.xml testserver" \
143 "100"
144do_test "cpp-java" "json" "buffered-ip" \
145 "cpp/TestClient" \
146 "ant -f ../lib/java/build.xml testserver" \
147 "100"
148do_test "js-java" "json " "http-ip" \
149 "" \
150 "ant -f ../lib/js/test/build.xml unittest" \
151 "100"
152do_test "java-cpp" "binary" "buffered-ip" \
153 "ant -f ../lib/java/build.xml testclient" \
154 "cpp/TestServer" \
155 "10"
156do_test "perl-cpp" "binary" "buffered-ip" \
Roger Meier01b568c2012-01-10 21:30:02 +0000157 "perl -I perl/gen-perl/ -I../lib/perl/lib/ perl/TestClient.pl" \
Roger Meier4d5157d2012-01-09 21:23:19 +0000158 "cpp/TestServer" \
159 "10"
Roger Meierb33967b2012-01-21 09:18:05 +0000160do_test "php-cpp" "binary" "buffered-ip" \
161 "make -C php/ client" \
162 "cpp/TestServer" \
163 "10"
Roger Meiereaa61d82012-01-12 21:38:29 +0000164do_test "nodejs-nodejs" "binary" "framed-ip" \
165 "make -C nodejs/ client" \
166 "make -C nodejs/ server" \
167 "1"
Henrique Mendoncad407b2d2012-10-22 21:06:14 +0000168do_test "nodejs-cpp" "binary" "framed-ip" \
169 "make -C nodejs/ client" \
170 "cpp/TestServer --transport=framed" \
171 "1"
Roger Meiereaa61d82012-01-12 21:38:29 +0000172do_test "cpp-nodejs" "binary" "framed-ip" \
173 "cpp/TestClient --transport=framed" \
174 "make -C nodejs/ server" \
175 "1"