forked from keybase/client
-
Notifications
You must be signed in to change notification settings - Fork 0
/
test.go
128 lines (115 loc) · 3.44 KB
/
test.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
// Auto-generated by avdl-compiler v1.3.25 (https://github.com/keybase/node-avdl-compiler)
// Input file: avdl/keybase1/test.avdl
package keybase1
import (
"github.com/keybase/go-framed-msgpack-rpc/rpc"
context "golang.org/x/net/context"
)
// Result from calling test(..).
type Test struct {
Reply string `codec:"reply" json:"reply"`
}
func (o Test) DeepCopy() Test {
return Test{
Reply: o.Reply,
}
}
type TestArg struct {
SessionID int `codec:"sessionID" json:"sessionID"`
Name string `codec:"name" json:"name"`
}
type TestCallbackArg struct {
SessionID int `codec:"sessionID" json:"sessionID"`
Name string `codec:"name" json:"name"`
}
type PanicArg struct {
Message string `codec:"message" json:"message"`
}
type TestInterface interface {
// Call test method.
// Will trigger the testCallback method, whose result will be set in the
// returned Test object, reply property.
Test(context.Context, TestArg) (Test, error)
// This is a service callback triggered from test(..).
// The name param is what was passed into test.
TestCallback(context.Context, TestCallbackArg) (string, error)
// For testing crashes.
Panic(context.Context, string) error
}
func TestProtocol(i TestInterface) rpc.Protocol {
return rpc.Protocol{
Name: "keybase.1.test",
Methods: map[string]rpc.ServeHandlerDescription{
"test": {
MakeArg: func() interface{} {
var ret [1]TestArg
return &ret
},
Handler: func(ctx context.Context, args interface{}) (ret interface{}, err error) {
typedArgs, ok := args.(*[1]TestArg)
if !ok {
err = rpc.NewTypeError((*[1]TestArg)(nil), args)
return
}
ret, err = i.Test(ctx, typedArgs[0])
return
},
MethodType: rpc.MethodCall,
},
"testCallback": {
MakeArg: func() interface{} {
var ret [1]TestCallbackArg
return &ret
},
Handler: func(ctx context.Context, args interface{}) (ret interface{}, err error) {
typedArgs, ok := args.(*[1]TestCallbackArg)
if !ok {
err = rpc.NewTypeError((*[1]TestCallbackArg)(nil), args)
return
}
ret, err = i.TestCallback(ctx, typedArgs[0])
return
},
MethodType: rpc.MethodCall,
},
"panic": {
MakeArg: func() interface{} {
var ret [1]PanicArg
return &ret
},
Handler: func(ctx context.Context, args interface{}) (ret interface{}, err error) {
typedArgs, ok := args.(*[1]PanicArg)
if !ok {
err = rpc.NewTypeError((*[1]PanicArg)(nil), args)
return
}
err = i.Panic(ctx, typedArgs[0].Message)
return
},
MethodType: rpc.MethodCall,
},
},
}
}
type TestClient struct {
Cli rpc.GenericClient
}
// Call test method.
// Will trigger the testCallback method, whose result will be set in the
// returned Test object, reply property.
func (c TestClient) Test(ctx context.Context, __arg TestArg) (res Test, err error) {
err = c.Cli.Call(ctx, "keybase.1.test.test", []interface{}{__arg}, &res)
return
}
// This is a service callback triggered from test(..).
// The name param is what was passed into test.
func (c TestClient) TestCallback(ctx context.Context, __arg TestCallbackArg) (res string, err error) {
err = c.Cli.Call(ctx, "keybase.1.test.testCallback", []interface{}{__arg}, &res)
return
}
// For testing crashes.
func (c TestClient) Panic(ctx context.Context, message string) (err error) {
__arg := PanicArg{Message: message}
err = c.Cli.Call(ctx, "keybase.1.test.panic", []interface{}{__arg}, nil)
return
}