2021-09-05 14:49:38 +02:00
|
|
|
package netxlite
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
2021-09-05 21:23:47 +02:00
|
|
|
"errors"
|
|
|
|
"sync"
|
2021-09-05 14:49:38 +02:00
|
|
|
"testing"
|
2021-09-05 21:23:47 +02:00
|
|
|
"time"
|
2021-09-05 14:49:38 +02:00
|
|
|
|
2021-09-05 20:59:42 +02:00
|
|
|
"github.com/apex/log"
|
2021-09-05 14:49:38 +02:00
|
|
|
utls "gitlab.com/yawning/utls.git"
|
|
|
|
)
|
|
|
|
|
2021-09-08 11:39:27 +02:00
|
|
|
func TestNewTLSHandshakerUTLS(t *testing.T) {
|
2021-09-05 20:59:42 +02:00
|
|
|
th := NewTLSHandshakerUTLS(log.Log, &utls.HelloChrome_83)
|
2021-09-08 11:39:27 +02:00
|
|
|
logger := th.(*tlsHandshakerLogger)
|
|
|
|
if logger.Logger != log.Log {
|
2021-09-05 20:59:42 +02:00
|
|
|
t.Fatal("invalid logger")
|
|
|
|
}
|
2021-09-08 11:39:27 +02:00
|
|
|
errWrapper := logger.TLSHandshaker.(*tlsHandshakerErrWrapper)
|
|
|
|
configurable := errWrapper.TLSHandshaker.(*tlsHandshakerConfigurable)
|
|
|
|
if configurable.NewConn == nil {
|
2021-09-05 20:59:42 +02:00
|
|
|
t.Fatal("expected non-nil NewConn")
|
|
|
|
}
|
|
|
|
}
|
2021-09-05 21:23:47 +02:00
|
|
|
|
2021-09-08 11:39:27 +02:00
|
|
|
func TestUTLSConn(t *testing.T) {
|
|
|
|
t.Run("Handshake", func(t *testing.T) {
|
|
|
|
t.Run("not interrupted with success", func(t *testing.T) {
|
|
|
|
ctx := context.Background()
|
|
|
|
conn := &utlsConn{
|
|
|
|
testableHandshake: func() error {
|
|
|
|
return nil
|
|
|
|
},
|
|
|
|
}
|
|
|
|
err := conn.HandshakeContext(ctx)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
})
|
2021-09-05 21:23:47 +02:00
|
|
|
|
2021-09-08 11:39:27 +02:00
|
|
|
t.Run("not interrupted with failure", func(t *testing.T) {
|
|
|
|
expected := errors.New("mocked error")
|
|
|
|
ctx := context.Background()
|
|
|
|
conn := &utlsConn{
|
|
|
|
testableHandshake: func() error {
|
|
|
|
return expected
|
|
|
|
},
|
|
|
|
}
|
|
|
|
err := conn.HandshakeContext(ctx)
|
|
|
|
if !errors.Is(err, expected) {
|
|
|
|
t.Fatal("not the error we expected", err)
|
|
|
|
}
|
|
|
|
})
|
2021-09-05 21:41:49 +02:00
|
|
|
|
2021-09-08 11:39:27 +02:00
|
|
|
t.Run("interrupted", func(t *testing.T) {
|
|
|
|
wg := sync.WaitGroup{}
|
|
|
|
wg.Add(1)
|
|
|
|
sigch := make(chan interface{})
|
|
|
|
ctx, cancel := context.WithTimeout(context.Background(), time.Millisecond)
|
|
|
|
defer cancel()
|
|
|
|
conn := &utlsConn{
|
|
|
|
testableHandshake: func() error {
|
|
|
|
defer wg.Done()
|
|
|
|
<-sigch
|
|
|
|
return nil
|
|
|
|
},
|
|
|
|
}
|
|
|
|
err := conn.HandshakeContext(ctx)
|
|
|
|
if !errors.Is(err, context.DeadlineExceeded) {
|
|
|
|
t.Fatal("not the error we expected", err)
|
|
|
|
}
|
|
|
|
close(sigch)
|
|
|
|
wg.Wait()
|
|
|
|
})
|
2021-09-05 21:41:49 +02:00
|
|
|
|
2021-09-08 11:39:27 +02:00
|
|
|
t.Run("with panic", func(t *testing.T) {
|
|
|
|
wg := sync.WaitGroup{}
|
|
|
|
wg.Add(1)
|
|
|
|
ctx := context.Background()
|
|
|
|
conn := &utlsConn{
|
|
|
|
testableHandshake: func() error {
|
|
|
|
defer wg.Done()
|
|
|
|
panic("mascetti")
|
|
|
|
},
|
|
|
|
}
|
|
|
|
err := conn.HandshakeContext(ctx)
|
|
|
|
if !errors.Is(err, ErrUTLSHandshakePanic) {
|
|
|
|
t.Fatal("not the error we expected", err)
|
|
|
|
}
|
|
|
|
wg.Wait()
|
|
|
|
})
|
|
|
|
})
|
2021-09-05 21:41:49 +02:00
|
|
|
}
|