Skip to content

Commit

Permalink
Feat[pool]: Add new interfaces for compatibility (#19)
Browse files Browse the repository at this point in the history
  • Loading branch information
yunginnanet authored Oct 30, 2023
1 parent 7b5cdbe commit 90e4356
Show file tree
Hide file tree
Showing 2 changed files with 87 additions and 0 deletions.
19 changes: 19 additions & 0 deletions pool/interface.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
package pool

type Pool[T any] interface {
Get() T
Put(T)
}

type WithPutError[T any] interface {
Get() T
Put(T) error
}

type BufferFactoryInterfaceCompat struct {
BufferFactory
}

func (b BufferFactoryInterfaceCompat) Put(buf *Buffer) {
_ = b.BufferFactory.Put(buf)
}
68 changes: 68 additions & 0 deletions pool/interface_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,68 @@
package pool

import (
"bytes"
"sync"
"testing"
)

// ensure compatibility with interface
func TestInterfaces(t *testing.T) {
t.Parallel()
defer func() {
if r := recover(); r != nil {
t.Error("interface not implemented")
}
}()
var (
bf any = NewBufferFactory()
bfCompat any = BufferFactoryInterfaceCompat{NewBufferFactory()}
sPool any = &sync.Pool{
New: func() any { return new(bytes.Buffer) },
}
)
if _, ok := sPool.(Pool[any]); !ok {
t.Fatal("Pool[any] not implemented by sync.Pool")
}
testMe1, ok1 := bfCompat.(Pool[*Buffer])
if !ok1 {
t.Fatal("Pool[*Buffer] not implemented")
}

t.Run("Pool", func(t *testing.T) {
t.Parallel()
b := testMe1.Get()
if _, err := b.WriteString("test"); err != nil {
t.Fatal(err)
}
testMe1.Put(b)
b = testMe1.Get()
if b.Len() != 0 {
t.Fatal("buffer not reset")
}
testMe1.Put(b)
})

t.Run("PoolWithPutError", func(t *testing.T) {
t.Parallel()
testMe2, ok2 := bf.(WithPutError[*Buffer])
if !ok2 {
t.Error("PoolWithPutError[*Buffer] not implemented")
}
b := testMe2.Get()
if _, err := b.WriteString("test"); err != nil {
t.Fatal(err)
}
if err := testMe2.Put(b); err != nil {
t.Fatal(err)
}
b = testMe2.Get()
if b.Len() != 0 {
t.Fatal("buffer not reset")
}
if err := testMe2.Put(b); err != nil {
t.Fatal(err)
}
})

}

0 comments on commit 90e4356

Please sign in to comment.