0d65438ea1
This commit forward ports 74947dbbd12266c12a38fad51a70fc78a21720fd from the `release/3.11` branch to `master`. Here's the original commit message: - - - Android is also Linux. The Android build fails because both errno_linux.go and errno_android.go are compiled. There's no difference between the files except into a comment that mentions "linux" or "android". Therefore, it's safe to remove the android-specific file and just keep and use the linux-specific one. Part of https://github.com/ooni/probe/issues/1863, where we're forward porting ooni/go patches to go1.17. I'm still trying to figure out whether I can build oonimkall using the forward ported patches and this error prevents me from building, because the build fails. "やれやれだぜ" Note that this patch WILL need to be forward ported to master. This bug was previosuly reported to me by @hellais. Because I did run `go generate ./internal/netxlite/...` we also get for free updated certificates, which is OK.
189 lines
5.8 KiB
Go
189 lines
5.8 KiB
Go
// Code generated by go generate; DO NOT EDIT.
|
|
// Generated: 2021-11-10 12:32:21.590776904 +0100 CET m=+1.350736040
|
|
|
|
package netxlite
|
|
|
|
import (
|
|
"io"
|
|
"syscall"
|
|
"testing"
|
|
|
|
"golang.org/x/sys/unix"
|
|
)
|
|
|
|
func TestClassifySyscallError(t *testing.T) {
|
|
t.Run("for a non-syscall error", func(t *testing.T) {
|
|
if v := classifySyscallError(io.EOF); v != "" {
|
|
t.Fatalf("expected empty string, got '%s'", v)
|
|
}
|
|
})
|
|
|
|
t.Run("for ECONNREFUSED", func(t *testing.T) {
|
|
if v := classifySyscallError(unix.ECONNREFUSED); v != FailureConnectionRefused {
|
|
t.Fatalf("expected '%s', got '%s'", FailureConnectionRefused, v)
|
|
}
|
|
})
|
|
|
|
t.Run("for ECONNRESET", func(t *testing.T) {
|
|
if v := classifySyscallError(unix.ECONNRESET); v != FailureConnectionReset {
|
|
t.Fatalf("expected '%s', got '%s'", FailureConnectionReset, v)
|
|
}
|
|
})
|
|
|
|
t.Run("for EHOSTUNREACH", func(t *testing.T) {
|
|
if v := classifySyscallError(unix.EHOSTUNREACH); v != FailureHostUnreachable {
|
|
t.Fatalf("expected '%s', got '%s'", FailureHostUnreachable, v)
|
|
}
|
|
})
|
|
|
|
t.Run("for ETIMEDOUT", func(t *testing.T) {
|
|
if v := classifySyscallError(unix.ETIMEDOUT); v != FailureTimedOut {
|
|
t.Fatalf("expected '%s', got '%s'", FailureTimedOut, v)
|
|
}
|
|
})
|
|
|
|
t.Run("for EAFNOSUPPORT", func(t *testing.T) {
|
|
if v := classifySyscallError(unix.EAFNOSUPPORT); v != FailureAddressFamilyNotSupported {
|
|
t.Fatalf("expected '%s', got '%s'", FailureAddressFamilyNotSupported, v)
|
|
}
|
|
})
|
|
|
|
t.Run("for EADDRINUSE", func(t *testing.T) {
|
|
if v := classifySyscallError(unix.EADDRINUSE); v != FailureAddressInUse {
|
|
t.Fatalf("expected '%s', got '%s'", FailureAddressInUse, v)
|
|
}
|
|
})
|
|
|
|
t.Run("for EADDRNOTAVAIL", func(t *testing.T) {
|
|
if v := classifySyscallError(unix.EADDRNOTAVAIL); v != FailureAddressNotAvailable {
|
|
t.Fatalf("expected '%s', got '%s'", FailureAddressNotAvailable, v)
|
|
}
|
|
})
|
|
|
|
t.Run("for EISCONN", func(t *testing.T) {
|
|
if v := classifySyscallError(unix.EISCONN); v != FailureAlreadyConnected {
|
|
t.Fatalf("expected '%s', got '%s'", FailureAlreadyConnected, v)
|
|
}
|
|
})
|
|
|
|
t.Run("for EFAULT", func(t *testing.T) {
|
|
if v := classifySyscallError(unix.EFAULT); v != FailureBadAddress {
|
|
t.Fatalf("expected '%s', got '%s'", FailureBadAddress, v)
|
|
}
|
|
})
|
|
|
|
t.Run("for EBADF", func(t *testing.T) {
|
|
if v := classifySyscallError(unix.EBADF); v != FailureBadFileDescriptor {
|
|
t.Fatalf("expected '%s', got '%s'", FailureBadFileDescriptor, v)
|
|
}
|
|
})
|
|
|
|
t.Run("for ECONNABORTED", func(t *testing.T) {
|
|
if v := classifySyscallError(unix.ECONNABORTED); v != FailureConnectionAborted {
|
|
t.Fatalf("expected '%s', got '%s'", FailureConnectionAborted, v)
|
|
}
|
|
})
|
|
|
|
t.Run("for EALREADY", func(t *testing.T) {
|
|
if v := classifySyscallError(unix.EALREADY); v != FailureConnectionAlreadyInProgress {
|
|
t.Fatalf("expected '%s', got '%s'", FailureConnectionAlreadyInProgress, v)
|
|
}
|
|
})
|
|
|
|
t.Run("for EDESTADDRREQ", func(t *testing.T) {
|
|
if v := classifySyscallError(unix.EDESTADDRREQ); v != FailureDestinationAddressRequired {
|
|
t.Fatalf("expected '%s', got '%s'", FailureDestinationAddressRequired, v)
|
|
}
|
|
})
|
|
|
|
t.Run("for EINTR", func(t *testing.T) {
|
|
if v := classifySyscallError(unix.EINTR); v != FailureInterrupted {
|
|
t.Fatalf("expected '%s', got '%s'", FailureInterrupted, v)
|
|
}
|
|
})
|
|
|
|
t.Run("for EINVAL", func(t *testing.T) {
|
|
if v := classifySyscallError(unix.EINVAL); v != FailureInvalidArgument {
|
|
t.Fatalf("expected '%s', got '%s'", FailureInvalidArgument, v)
|
|
}
|
|
})
|
|
|
|
t.Run("for EMSGSIZE", func(t *testing.T) {
|
|
if v := classifySyscallError(unix.EMSGSIZE); v != FailureMessageSize {
|
|
t.Fatalf("expected '%s', got '%s'", FailureMessageSize, v)
|
|
}
|
|
})
|
|
|
|
t.Run("for ENETDOWN", func(t *testing.T) {
|
|
if v := classifySyscallError(unix.ENETDOWN); v != FailureNetworkDown {
|
|
t.Fatalf("expected '%s', got '%s'", FailureNetworkDown, v)
|
|
}
|
|
})
|
|
|
|
t.Run("for ENETRESET", func(t *testing.T) {
|
|
if v := classifySyscallError(unix.ENETRESET); v != FailureNetworkReset {
|
|
t.Fatalf("expected '%s', got '%s'", FailureNetworkReset, v)
|
|
}
|
|
})
|
|
|
|
t.Run("for ENETUNREACH", func(t *testing.T) {
|
|
if v := classifySyscallError(unix.ENETUNREACH); v != FailureNetworkUnreachable {
|
|
t.Fatalf("expected '%s', got '%s'", FailureNetworkUnreachable, v)
|
|
}
|
|
})
|
|
|
|
t.Run("for ENOBUFS", func(t *testing.T) {
|
|
if v := classifySyscallError(unix.ENOBUFS); v != FailureNoBufferSpace {
|
|
t.Fatalf("expected '%s', got '%s'", FailureNoBufferSpace, v)
|
|
}
|
|
})
|
|
|
|
t.Run("for ENOPROTOOPT", func(t *testing.T) {
|
|
if v := classifySyscallError(unix.ENOPROTOOPT); v != FailureNoProtocolOption {
|
|
t.Fatalf("expected '%s', got '%s'", FailureNoProtocolOption, v)
|
|
}
|
|
})
|
|
|
|
t.Run("for ENOTSOCK", func(t *testing.T) {
|
|
if v := classifySyscallError(unix.ENOTSOCK); v != FailureNotASocket {
|
|
t.Fatalf("expected '%s', got '%s'", FailureNotASocket, v)
|
|
}
|
|
})
|
|
|
|
t.Run("for ENOTCONN", func(t *testing.T) {
|
|
if v := classifySyscallError(unix.ENOTCONN); v != FailureNotConnected {
|
|
t.Fatalf("expected '%s', got '%s'", FailureNotConnected, v)
|
|
}
|
|
})
|
|
|
|
t.Run("for EWOULDBLOCK", func(t *testing.T) {
|
|
if v := classifySyscallError(unix.EWOULDBLOCK); v != FailureOperationWouldBlock {
|
|
t.Fatalf("expected '%s', got '%s'", FailureOperationWouldBlock, v)
|
|
}
|
|
})
|
|
|
|
t.Run("for EACCES", func(t *testing.T) {
|
|
if v := classifySyscallError(unix.EACCES); v != FailurePermissionDenied {
|
|
t.Fatalf("expected '%s', got '%s'", FailurePermissionDenied, v)
|
|
}
|
|
})
|
|
|
|
t.Run("for EPROTONOSUPPORT", func(t *testing.T) {
|
|
if v := classifySyscallError(unix.EPROTONOSUPPORT); v != FailureProtocolNotSupported {
|
|
t.Fatalf("expected '%s', got '%s'", FailureProtocolNotSupported, v)
|
|
}
|
|
})
|
|
|
|
t.Run("for EPROTOTYPE", func(t *testing.T) {
|
|
if v := classifySyscallError(unix.EPROTOTYPE); v != FailureWrongProtocolType {
|
|
t.Fatalf("expected '%s', got '%s'", FailureWrongProtocolType, v)
|
|
}
|
|
})
|
|
|
|
t.Run("for the zero errno value", func(t *testing.T) {
|
|
if v := classifySyscallError(syscall.Errno(0)); v != "" {
|
|
t.Fatalf("expected empty string, got '%s'", v)
|
|
}
|
|
})
|
|
}
|