contentserver/client/sockettransport_test.go
Kevin Franklin Kim ec6ff54135
fix: lint issues
2024-11-25 22:40:02 +01:00

64 lines
1.5 KiB
Go

package client_test
import (
"net"
"testing"
"time"
"github.com/foomo/contentserver/client"
"github.com/foomo/contentserver/pkg/handler"
"github.com/pkg/errors"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require"
"go.uber.org/zap"
"go.uber.org/zap/zaptest"
"golang.org/x/net/nettest"
)
func BenchmarkSocketClientAndServerGetContent(b *testing.B) {
l := zaptest.NewLogger(b)
socketServer := initSocketRepoServer(b, l)
socketClient := newSocketClient(b, socketServer.Addr().String())
defer socketClient.Close()
defer socketServer.Close()
benchmarkServerAndClientGetContent(b, 30, 100, socketClient)
}
func newSocketClient(tb testing.TB, address string) *client.Client {
tb.Helper()
return client.New(client.NewSocketTransport(address, 25, 100*time.Millisecond))
}
func initSocketRepoServer(tb testing.TB, l *zap.Logger) net.Listener {
tb.Helper()
r := initRepo(tb, l)
h := handler.NewSocket(l, r)
// listen on socket
ln, err := nettest.NewLocalListener("tcp")
require.NoError(tb, err)
go func() {
for {
// this blocks until connection or error
conn, err := ln.Accept()
if errors.Is(err, net.ErrClosed) {
return
} else if err != nil {
tb.Error("runSocketServer: could not accept connection", err.Error())
continue
}
// a goroutine handles conn so that the loop can accept other connections
go func() {
l.Debug("accepted connection", zap.String("source", conn.RemoteAddr().String()))
h.Serve(conn)
assert.NoError(tb, conn.Close())
}()
}
}()
return ln
}