mirror of
https://github.com/refraction-networking/uquic.git
synced 2025-04-04 04:37:36 +03:00
move GSO control message handling to the oobConn (#4056)
* move GSO control message handling to the oobConn * disable OOB test on Windows * improve GSO tests * update ooConn.WritePacket comment
This commit is contained in:
parent
d7334c16e7
commit
090e505aa9
15 changed files with 134 additions and 115 deletions
|
@ -3,6 +3,7 @@ package quic
|
|||
import (
|
||||
"net"
|
||||
"net/netip"
|
||||
"runtime"
|
||||
|
||||
"github.com/quic-go/quic-go/internal/utils"
|
||||
|
||||
|
@ -35,48 +36,43 @@ var _ = Describe("Connection (for sending packets)", func() {
|
|||
Expect(c.LocalAddr().String()).To(Equal("127.0.0.42:1234"))
|
||||
})
|
||||
|
||||
if platformSupportsGSO {
|
||||
It("writes with GSO", func() {
|
||||
// We're not using an OOB conn on windows, and packetInfo.OOB() always returns an empty slice.
|
||||
if runtime.GOOS != "windows" {
|
||||
It("sets the OOB", func() {
|
||||
rawConn := NewMockRawConn(mockCtrl)
|
||||
rawConn.EXPECT().LocalAddr()
|
||||
rawConn.EXPECT().capabilities().Return(connCapabilities{GSO: true}).AnyTimes()
|
||||
c := newSendConn(rawConn, remoteAddr, packetInfo{}, utils.DefaultLogger)
|
||||
rawConn.EXPECT().WritePacket([]byte("foobar"), remoteAddr, gomock.Any()).Do(func(_ []byte, _ net.Addr, oob []byte) {
|
||||
msg := appendUDPSegmentSizeMsg([]byte{}, 3)
|
||||
Expect(oob).To(Equal(msg))
|
||||
})
|
||||
Expect(c.Write([]byte("foobar"), 3)).To(Succeed())
|
||||
rawConn.EXPECT().capabilities().AnyTimes()
|
||||
pi := packetInfo{addr: netip.IPv6Loopback()}
|
||||
Expect(pi.OOB()).ToNot(BeEmpty())
|
||||
c := newSendConn(rawConn, remoteAddr, pi, utils.DefaultLogger)
|
||||
rawConn.EXPECT().WritePacket([]byte("foobar"), remoteAddr, pi.OOB(), uint16(0))
|
||||
Expect(c.Write([]byte("foobar"), 0)).To(Succeed())
|
||||
})
|
||||
}
|
||||
|
||||
It("disables GSO if writing fails", func() {
|
||||
It("writes", func() {
|
||||
rawConn := NewMockRawConn(mockCtrl)
|
||||
rawConn.EXPECT().LocalAddr()
|
||||
rawConn.EXPECT().capabilities().AnyTimes()
|
||||
c := newSendConn(rawConn, remoteAddr, packetInfo{}, utils.DefaultLogger)
|
||||
rawConn.EXPECT().WritePacket([]byte("foobar"), remoteAddr, gomock.Any(), uint16(3))
|
||||
Expect(c.Write([]byte("foobar"), 3)).To(Succeed())
|
||||
})
|
||||
|
||||
if platformSupportsGSO {
|
||||
It("disables GSO if sending fails", func() {
|
||||
rawConn := NewMockRawConn(mockCtrl)
|
||||
rawConn.EXPECT().LocalAddr()
|
||||
rawConn.EXPECT().capabilities().Return(connCapabilities{GSO: true}).AnyTimes()
|
||||
c := newSendConn(rawConn, remoteAddr, packetInfo{}, utils.DefaultLogger)
|
||||
Expect(c.capabilities().GSO).To(BeTrue())
|
||||
gomock.InOrder(
|
||||
rawConn.EXPECT().WritePacket([]byte("foobar"), remoteAddr, gomock.Any()).DoAndReturn(func(_ []byte, _ net.Addr, oob []byte) (int, error) {
|
||||
msg := appendUDPSegmentSizeMsg([]byte{}, 3)
|
||||
Expect(oob).To(Equal(msg))
|
||||
return 0, errGSO
|
||||
}),
|
||||
rawConn.EXPECT().WritePacket([]byte("foo"), remoteAddr, gomock.Len(0)).Return(3, nil),
|
||||
rawConn.EXPECT().WritePacket([]byte("bar"), remoteAddr, gomock.Len(0)).Return(3, nil),
|
||||
rawConn.EXPECT().WritePacket([]byte("foobar"), remoteAddr, gomock.Any(), uint16(4)).Return(0, errGSO),
|
||||
rawConn.EXPECT().WritePacket([]byte("foob"), remoteAddr, gomock.Any(), uint16(0)).Return(4, nil),
|
||||
rawConn.EXPECT().WritePacket([]byte("ar"), remoteAddr, gomock.Any(), uint16(0)).Return(2, nil),
|
||||
)
|
||||
Expect(c.Write([]byte("foobar"), 3)).To(Succeed())
|
||||
Expect(c.capabilities().GSO).To(BeFalse()) // GSO support is now disabled
|
||||
// make sure we actually enforce that
|
||||
Expect(func() { c.Write([]byte("foobar"), 3) }).To(PanicWith("inconsistent packet size (6 vs 3)"))
|
||||
})
|
||||
} else {
|
||||
It("writes without GSO", func() {
|
||||
remoteAddr := &net.UDPAddr{IP: net.IPv4(192, 168, 100, 200), Port: 1337}
|
||||
rawConn := NewMockRawConn(mockCtrl)
|
||||
rawConn.EXPECT().LocalAddr()
|
||||
rawConn.EXPECT().capabilities()
|
||||
c := newSendConn(rawConn, remoteAddr, packetInfo{}, utils.DefaultLogger)
|
||||
rawConn.EXPECT().WritePacket([]byte("foobar"), remoteAddr, gomock.Len(0))
|
||||
Expect(c.Write([]byte("foobar"), 6)).To(Succeed())
|
||||
Expect(c.Write([]byte("foobar"), 4)).To(Succeed())
|
||||
Expect(c.capabilities().GSO).To(BeFalse())
|
||||
})
|
||||
}
|
||||
})
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue