b8428b302f
* refactor(netxlite): make sure we always use netmocks While there, improve logging and make sure we test 100% of the package with unit tests only. (We don't need to have integration testing in this package because it's fairly simple/obvious.) Part of https://github.com/ooni/probe/issues/1505 * further improve logs
61 lines
1.3 KiB
Go
61 lines
1.3 KiB
Go
package netxmocks
|
|
|
|
import (
|
|
"net"
|
|
"time"
|
|
)
|
|
|
|
// Conn is a mockable net.Conn.
|
|
type Conn struct {
|
|
MockRead func(b []byte) (int, error)
|
|
MockWrite func(b []byte) (int, error)
|
|
MockClose func() error
|
|
MockLocalAddr func() net.Addr
|
|
MockRemoteAddr func() net.Addr
|
|
MockSetDeadline func(t time.Time) error
|
|
MockSetReadDeadline func(t time.Time) error
|
|
MockSetWriteDeadline func(t time.Time) error
|
|
}
|
|
|
|
// Read calls MockRead.
|
|
func (c *Conn) Read(b []byte) (int, error) {
|
|
return c.MockRead(b)
|
|
}
|
|
|
|
// Write calls MockWrite.
|
|
func (c *Conn) Write(b []byte) (int, error) {
|
|
return c.MockWrite(b)
|
|
}
|
|
|
|
// Close calls MockClose.
|
|
func (c *Conn) Close() error {
|
|
return c.MockClose()
|
|
}
|
|
|
|
// LocalAddr class MockLocalAddr.
|
|
func (c *Conn) LocalAddr() net.Addr {
|
|
return c.MockLocalAddr()
|
|
}
|
|
|
|
// RemoteAddr calls MockRemoteAddr.
|
|
func (c *Conn) RemoteAddr() net.Addr {
|
|
return c.MockRemoteAddr()
|
|
}
|
|
|
|
// SetDeadline calls MockSetDeadline.
|
|
func (c *Conn) SetDeadline(t time.Time) error {
|
|
return c.MockSetDeadline(t)
|
|
}
|
|
|
|
// SetReadDeadline calls MockSetReadDeadline.
|
|
func (c *Conn) SetReadDeadline(t time.Time) error {
|
|
return c.MockSetReadDeadline(t)
|
|
}
|
|
|
|
// SetWriteDeadline calls MockSetWriteDeadline.
|
|
func (c *Conn) SetWriteDeadline(t time.Time) error {
|
|
return c.MockSetWriteDeadline(t)
|
|
}
|
|
|
|
var _ net.Conn = &Conn{}
|