blob: 7b0be72dbd589e0bb04ab6d6b5d7ba16d2138046 [file] [log] [blame]
David Reissea2cba82009-03-30 21:35:00 +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
David Reiss6d477592008-06-11 01:12:09 +000020-module(test_disklog).
21
22-compile(export_all).
23
24t() ->
25 {ok, TransportFactory} =
26 thrift_disk_log_transport:new_transport_factory(
27 test_disklog,
28 [{file, "/tmp/test_log"},
29 {size, {1024*1024, 10}}]),
30 {ok, ProtocolFactory} = thrift_binary_protocol:new_protocol_factory(
31 TransportFactory, []),
32 {ok, Client} = thrift_client:start_link(ProtocolFactory, thriftTest_thrift),
33
34 io:format("Client started~n"),
David Reiss65cf7202008-06-11 01:12:20 +000035
David Reissc51986f2009-03-24 20:01:25 +000036 % We have to make oneway calls into this client only since otherwise it will try
David Reiss6d477592008-06-11 01:12:09 +000037 % to read from the disklog and go boom.
David Reiss6ce401d2009-03-24 20:01:58 +000038 {ok, ok} = thrift_client:call(Client, testOneway, [16#deadbeef]),
David Reiss6d477592008-06-11 01:12:09 +000039 io:format("Call written~n"),
40
David Reissc51986f2009-03-24 20:01:25 +000041 % Use the send_call method to write a non-oneway call into the log
David Reiss65cf7202008-06-11 01:12:20 +000042 ok = thrift_client:send_call(Client, testString, [<<"hello world">>]),
David Reiss6ce401d2009-03-24 20:01:58 +000043 io:format("Non-oneway call sent~n"),
David Reiss65cf7202008-06-11 01:12:20 +000044
David Reiss6d477592008-06-11 01:12:09 +000045 ok = thrift_client:close(Client),
46 io:format("Client closed~n"),
47
48 ok.
49
David Reiss84454062008-06-11 01:12:31 +000050
51
52t_base64() ->
53 {ok, TransportFactory} =
54 thrift_disk_log_transport:new_transport_factory(
55 test_disklog,
56 [{file, "/tmp/test_b64_log"},
57 {size, {1024*1024, 10}}]),
58 {ok, B64Factory} =
59 thrift_base64_transport:new_transport_factory(TransportFactory),
60 {ok, BufFactory} =
61 thrift_buffered_transport:new_transport_factory(B64Factory),
62 {ok, ProtocolFactory} = thrift_binary_protocol:new_protocol_factory(
63 BufFactory, []),
64 {ok, Client} = thrift_client:start_link(ProtocolFactory, thriftTest_thrift),
65
66 io:format("Client started~n"),
67
David Reissc51986f2009-03-24 20:01:25 +000068 % We have to make oneway calls into this client only since otherwise it will try
David Reiss84454062008-06-11 01:12:31 +000069 % to read from the disklog and go boom.
David Reiss6ce401d2009-03-24 20:01:58 +000070 {ok, ok} = thrift_client:call(Client, testOneway, [16#deadbeef]),
David Reiss84454062008-06-11 01:12:31 +000071 io:format("Call written~n"),
72
David Reissc51986f2009-03-24 20:01:25 +000073 % Use the send_call method to write a non-oneway call into the log
David Reiss84454062008-06-11 01:12:31 +000074 ok = thrift_client:send_call(Client, testString, [<<"hello world">>]),
David Reiss6ce401d2009-03-24 20:01:58 +000075 io:format("Non-oneway call sent~n"),
David Reiss84454062008-06-11 01:12:31 +000076
77 ok = thrift_client:close(Client),
78 io:format("Client closed~n"),
79
80 ok.
81