2021-07-01 16:34:36 +02:00
|
|
|
package errorsx
|
2021-02-02 12:05:47 +01:00
|
|
|
|
|
|
|
import (
|
|
|
|
"errors"
|
|
|
|
"testing"
|
|
|
|
|
2021-09-07 17:09:30 +02:00
|
|
|
"github.com/ooni/probe-cli/v3/internal/netxlite/errorsx"
|
2021-02-02 12:05:47 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestMaybeBuildFactory(t *testing.T) {
|
|
|
|
err := SafeErrWrapperBuilder{
|
2021-06-23 13:36:45 +02:00
|
|
|
Error: errors.New("mocked error"),
|
2021-02-02 12:05:47 +01:00
|
|
|
}.MaybeBuild()
|
2021-09-07 17:09:30 +02:00
|
|
|
var target *errorsx.ErrWrapper
|
2021-02-02 12:05:47 +01:00
|
|
|
if errors.As(err, &target) == false {
|
|
|
|
t.Fatal("not the expected error type")
|
|
|
|
}
|
|
|
|
if target.Failure != "unknown_failure: mocked error" {
|
|
|
|
t.Fatal("the failure string is wrong")
|
|
|
|
}
|
|
|
|
if target.WrappedErr.Error() != "mocked error" {
|
|
|
|
t.Fatal("the wrapped error is wrong")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestToOperationString(t *testing.T) {
|
|
|
|
t.Run("for connect", func(t *testing.T) {
|
|
|
|
// You're doing HTTP and connect fails. You want to know
|
|
|
|
// that connect failed not that HTTP failed.
|
2021-09-07 17:09:30 +02:00
|
|
|
err := &errorsx.ErrWrapper{Operation: errorsx.ConnectOperation}
|
|
|
|
if toOperationString(err, errorsx.HTTPRoundTripOperation) != errorsx.ConnectOperation {
|
2021-02-02 12:05:47 +01:00
|
|
|
t.Fatal("unexpected result")
|
|
|
|
}
|
|
|
|
})
|
|
|
|
t.Run("for http_round_trip", func(t *testing.T) {
|
|
|
|
// You're doing DoH and something fails inside HTTP. You want
|
|
|
|
// to know about the internal HTTP error, not resolve.
|
2021-09-07 17:09:30 +02:00
|
|
|
err := &errorsx.ErrWrapper{Operation: errorsx.HTTPRoundTripOperation}
|
|
|
|
if toOperationString(err, errorsx.ResolveOperation) != errorsx.HTTPRoundTripOperation {
|
2021-02-02 12:05:47 +01:00
|
|
|
t.Fatal("unexpected result")
|
|
|
|
}
|
|
|
|
})
|
|
|
|
t.Run("for resolve", func(t *testing.T) {
|
|
|
|
// You're doing HTTP and the DNS fails. You want to
|
|
|
|
// know that resolve failed.
|
2021-09-07 17:09:30 +02:00
|
|
|
err := &errorsx.ErrWrapper{Operation: errorsx.ResolveOperation}
|
|
|
|
if toOperationString(err, errorsx.HTTPRoundTripOperation) != errorsx.ResolveOperation {
|
2021-02-02 12:05:47 +01:00
|
|
|
t.Fatal("unexpected result")
|
|
|
|
}
|
|
|
|
})
|
|
|
|
t.Run("for tls_handshake", func(t *testing.T) {
|
|
|
|
// You're doing HTTP and the TLS handshake fails. You want
|
|
|
|
// to know about a TLS handshake error.
|
2021-09-07 17:09:30 +02:00
|
|
|
err := &errorsx.ErrWrapper{Operation: errorsx.TLSHandshakeOperation}
|
|
|
|
if toOperationString(err, errorsx.HTTPRoundTripOperation) != errorsx.TLSHandshakeOperation {
|
2021-02-02 12:05:47 +01:00
|
|
|
t.Fatal("unexpected result")
|
|
|
|
}
|
|
|
|
})
|
|
|
|
t.Run("for minor operation", func(t *testing.T) {
|
|
|
|
// You just noticed that TLS handshake failed and you
|
|
|
|
// have a child error telling you that read failed. Here
|
|
|
|
// you want to know about a TLS handshake error.
|
2021-09-07 17:09:30 +02:00
|
|
|
err := &errorsx.ErrWrapper{Operation: errorsx.ReadOperation}
|
|
|
|
if toOperationString(err, errorsx.TLSHandshakeOperation) != errorsx.TLSHandshakeOperation {
|
2021-02-02 12:05:47 +01:00
|
|
|
t.Fatal("unexpected result")
|
|
|
|
}
|
|
|
|
})
|
|
|
|
t.Run("for quic_handshake", func(t *testing.T) {
|
|
|
|
// You're doing HTTP and the TLS handshake fails. You want
|
|
|
|
// to know about a TLS handshake error.
|
2021-09-07 17:09:30 +02:00
|
|
|
err := &errorsx.ErrWrapper{Operation: errorsx.QUICHandshakeOperation}
|
|
|
|
if toOperationString(err, errorsx.HTTPRoundTripOperation) != errorsx.QUICHandshakeOperation {
|
2021-02-02 12:05:47 +01:00
|
|
|
t.Fatal("unexpected result")
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|