160 lines
3.3 KiB
Go
160 lines
3.3 KiB
Go
package mocks
|
|
|
|
import (
|
|
"crypto/tls"
|
|
"net"
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/lucas-clemente/quic-go"
|
|
"github.com/ooni/probe-cli/v3/internal/model"
|
|
)
|
|
|
|
func TestTrace(t *testing.T) {
|
|
t.Run("TimeNow", func(t *testing.T) {
|
|
now := time.Now()
|
|
tx := &Trace{
|
|
MockTimeNow: func() time.Time {
|
|
return now
|
|
},
|
|
}
|
|
if !tx.TimeNow().Equal(now) {
|
|
t.Fatal("not working as intended")
|
|
}
|
|
})
|
|
|
|
t.Run("MaybeWrapNetConn", func(t *testing.T) {
|
|
expect := &Conn{}
|
|
tx := &Trace{
|
|
MockMaybeWrapNetConn: func(conn net.Conn) net.Conn {
|
|
return expect
|
|
},
|
|
}
|
|
got := tx.MaybeWrapNetConn(&Conn{})
|
|
if got != expect {
|
|
t.Fatal("not working as intended")
|
|
}
|
|
})
|
|
|
|
t.Run("MaybeWrapUDPLikeConn", func(t *testing.T) {
|
|
expect := &UDPLikeConn{}
|
|
tx := &Trace{
|
|
MockMaybeWrapUDPLikeConn: func(conn model.UDPLikeConn) model.UDPLikeConn {
|
|
return expect
|
|
},
|
|
}
|
|
got := tx.MaybeWrapUDPLikeConn(&UDPLikeConn{})
|
|
if got != expect {
|
|
t.Fatal("not working as intended")
|
|
}
|
|
})
|
|
|
|
t.Run("OnDNSRoundTripForLookupHost", func(t *testing.T) {
|
|
var called bool
|
|
tx := &Trace{
|
|
MockOnDNSRoundTripForLookupHost: func(started time.Time, reso model.Resolver, query model.DNSQuery,
|
|
response model.DNSResponse, addrs []string, err error, finished time.Time) {
|
|
called = true
|
|
},
|
|
}
|
|
tx.OnDNSRoundTripForLookupHost(
|
|
time.Now(),
|
|
&Resolver{},
|
|
&DNSQuery{},
|
|
&DNSResponse{},
|
|
[]string{},
|
|
nil,
|
|
time.Now(),
|
|
)
|
|
if !called {
|
|
t.Fatal("not called")
|
|
}
|
|
})
|
|
|
|
t.Run("OnConnectDone", func(t *testing.T) {
|
|
var called bool
|
|
tx := &Trace{
|
|
MockOnConnectDone: func(started time.Time, network, domain, remoteAddr string, err error, finished time.Time) {
|
|
called = true
|
|
},
|
|
}
|
|
tx.OnConnectDone(
|
|
time.Now(),
|
|
"tcp",
|
|
"dns.google",
|
|
"8.8.8.8:443",
|
|
nil,
|
|
time.Now(),
|
|
)
|
|
if !called {
|
|
t.Fatal("not called")
|
|
}
|
|
})
|
|
|
|
t.Run("OnTLSHandshakeStart", func(t *testing.T) {
|
|
var called bool
|
|
tx := &Trace{
|
|
MockOnTLSHandshakeStart: func(now time.Time, remoteAddr string, config *tls.Config) {
|
|
called = true
|
|
},
|
|
}
|
|
tx.OnTLSHandshakeStart(time.Now(), "8.8.8.8:443", &tls.Config{})
|
|
if !called {
|
|
t.Fatal("not called")
|
|
}
|
|
})
|
|
|
|
t.Run("OnTLSHandshakeDone", func(t *testing.T) {
|
|
var called bool
|
|
tx := &Trace{
|
|
MockOnTLSHandshakeDone: func(started time.Time, remoteAddr string, config *tls.Config, state tls.ConnectionState, err error, finished time.Time) {
|
|
called = true
|
|
},
|
|
}
|
|
tx.OnTLSHandshakeDone(
|
|
time.Now(),
|
|
"8.8.8.8:443",
|
|
&tls.Config{},
|
|
tls.ConnectionState{},
|
|
nil,
|
|
time.Now(),
|
|
)
|
|
if !called {
|
|
t.Fatal("not called")
|
|
}
|
|
})
|
|
|
|
t.Run("OnQUICHandshakeStart", func(t *testing.T) {
|
|
var called bool
|
|
tx := &Trace{
|
|
MockOnQUICHandshakeStart: func(now time.Time, remoteAddrs string, config *quic.Config) {
|
|
called = true
|
|
},
|
|
}
|
|
tx.OnQUICHandshakeStart(time.Now(), "1.1.1.1:443", &quic.Config{})
|
|
if !called {
|
|
t.Fatal("not called")
|
|
}
|
|
})
|
|
|
|
t.Run("OnQUICHandshakeDone", func(t *testing.T) {
|
|
var called bool
|
|
tx := &Trace{
|
|
MockOnQUICHandshakeDone: func(started time.Time, remoteAddr string, qconn quic.EarlyConnection, config *tls.Config, err error, finished time.Time) {
|
|
called = true
|
|
},
|
|
}
|
|
tx.OnQUICHandshakeDone(
|
|
time.Now(),
|
|
"1.1.1.1:443",
|
|
nil,
|
|
&tls.Config{},
|
|
nil,
|
|
time.Now(),
|
|
)
|
|
if !called {
|
|
t.Fatal("not called")
|
|
}
|
|
})
|
|
}
|