登录
首页 >  Golang >  Go问答

测试 gRPC 服务

来源:Golang技术栈

时间:2023-04-15 17:53:16 243浏览 收藏

偷偷努力,悄无声息地变强,然后惊艳所有人!哈哈,小伙伴们又来学习啦~今天我将给大家介绍《测试 gRPC 服务》,这篇文章主要会讲到golang等等知识点,不知道大家对其都有多少了解,下面我们就一起来看一吧!当然,非常希望大家能多多评论,给出合理的建议,我们一起学习,一起进步!

问题内容

我想测试一个用 Go 编写的 gRPC 服务。我使用的示例是来自[grpc-go repo](https://github.com/grpc/grpc- go/blob/master/examples/helloworld/greeter_server/main.go)的 Hello World 服务器示例。

protobuf 定义如下:

syntax = "proto3";

package helloworld;

// The greeting service definition.
service Greeter {
  // Sends a greeting
  rpc SayHello (HelloRequest) returns (HelloReply) {}
}

// The request message containing the user's name.
message HelloRequest {
  string name = 1;
}

// The response message containing the greetings
message HelloReply {
  string message = 1;
}

主要的类型greeter_server是:

// server is used to implement helloworld.GreeterServer.
type server struct{}

// SayHello implements helloworld.GreeterServer
func (s *server) SayHello(ctx context.Context, in *pb.HelloRequest) (*pb.HelloReply, error) {
    return &pb.HelloReply{Message: "Hello " + in.Name}, nil
}

我找了一些例子,但我找不到任何关于如何在 Go 中为 gRPC 服务实现测试的信息。

正确答案

我认为您正在寻找该google.golang.org/grpc/test/bufconn软件包来帮助您避免使用真实端口号启动服务,但仍允许测试流式 RPC。

import "google.golang.org/grpc/test/bufconn"

const bufSize = 1024 * 1024

var lis *bufconn.Listener

func init() {
    lis = bufconn.Listen(bufSize)
    s := grpc.NewServer()
    pb.RegisterGreeterServer(s, &server{})
    go func() {
        if err := s.Serve(lis); err != nil {
            log.Fatalf("Server exited with error: %v", err)
        }
    }()
}

func bufDialer(context.Context, string) (net.Conn, error) {
    return lis.Dial()
}

func TestSayHello(t *testing.T) {
    ctx := context.Background()
    conn, err := grpc.DialContext(ctx, "bufnet", grpc.WithContextDialer(bufDialer), grpc.WithInsecure())
    if err != nil {
        t.Fatalf("Failed to dial bufnet: %v", err)
    }
    defer conn.Close()
    client := pb.NewGreeterClient(conn)
    resp, err := client.SayHello(ctx, &pb.HelloRequest{"Dr. Seuss"})
    if err != nil {
        t.Fatalf("SayHello failed: %v", err)
    }
    log.Printf("Response: %+v", resp)
    // Test for output here.
}

这种方法的好处是您仍然可以获得网络行为,但是通过内存连接而不使用操作系统级别的资源,例如可能会或可能不会快速清理的端口。它允许您以实际使用的方式对其进行测试,并为您提供正确的流媒体行为。

我没有想到一个流媒体示例,但神奇的酱汁就在上面。它为您提供了正常网络连接的所有预期行为。诀窍是设置 WithDialer 选项,如图所示,使用 bufconn 包创建一个公开自己的拨号程序的侦听器。我一直使用这种技术来测试 gRPC 服务,而且效果很好。

理论要掌握,实操不能落!以上关于《测试 gRPC 服务》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!

声明:本文转载于:Golang技术栈 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>