diff options
author | Felix Lange <fjl@twurst.com> | 2015-12-16 18:12:06 +0800 |
---|---|---|
committer | Felix Lange <fjl@twurst.com> | 2015-12-16 18:12:06 +0800 |
commit | e6408617049d10a6366eef33ea9e97b58c7e30f9 (patch) | |
tree | e68b2711bbe3a745e67f022595dbe9ecd2a6f4b8 /rpc/v2/server_test.go | |
parent | b9aedeab0b1cf56860f5ca53333a4f348395259c (diff) | |
parent | f3aac71fad041dedd239f0a86f7c7c43614cbf4f (diff) | |
download | go-tangerine-e6408617049d10a6366eef33ea9e97b58c7e30f9.tar go-tangerine-e6408617049d10a6366eef33ea9e97b58c7e30f9.tar.gz go-tangerine-e6408617049d10a6366eef33ea9e97b58c7e30f9.tar.bz2 go-tangerine-e6408617049d10a6366eef33ea9e97b58c7e30f9.tar.lz go-tangerine-e6408617049d10a6366eef33ea9e97b58c7e30f9.tar.xz go-tangerine-e6408617049d10a6366eef33ea9e97b58c7e30f9.tar.zst go-tangerine-e6408617049d10a6366eef33ea9e97b58c7e30f9.zip |
Merge pull request #2061 from zsfelfoldi/rpc-context
rpc: optionally passing context argument to rpc v2 api methods
Diffstat (limited to 'rpc/v2/server_test.go')
-rw-r--r-- | rpc/v2/server_test.go | 40 |
1 files changed, 38 insertions, 2 deletions
diff --git a/rpc/v2/server_test.go b/rpc/v2/server_test.go index f4f77672f..f250c184f 100644 --- a/rpc/v2/server_test.go +++ b/rpc/v2/server_test.go @@ -6,6 +6,8 @@ import ( "reflect" "testing" "time" + + "golang.org/x/net/context" ) type Service struct{} @@ -27,6 +29,10 @@ func (s *Service) Echo(str string, i int, args *Args) Result { return Result{str, i, args} } +func (s *Service) EchoWithCtx(ctx context.Context, str string, i int, args *Args) Result { + return Result{str, i, args} +} + func (s *Service) Rets() (string, error) { return "", nil } @@ -64,8 +70,8 @@ func TestServerRegisterName(t *testing.T) { t.Fatalf("Expected service calc to be registered") } - if len(svc.callbacks) != 3 { - t.Errorf("Expected 3 callbacks for service 'calc', got %d", len(svc.callbacks)) + if len(svc.callbacks) != 4 { + t.Errorf("Expected 4 callbacks for service 'calc', got %d", len(svc.callbacks)) } if len(svc.subscriptions) != 1 { @@ -217,3 +223,33 @@ func TestServerMethodExecution(t *testing.T) { t.Fatalf("expected %s, got %s\n", expected, codec.output) } } + +func TestServerMethodWithCtx(t *testing.T) { + server := NewServer() + service := new(Service) + + if err := server.RegisterName("test", service); err != nil { + t.Fatalf("%v", err) + } + + id := int64(12345) + req := jsonRequest{ + Method: "echoWithCtx", + Version: "2.0", + Id: &id, + } + args := []interface{}{"string arg", 1122, &Args{"qwerty"}} + req.Payload, _ = json.Marshal(&args) + + input, _ := json.Marshal(&req) + codec := &ServerTestCodec{input: input, closer: make(chan interface{})} + go server.ServeCodec(codec) + + <-codec.closer + + expected := `{"jsonrpc":"2.0","id":12345,"result":{"String":"string arg","Int":1122,"Args":{"S":"qwerty"}}}` + + if expected != codec.output { + t.Fatalf("expected %s, got %s\n", expected, codec.output) + } +} |