Subversion Repositories SmartDukaan

Rev

Rev 30 | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
30 ashish 1
%%
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_disklog).
21
 
22
-compile(export_all).
23
 
24
t() ->
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"),
35
 
36
    % We have to make oneway calls into this client only since otherwise it will try
37
    % to read from the disklog and go boom.
38
    {ok, ok} = thrift_client:call(Client, testOneway, [16#deadbeef]),
39
    io:format("Call written~n"),
40
 
41
    % Use the send_call method to write a non-oneway call into the log
42
    ok = thrift_client:send_call(Client, testString, [<<"hello world">>]),
43
    io:format("Non-oneway call sent~n"),
44
 
45
    ok = thrift_client:close(Client),
46
    io:format("Client closed~n"),
47
 
48
    ok.
49
 
50
 
51
 
52
t_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
 
68
    % We have to make oneway calls into this client only since otherwise it will try
69
    % to read from the disklog and go boom.
70
    {ok, ok} = thrift_client:call(Client, testOneway, [16#deadbeef]),
71
    io:format("Call written~n"),
72
 
73
    % Use the send_call method to write a non-oneway call into the log
74
    ok = thrift_client:send_call(Client, testString, [<<"hello world">>]),
75
    io:format("Non-oneway call sent~n"),
76
 
77
    ok = thrift_client:close(Client),
78
    io:format("Client closed~n"),
79
 
80
    ok.
81