136 lines
4.1 KiB
Go
136 lines
4.1 KiB
Go
|
|
package notify
|
||
|
|
|
||
|
|
import (
|
||
|
|
"context"
|
||
|
|
"errors"
|
||
|
|
"net"
|
||
|
|
"testing"
|
||
|
|
"time"
|
||
|
|
)
|
||
|
|
|
||
|
|
func TestClientSendReturnsServiceShutdownWhenNotRunning(t *testing.T) {
|
||
|
|
client := NewClient().(*ClientCommon)
|
||
|
|
UseLegacySecurityClient(client)
|
||
|
|
|
||
|
|
err := client.Send("notify", []byte("hello"))
|
||
|
|
if !errors.Is(err, errServiceShutdown) {
|
||
|
|
t.Fatalf("client Send error = %v, want %v", err, errServiceShutdown)
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
func TestServerSendReturnsServiceShutdownWhenNotRunning(t *testing.T) {
|
||
|
|
server := NewServer().(*ServerCommon)
|
||
|
|
UseLegacySecurityServer(server)
|
||
|
|
|
||
|
|
err := server.Send(nil, "notify", []byte("hello"))
|
||
|
|
if !errors.Is(err, errServiceShutdown) {
|
||
|
|
t.Fatalf("server Send error = %v, want %v", err, errServiceShutdown)
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
func TestClientSendReturnsTransportDetachedWhenSessionAliveWithoutTransport(t *testing.T) {
|
||
|
|
client := NewClient().(*ClientCommon)
|
||
|
|
client.markSessionStarted()
|
||
|
|
client.clearClientSessionRuntimeTransport()
|
||
|
|
|
||
|
|
err := client.Send("notify", []byte("hello"))
|
||
|
|
if !errors.Is(err, errTransportDetached) {
|
||
|
|
t.Fatalf("client Send error = %v, want %v", err, errTransportDetached)
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
func TestServerSendReturnsTransportDetachedWhenPeerTransportMissing(t *testing.T) {
|
||
|
|
server := NewServer().(*ServerCommon)
|
||
|
|
server.markSessionStarted()
|
||
|
|
|
||
|
|
err := server.Send(&ClientConn{}, "notify", []byte("hello"))
|
||
|
|
if !errors.Is(err, errTransportDetached) {
|
||
|
|
t.Fatalf("server Send error = %v, want %v", err, errTransportDetached)
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
func TestPendingWaitClosedErrorReturnsTransportDetachedWhenServiceStillRunning(t *testing.T) {
|
||
|
|
if err := pendingWaitClosedError(nil); !errors.Is(err, errTransportDetached) {
|
||
|
|
t.Fatalf("pendingWaitClosedError(nil) = %v, want %v", err, errTransportDetached)
|
||
|
|
}
|
||
|
|
openCh := make(chan struct{})
|
||
|
|
if err := pendingWaitClosedError(openCh); !errors.Is(err, errTransportDetached) {
|
||
|
|
t.Fatalf("pendingWaitClosedError(open) = %v, want %v", err, errTransportDetached)
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
func TestPendingWaitClosedErrorReturnsServiceShutdownWhenStopped(t *testing.T) {
|
||
|
|
stopCh := make(chan struct{})
|
||
|
|
close(stopCh)
|
||
|
|
if err := pendingWaitClosedError(stopCh); !errors.Is(err, errServiceShutdown) {
|
||
|
|
t.Fatalf("pendingWaitClosedError(stopped) = %v, want %v", err, errServiceShutdown)
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
func TestClientSendCtxReturnsContextCanceled(t *testing.T) {
|
||
|
|
client := NewClient().(*ClientCommon)
|
||
|
|
secret := []byte("0123456789abcdef0123456789abcdef")
|
||
|
|
client.SetSecretKey(secret)
|
||
|
|
server := newRunningPeerAttachServerForTest(t, func(server *ServerCommon) {
|
||
|
|
server.SetSecretKey(secret)
|
||
|
|
})
|
||
|
|
|
||
|
|
left, right := net.Pipe()
|
||
|
|
defer right.Close()
|
||
|
|
bootstrapPeerAttachConnForTest(t, server, right)
|
||
|
|
if err := client.ConnectByConn(left); err != nil {
|
||
|
|
t.Fatalf("client ConnectByConn failed: %v", err)
|
||
|
|
}
|
||
|
|
defer func() {
|
||
|
|
client.setByeFromServer(true)
|
||
|
|
_ = client.Stop()
|
||
|
|
}()
|
||
|
|
|
||
|
|
ctx, cancel := context.WithCancel(context.Background())
|
||
|
|
cancel()
|
||
|
|
_, err := client.SendCtx(ctx, "ctx-canceled", []byte("payload"))
|
||
|
|
if !errors.Is(err, context.Canceled) {
|
||
|
|
t.Fatalf("client SendCtx error = %v, want %v", err, context.Canceled)
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
func TestServerSendCtxReturnsContextCanceled(t *testing.T) {
|
||
|
|
client := NewClient().(*ClientCommon)
|
||
|
|
secret := []byte("0123456789abcdef0123456789abcdef")
|
||
|
|
client.SetSecretKey(secret)
|
||
|
|
server := newRunningPeerAttachServerForTest(t, func(server *ServerCommon) {
|
||
|
|
server.SetSecretKey(secret)
|
||
|
|
})
|
||
|
|
|
||
|
|
left, right := net.Pipe()
|
||
|
|
defer right.Close()
|
||
|
|
bootstrapPeerAttachConnForTest(t, server, right)
|
||
|
|
if err := client.ConnectByConn(left); err != nil {
|
||
|
|
t.Fatalf("client ConnectByConn failed: %v", err)
|
||
|
|
}
|
||
|
|
defer func() {
|
||
|
|
client.setByeFromServer(true)
|
||
|
|
_ = client.Stop()
|
||
|
|
}()
|
||
|
|
|
||
|
|
var logical *LogicalConn
|
||
|
|
deadline := time.Now().Add(time.Second)
|
||
|
|
for time.Now().Before(deadline) {
|
||
|
|
logical = server.GetLogicalConn(client.peerIdentity)
|
||
|
|
if logical != nil {
|
||
|
|
break
|
||
|
|
}
|
||
|
|
time.Sleep(10 * time.Millisecond)
|
||
|
|
}
|
||
|
|
if logical == nil {
|
||
|
|
t.Fatal("server logical conn not found")
|
||
|
|
}
|
||
|
|
|
||
|
|
ctx, cancel := context.WithCancel(context.Background())
|
||
|
|
cancel()
|
||
|
|
_, err := server.SendCtxLogical(ctx, logical, "ctx-canceled", []byte("payload"))
|
||
|
|
if !errors.Is(err, context.Canceled) {
|
||
|
|
t.Fatalf("server SendCtxLogical error = %v, want %v", err, context.Canceled)
|
||
|
|
}
|
||
|
|
}
|