gRPC 서비스 테스트
Go에서 gRPC 서비스를 테스트하려면 기능과 성능을 모두 보장하는 포괄적인 접근 방식이 필요합니다. 이러한 서비스를 테스트하는 한 가지 방법은 google.golang.org/grpc/test/bufconn 패키지를 사용하여 메모리 내 연결 내에서 네트워크 동작을 모의하는 것입니다.
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. }
이 접근 방식은 네트워크 동작과 인메모리 연결을 모두 활용하여 적절한 테스트를 보장하므로 보다 현실적이고 포괄적인 테스트 프로세스가 가능합니다.
위 내용은 인메모리 연결을 사용하여 Go에서 gRPC 서비스를 효과적으로 테스트하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!