update mplex (#31)

This commit is contained in:
Marten Seemann 2022-03-04 10:56:56 +04:00 committed by GitHub
parent ce30ce884d
commit d6fc4be820
2 changed files with 46 additions and 1 deletions

View File

@ -18,5 +18,9 @@ var _ network.Multiplexer = &Transport{}
type Transport struct{}
func (t *Transport) NewConn(nc net.Conn, isServer bool, scope network.PeerScope) (network.MuxedConn, error) {
return (*conn)(mp.NewMultiplex(nc, isServer, scope)), nil
m, err := mp.NewMultiplex(nc, isServer, scope)
if err != nil {
return nil, err
}
return (*conn)(m), nil
}

View File

@ -1,11 +1,52 @@
package peerstream_multiplex
import (
"errors"
"net"
"testing"
"github.com/libp2p/go-libp2p-core/network"
test "github.com/libp2p/go-libp2p-testing/suites/mux"
)
func TestDefaultTransport(t *testing.T) {
test.SubtestAll(t, DefaultTransport)
}
type memoryScope struct {
network.PeerScope
limit int
reserved int
}
func (m *memoryScope) ReserveMemory(size int, prio uint8) error {
if m.reserved+size > m.limit {
return errors.New("too much")
}
m.reserved += size
return nil
}
func (m *memoryScope) ReleaseMemory(size int) {
m.reserved -= size
if m.reserved < 0 {
panic("too much memory released")
}
}
type memoryLimitedTransport struct {
Transport
}
func (t *memoryLimitedTransport) NewConn(nc net.Conn, isServer bool, scope network.PeerScope) (network.MuxedConn, error) {
return t.Transport.NewConn(nc, isServer, &memoryScope{
limit: 3 * 1 << 20,
PeerScope: scope,
})
}
func TestDefaultTransportWithMemoryLimit(t *testing.T) {
test.SubtestAll(t, &memoryLimitedTransport{
Transport: *DefaultTransport,
})
}