kratos/examples/tls/tls_test.go

133 lines
3.1 KiB

package main
import (
"context"
"crypto/tls"
"crypto/x509"
"fmt"
"io/ioutil"
"testing"
"time"
etcdregistry "github.com/go-kratos/kratos/contrib/registry/etcd/v2"
"github.com/go-kratos/kratos/examples/helloworld/helloworld"
pb "github.com/go-kratos/kratos/examples/helloworld/helloworld"
"github.com/go-kratos/kratos/v2"
"github.com/go-kratos/kratos/v2/registry"
"github.com/go-kratos/kratos/v2/transport/grpc"
"github.com/go-kratos/kratos/v2/transport/http"
etcd "go.etcd.io/etcd/client/v3"
)
// server is used to implement helloworld.GreeterServer.
type server struct {
pb.UnimplementedGreeterServer
}
// SayHello implements helloworld.GreeterServer
func (s *server) SayHello(ctx context.Context, in *pb.HelloRequest) (*pb.HelloReply, error) {
return &pb.HelloReply{Message: fmt.Sprintf("Welcome %+v!", in.Name)}, nil
}
func startServer(r registry.Registrar, c *tls.Config) (app *kratos.App, err error) {
httpSrv := http.NewServer(http.TLSConfig(c))
grpcSrv := grpc.NewServer(grpc.TLSConfig(c))
s := &server{}
pb.RegisterGreeterServer(grpcSrv, s)
pb.RegisterGreeterHTTPServer(httpSrv, s)
app = kratos.New(
kratos.Name("helloworld"),
kratos.Server(
httpSrv,
grpcSrv,
),
kratos.Registrar(r),
kratos.RegistrarTimeout(5*time.Second),
)
go func() {
err = app.Run()
}()
time.Sleep(time.Second)
return
}
func callGRPC(t *testing.T, r registry.Discovery, c *tls.Config) {
conn, err := grpc.Dial(
context.Background(),
grpc.WithEndpoint("discovery:///helloworld"),
grpc.WithTLSConfig(c),
grpc.WithDiscovery(r),
)
if err != nil {
t.Fatal(err)
}
defer conn.Close()
client := helloworld.NewGreeterClient(conn)
reply, err := client.SayHello(context.Background(), &helloworld.HelloRequest{Name: "kratos"})
if err != nil {
t.Fatal(err)
}
t.Logf("[grpc] SayHello %+v\n", reply)
}
func callHTTP(t *testing.T, r registry.Discovery, c *tls.Config) {
conn, err := http.NewClient(
context.Background(),
http.WithEndpoint("discovery:///helloworld"),
http.WithTLSConfig(c),
http.WithDiscovery(r),
http.WithBlock(),
)
if err != nil {
t.Fatal(err)
}
defer conn.Close()
client := helloworld.NewGreeterHTTPClient(conn)
reply, err := client.SayHello(context.Background(), &helloworld.HelloRequest{Name: "kratos"})
if err != nil {
t.Fatal(err)
}
t.Logf("[http] SayHello %+v\n", reply)
}
func TestETCD(t *testing.T) {
client, err := etcd.New(etcd.Config{
Endpoints: []string{"127.0.0.1:2379"},
})
if err != nil {
t.Fatal(err)
}
b, err := ioutil.ReadFile("./cert/server.crt")
if err != nil {
t.Fatal(err)
}
cp := x509.NewCertPool()
if !cp.AppendCertsFromPEM(b) {
t.Fatal(err)
}
cert, err := tls.LoadX509KeyPair("./cert/server.crt", "./cert/server.key")
if err != nil {
t.Fatal(err)
}
tlsConf := &tls.Config{
ServerName: "www.kratos.com",
RootCAs: cp,
Certificates: []tls.Certificate{cert},
}
r := etcdregistry.New(client)
srv, err := startServer(r, nil)
if err != nil {
t.Fatal(err)
}
srvTLS, err := startServer(r, tlsConf)
if err != nil {
t.Fatal(err)
}
callHTTP(t, r, tlsConf)
callGRPC(t, r, tlsConf)
srv.Stop()
srvTLS.Stop()
}