forked from quic-go/quic-go
migrate the buffer pool tests away from Ginkgo (#4796)
This commit is contained in:
@@ -1,52 +1,38 @@
|
|||||||
package quic
|
package quic
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"testing"
|
||||||
|
|
||||||
"github.com/quic-go/quic-go/internal/protocol"
|
"github.com/quic-go/quic-go/internal/protocol"
|
||||||
|
|
||||||
. "github.com/onsi/ginkgo/v2"
|
"github.com/stretchr/testify/require"
|
||||||
. "github.com/onsi/gomega"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
var _ = Describe("Buffer Pool", func() {
|
func TestBufferPoolSizes(t *testing.T) {
|
||||||
It("returns buffers of cap", func() {
|
|
||||||
buf1 := getPacketBuffer()
|
buf1 := getPacketBuffer()
|
||||||
Expect(buf1.Data).To(HaveCap(protocol.MaxPacketBufferSize))
|
require.Equal(t, protocol.MaxPacketBufferSize, cap(buf1.Data))
|
||||||
buf2 := getLargePacketBuffer()
|
require.Zero(t, buf1.Len())
|
||||||
Expect(buf2.Data).To(HaveCap(protocol.MaxLargePacketBufferSize))
|
buf1.Data = append(buf1.Data, []byte("foobar")...)
|
||||||
})
|
require.Equal(t, protocol.ByteCount(6), buf1.Len())
|
||||||
|
|
||||||
It("releases buffers", func() {
|
buf2 := getLargePacketBuffer()
|
||||||
|
require.Equal(t, protocol.MaxLargePacketBufferSize, cap(buf2.Data))
|
||||||
|
require.Zero(t, buf2.Len())
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestBufferPoolRelease(t *testing.T) {
|
||||||
buf1 := getPacketBuffer()
|
buf1 := getPacketBuffer()
|
||||||
buf1.Release()
|
buf1.Release()
|
||||||
|
// panics if released twice
|
||||||
|
require.Panics(t, func() { buf1.Release() })
|
||||||
|
|
||||||
|
// panics if wrong-sized buffers are passed
|
||||||
buf2 := getLargePacketBuffer()
|
buf2 := getLargePacketBuffer()
|
||||||
buf2.Release()
|
buf2.Data = make([]byte, 10) // replace the underlying slice
|
||||||
})
|
require.Panics(t, func() { buf2.Release() })
|
||||||
|
}
|
||||||
|
|
||||||
It("gets the length", func() {
|
func TestBufferPoolSplitting(t *testing.T) {
|
||||||
buf := getPacketBuffer()
|
|
||||||
buf.Data = append(buf.Data, []byte("foobar")...)
|
|
||||||
Expect(buf.Len()).To(BeEquivalentTo(6))
|
|
||||||
})
|
|
||||||
|
|
||||||
It("panics if wrong-sized buffers are passed", func() {
|
|
||||||
buf := getPacketBuffer()
|
|
||||||
buf.Data = make([]byte, 10)
|
|
||||||
Expect(func() { buf.Release() }).To(Panic())
|
|
||||||
})
|
|
||||||
|
|
||||||
It("panics if it is released twice", func() {
|
|
||||||
buf := getPacketBuffer()
|
|
||||||
buf.Release()
|
|
||||||
Expect(func() { buf.Release() }).To(Panic())
|
|
||||||
})
|
|
||||||
|
|
||||||
It("panics if it is decremented too many times", func() {
|
|
||||||
buf := getPacketBuffer()
|
|
||||||
buf.Decrement()
|
|
||||||
Expect(func() { buf.Decrement() }).To(Panic())
|
|
||||||
})
|
|
||||||
|
|
||||||
It("waits until all parts have been released", func() {
|
|
||||||
buf := getPacketBuffer()
|
buf := getPacketBuffer()
|
||||||
buf.Split()
|
buf.Split()
|
||||||
buf.Split()
|
buf.Split()
|
||||||
@@ -54,6 +40,5 @@ var _ = Describe("Buffer Pool", func() {
|
|||||||
buf.Decrement()
|
buf.Decrement()
|
||||||
buf.Decrement()
|
buf.Decrement()
|
||||||
buf.Decrement()
|
buf.Decrement()
|
||||||
Expect(func() { buf.Decrement() }).To(Panic())
|
require.Panics(t, func() { buf.Decrement() })
|
||||||
})
|
}
|
||||||
})
|
|
||||||
|
|||||||
Reference in New Issue
Block a user