aboutsummaryrefslogtreecommitdiff
path: root/internal/bufpool/buffers_test.go
diff options
context:
space:
mode:
authorGravatar Runxi Yu2025-11-22 08:00:00 +0800
committerGravatar Runxi Yu2025-11-22 08:00:00 +0800
commit10987664c3a92e6d7744f7dcfa1214b8e1063234 (patch)
tree9c3bd029d09730e6f24f816e7b8f090d52da3d43 /internal/bufpool/buffers_test.go
parentflatex: Reformat code (diff)
signatureNo signature
bufpool: Improve perf by using buckets of different size classes
Diffstat (limited to 'internal/bufpool/buffers_test.go')
-rw-r--r--internal/bufpool/buffers_test.go37
1 files changed, 37 insertions, 0 deletions
diff --git a/internal/bufpool/buffers_test.go b/internal/bufpool/buffers_test.go
index 87dbdd73..f5c006da 100644
--- a/internal/bufpool/buffers_test.go
+++ b/internal/bufpool/buffers_test.go
@@ -38,3 +38,40 @@ func TestBorrowBufferRelease(t *testing.T) {
t.Fatal("expected buffer cleared after release")
}
}
+
+func TestBorrowUsesLargerPools(t *testing.T) {
+ const request = DefaultBufferCap * 4
+
+ classIdx, classCap, pooled := classFor(request)
+ if !pooled {
+ t.Fatalf("expected %d to map to a pooled class", request)
+ }
+
+ b := Borrow(request)
+ if b.pool != poolIndex(classIdx) {
+ t.Fatalf("expected pooled buffer in class %d, got %d", classIdx, b.pool)
+ }
+ if cap(b.buf) != classCap {
+ t.Fatalf("expected capacity %d, got %d", classCap, cap(b.buf))
+ }
+ b.Release()
+
+ b2 := Borrow(request)
+ defer b2.Release()
+ if b2.pool != poolIndex(classIdx) {
+ t.Fatalf("expected pooled buffer in class %d on reuse, got %d", classIdx, b2.pool)
+ }
+ if cap(b2.buf) != classCap {
+ t.Fatalf("expected capacity %d on reuse, got %d", classCap, cap(b2.buf))
+ }
+}
+
+func TestGrowingBufferStaysPooled(t *testing.T) {
+ b := Borrow(DefaultBufferCap)
+ defer b.Release()
+
+ b.Append(make([]byte, DefaultBufferCap*3))
+ if b.pool == unpooled {
+ t.Fatal("buffer should stay pooled after growth within limit")
+ }
+}