blob: c916cee7102c23be5042595ecf3392d272d1decf [file] [log] [blame]
David Reiss2c8d2282010-08-30 22:05:39 +00001%%
2%% Licensed to the Apache Software Foundation (ASF) under one
3%% or more contributor license agreements. See the NOTICE file
4%% distributed with this work for additional information
5%% regarding copyright ownership. The ASF licenses this file
6%% to you under the Apache License, Version 2.0 (the
7%% "License"); you may not use this file except in compliance
8%% with the License. You may obtain a copy of the License at
9%%
10%% http://www.apache.org/licenses/LICENSE-2.0
11%%
12%% Unless required by applicable law or agreed to in writing,
13%% software distributed under the License is distributed on an
14%% "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
15%% KIND, either express or implied. See the License for the
16%% specific language governing permissions and limitations
17%% under the License.
18%%
19
20-module(test_client).
21
22-export([start/0, start/1]).
23
Jens Geyer6d15c302014-10-02 10:03:09 +020024-include("gen-erl/thrift_test_types.hrl").
David Reiss2c8d2282010-08-30 22:05:39 +000025
David Reissa508b332010-08-30 22:05:41 +000026-record(options, {port = 9090,
27 client_opts = []}).
28
29parse_args(Args) -> parse_args(Args, #options{}).
Nobuaki Sukegawa826ea992015-10-28 22:19:45 +090030parse_args([], Opts) ->
31 Opts;
David Reissa508b332010-08-30 22:05:41 +000032parse_args([Head | Rest], Opts) ->
33 NewOpts =
Nobuaki Sukegawa826ea992015-10-28 22:19:45 +090034 case Head of
35 "--port=" ++ Port ->
36 case string:to_integer(Port) of
37 {IntPort,_} when is_integer(IntPort) ->
38 Opts#options{port = IntPort};
39 _Else ->
40 erlang:error({bad_arg, Head})
41 end;
42 "--transport=" ++ Trans ->
43 % TODO: Enable Buffered and HTTP transport
44 case Trans of
David Reissa508b332010-08-30 22:05:41 +000045 "framed" ->
46 Opts#options{client_opts = [{framed, true} | Opts#options.client_opts]};
David Reissa508b332010-08-30 22:05:41 +000047 _Else ->
Nobuaki Sukegawa826ea992015-10-28 22:19:45 +090048 Opts
49 end;
David Robakowskia7d6a972013-08-07 05:51:00 +020050 "--ssl" ->
51 ssl:start(),
52 SslOptions =
53 {ssloptions, [
James E. King, III377719c2017-02-15 14:33:20 -050054 {cacertfile, "../keys/CA.pem"},
55 {certfile, "../keys/client.pem"},
56 {keyfile, "../keys/client.key"}
David Robakowskia7d6a972013-08-07 05:51:00 +020057 ]},
58 Opts#options{client_opts = [{ssltransport, true} | [SslOptions | Opts#options.client_opts]]};
Nobuaki Sukegawab31f0902015-11-01 17:00:34 +090059 "--protocol=" ++ Proto ->
60 Opts#options{client_opts = [{protocol, list_to_atom(Proto)}]};
Nobuaki Sukegawa826ea992015-10-28 22:19:45 +090061 _Else ->
62 erlang:error({bad_arg, Head})
David Reissa508b332010-08-30 22:05:41 +000063 end,
64 parse_args(Rest, NewOpts).
65
Nobuaki Sukegawa826ea992015-10-28 22:19:45 +090066start() -> start(init:get_plain_arguments()).
David Reissa508b332010-08-30 22:05:41 +000067start(Args) ->
68 #options{port = Port, client_opts = ClientOpts} = parse_args(Args),
David Reiss2c8d2282010-08-30 22:05:39 +000069 {ok, Client0} = thrift_client_util:new(
Jens Geyer6d15c302014-10-02 10:03:09 +020070 "127.0.0.1", Port, thrift_test_thrift, ClientOpts),
David Reiss2c8d2282010-08-30 22:05:39 +000071
Steve Cohen7ea4a872016-06-14 00:32:48 +020072 DemoXtruct = #'thrift.test.Xtruct'{
73 string_thing = <<"Zero">>,
74 byte_thing = 1,
75 i32_thing = 9128361,
76 i64_thing = 9223372036854775807},
David Reiss2c8d2282010-08-30 22:05:39 +000077
Steve Cohen7ea4a872016-06-14 00:32:48 +020078 DemoNest = #'thrift.test.Xtruct2'{
David Reiss2c8d2282010-08-30 22:05:39 +000079 byte_thing = 7,
80 struct_thing = DemoXtruct,
81 % Note that we don't set i32_thing, it will come back as undefined
82 % from the Python server, but 0 from the C++ server, since it is not
83 % optional
84 i32_thing = 2},
85
86 % Is it safe to match these things?
87 DemoDict = dict:from_list([ {Key, Key-10} || Key <- lists:seq(0,10) ]),
88 DemoSet = sets:from_list([ Key || Key <- lists:seq(-3,3) ]),
89
Steve Cohen7ea4a872016-06-14 00:32:48 +020090 DemoInsane = #'thrift.test.Insanity'{
Nobuaki Sukegawa826ea992015-10-28 22:19:45 +090091 userMap = dict:from_list([{?THRIFT_TEST_NUMBERZ_FIVE, 5000}]),
Steve Cohen7ea4a872016-06-14 00:32:48 +020092 xtructs = [#'thrift.test.Xtruct'{ string_thing = <<"Truck">>, byte_thing = 8, i32_thing = 8, i64_thing = 8}]},
David Reiss2c8d2282010-08-30 22:05:39 +000093
Nobuaki Sukegawab31f0902015-11-01 17:00:34 +090094 error_logger:info_msg("testVoid"),
David Reiss2c8d2282010-08-30 22:05:39 +000095 {Client01, {ok, ok}} = thrift_client:call(Client0, testVoid, []),
96
Nobuaki Sukegawab31f0902015-11-01 17:00:34 +090097 error_logger:info_msg("testString"),
David Reiss2c8d2282010-08-30 22:05:39 +000098 {Client02, {ok, <<"Test">>}} = thrift_client:call(Client01, testString, ["Test"]),
Nobuaki Sukegawab31f0902015-11-01 17:00:34 +090099 error_logger:info_msg("testString"),
David Reiss2c8d2282010-08-30 22:05:39 +0000100 {Client03, {ok, <<"Test">>}} = thrift_client:call(Client02, testString, [<<"Test">>]),
Nobuaki Sukegawab31f0902015-11-01 17:00:34 +0900101 error_logger:info_msg("testByte"),
David Reiss2c8d2282010-08-30 22:05:39 +0000102 {Client04, {ok, 63}} = thrift_client:call(Client03, testByte, [63]),
Nobuaki Sukegawab31f0902015-11-01 17:00:34 +0900103 error_logger:info_msg("testI32"),
David Reiss2c8d2282010-08-30 22:05:39 +0000104 {Client05, {ok, -1}} = thrift_client:call(Client04, testI32, [-1]),
Nobuaki Sukegawab31f0902015-11-01 17:00:34 +0900105 error_logger:info_msg("testI32"),
David Reiss2c8d2282010-08-30 22:05:39 +0000106 {Client06, {ok, 0}} = thrift_client:call(Client05, testI32, [0]),
Nobuaki Sukegawab31f0902015-11-01 17:00:34 +0900107 error_logger:info_msg("testI64"),
David Reiss2c8d2282010-08-30 22:05:39 +0000108 {Client07, {ok, -34359738368}} = thrift_client:call(Client06, testI64, [-34359738368]),
Nobuaki Sukegawab31f0902015-11-01 17:00:34 +0900109 error_logger:info_msg("testDouble"),
David Reiss2c8d2282010-08-30 22:05:39 +0000110 {Client08, {ok, -5.2098523}} = thrift_client:call(Client07, testDouble, [-5.2098523]),
Jens Geyer8bcfdd92014-12-14 03:14:26 +0100111 %% TODO: add testBinary() call
Nobuaki Sukegawab31f0902015-11-01 17:00:34 +0900112 error_logger:info_msg("testStruct"),
David Reiss2c8d2282010-08-30 22:05:39 +0000113 {Client09, {ok, DemoXtruct}} = thrift_client:call(Client08, testStruct, [DemoXtruct]),
Nobuaki Sukegawab31f0902015-11-01 17:00:34 +0900114 error_logger:info_msg("testNest"),
David Reiss2c8d2282010-08-30 22:05:39 +0000115 {Client10, {ok, DemoNest}} = thrift_client:call(Client09, testNest, [DemoNest]),
Nobuaki Sukegawab31f0902015-11-01 17:00:34 +0900116 error_logger:info_msg("testMap"),
David Reiss2c8d2282010-08-30 22:05:39 +0000117 {Client11, {ok, DemoDict}} = thrift_client:call(Client10, testMap, [DemoDict]),
Nobuaki Sukegawab31f0902015-11-01 17:00:34 +0900118 error_logger:info_msg("testSet"),
David Reiss2c8d2282010-08-30 22:05:39 +0000119 {Client12, {ok, DemoSet}} = thrift_client:call(Client11, testSet, [DemoSet]),
Nobuaki Sukegawab31f0902015-11-01 17:00:34 +0900120 error_logger:info_msg("testList"),
David Reiss2c8d2282010-08-30 22:05:39 +0000121 {Client13, {ok, [-1,2,3]}} = thrift_client:call(Client12, testList, [[-1,2,3]]),
Nobuaki Sukegawab31f0902015-11-01 17:00:34 +0900122 error_logger:info_msg("testEnum"),
Jens Geyer6d15c302014-10-02 10:03:09 +0200123 {Client14, {ok, 1}} = thrift_client:call(Client13, testEnum, [?THRIFT_TEST_NUMBERZ_ONE]),
Nobuaki Sukegawab31f0902015-11-01 17:00:34 +0900124 error_logger:info_msg("testTypedef"),
David Reiss2c8d2282010-08-30 22:05:39 +0000125 {Client15, {ok, 309858235082523}} = thrift_client:call(Client14, testTypedef, [309858235082523]),
Nobuaki Sukegawab31f0902015-11-01 17:00:34 +0900126 error_logger:info_msg("testInsanity"),
Nobuaki Sukegawa826ea992015-10-28 22:19:45 +0900127 {Client16, {ok, InsaneResult}} = thrift_client:call(Client15, testInsanity, [DemoInsane]),
128 io:format("~p~n", [InsaneResult]),
David Reiss2c8d2282010-08-30 22:05:39 +0000129
Steve Cohen7ea4a872016-06-14 00:32:48 +0200130 {Client17, {ok, #'thrift.test.Xtruct'{string_thing = <<"Message">>}}} =
David Reiss2c8d2282010-08-30 22:05:39 +0000131 thrift_client:call(Client16, testMultiException, ["Safe", "Message"]),
132
133 Client18 =
134 try
135 {ClientS1, Result1} = thrift_client:call(Client17, testMultiException, ["Xception", "Message"]),
136 io:format("Unexpected return! ~p~n", [Result1]),
137 ClientS1
138 catch
Steve Cohen7ea4a872016-06-14 00:32:48 +0200139 throw:{ClientS2, {exception, ExnS1 = #'thrift.test.Xception'{}}} ->
140 #'thrift.test.Xception'{errorCode = 1001, message = <<"This is an Xception">>} = ExnS1,
David Reiss2c8d2282010-08-30 22:05:39 +0000141 ClientS2;
Steve Cohen7ea4a872016-06-14 00:32:48 +0200142 throw:{ClientS2, {exception, _ExnS1 = #'thrift.test.Xception2'{}}} ->
David Reiss2c8d2282010-08-30 22:05:39 +0000143 io:format("Wrong exception type!~n", []),
144 ClientS2
145 end,
146
147 Client19 =
148 try
149 {ClientS3, Result2} = thrift_client:call(Client18, testMultiException, ["Xception2", "Message"]),
150 io:format("Unexpected return! ~p~n", [Result2]),
151 ClientS3
152 catch
Steve Cohen7ea4a872016-06-14 00:32:48 +0200153 throw:{ClientS4, {exception, _ExnS2 = #'thrift.test.Xception'{}}} ->
David Reiss2c8d2282010-08-30 22:05:39 +0000154 io:format("Wrong exception type!~n", []),
155 ClientS4;
Steve Cohen7ea4a872016-06-14 00:32:48 +0200156 throw:{ClientS4, {exception, ExnS2 = #'thrift.test.Xception2'{}}} ->
157 #'thrift.test.Xception2'{errorCode = 2002,
158 struct_thing = #'thrift.test.Xtruct'{
David Reiss2c8d2282010-08-30 22:05:39 +0000159 string_thing = <<"This is an Xception2">>}} = ExnS2,
160 ClientS4
161 end,
162
Nobuaki Sukegawa7ab56e82015-10-31 12:17:46 +0900163 %% Use deprecated erlang:now until we start requiring OTP18
164 %% Started = erlang:monotonic_time(milli_seconds),
165 {_, StartSec, StartUSec} = erlang:now(),
Nobuaki Sukegawab31f0902015-11-01 17:00:34 +0900166 error_logger:info_msg("testOneway"),
alisdair sullivan7bdba5c2014-09-30 22:03:34 -0700167 {Client20, {ok, ok}} = thrift_client:call(Client19, testOneway, [1]),
Nobuaki Sukegawa7ab56e82015-10-31 12:17:46 +0900168 {_, EndSec, EndUSec} = erlang:now(),
169 Elapsed = (EndSec - StartSec) * 1000 + (EndUSec - StartUSec) / 1000,
170 if
171 Elapsed > 1000 -> exit(1);
172 true -> true
173 end,
alisdair sullivan7bdba5c2014-09-30 22:03:34 -0700174
175 thrift_client:close(Client20).