From 5c525089ff21f1830d1d5f0677463143fc7082fe Mon Sep 17 00:00:00 2001 From: ykadowak Date: Tue, 12 Sep 2023 01:38:41 +0000 Subject: [PATCH] changed key type to []byte --- internal/db/kvs/bbolt/bbolt.go | 26 +++++++++++--------------- internal/db/kvs/bbolt/bbolt_test.go | 12 ++++++------ 2 files changed, 17 insertions(+), 21 deletions(-) diff --git a/internal/db/kvs/bbolt/bbolt.go b/internal/db/kvs/bbolt/bbolt.go index 88d38aa17a..d89ca9fe80 100644 --- a/internal/db/kvs/bbolt/bbolt.go +++ b/internal/db/kvs/bbolt/bbolt.go @@ -15,19 +15,19 @@ type Bbolt struct { bucket string } -const default_bucket = "vald-bbolt-bucket" +const defaultBucket = "vald-bbolt-bucket" // New returns a new Bbolt instance. // If file does not exist, it creates a new file. If bucket is empty, it uses default_bucket. // If opts is nil, it uses default options. -func New(file string, bucket string, opts *bolt.Options) (*Bbolt, error) { +func New(file, bucket string, opts *bolt.Options) (*Bbolt, error) { db, err := bolt.Open(file, 0600, opts) if err != nil { return nil, err } if bucket == "" { - bucket = default_bucket + bucket = defaultBucket } db.Update(func(tx *bolt.Tx) error { _, err := tx.CreateBucket([]byte(bucket)) @@ -43,23 +43,19 @@ func New(file string, bucket string, opts *bolt.Options) (*Bbolt, error) { }, nil } -func (b *Bbolt) Set(key string, val []byte) error { - if err := b.db.Update(func(tx *bolt.Tx) error { +func (b *Bbolt) Set(key []byte, val []byte) error { + return b.db.Update(func(tx *bolt.Tx) error { b := tx.Bucket([]byte(b.bucket)) - err := b.Put([]byte(key), val) + err := b.Put(key, val) return err - }); err != nil { - return err - } - - return nil + }) } -func (b *Bbolt) Get(key string) ([]byte, bool, error) { +func (b *Bbolt) Get(key []byte) ([]byte, bool, error) { var val []byte if err := b.db.View(func(tx *bolt.Tx) error { b := tx.Bucket([]byte(b.bucket)) - ret := b.Get([]byte(key)) + ret := b.Get(key) if ret == nil { // key not found. just return without copying anything to val return nil @@ -83,14 +79,14 @@ func (b *Bbolt) Get(key string) ([]byte, bool, error) { // AsyncSet sets the key and value asynchronously for better write performance. // It accumulates the keys and values until the batch size is reached or the timeout comes, then // writes them all at once. Wait for the errgroup to make sure all the batches finished if required. -func (b *Bbolt) AsyncSet(eg *errgroup.Group, key string, val []byte) error { +func (b *Bbolt) AsyncSet(eg *errgroup.Group, key []byte, val []byte) error { if eg == nil { return errors.ErrNilErrGroup } (*eg).Go(func() error { b.db.Batch(func(tx *bolt.Tx) error { b := tx.Bucket([]byte(b.bucket)) - err := b.Put([]byte(key), val) + err := b.Put(key, val) return err }) return nil diff --git a/internal/db/kvs/bbolt/bbolt_test.go b/internal/db/kvs/bbolt/bbolt_test.go index 1e6664b112..cfc2edb3f6 100644 --- a/internal/db/kvs/bbolt/bbolt_test.go +++ b/internal/db/kvs/bbolt/bbolt_test.go @@ -19,15 +19,15 @@ func TestGetSetClose(t *testing.T) { b, err := bbolt.New(tmpfile, "", nil) require.NoError(t, err) - err = b.Set("key", []byte("value")) + err = b.Set([]byte("key"), []byte("value")) require.NoError(t, err) - val, ok, err := b.Get("key") + val, ok, err := b.Get([]byte("key")) require.NoError(t, err) require.True(t, ok) require.Equal(t, []byte("value"), val) - val, ok, err = b.Get("no exist key") + val, ok, err = b.Get([]byte("no exist key")) require.NoError(t, err) require.False(t, ok) require.Nil(t, val) @@ -39,7 +39,7 @@ func TestGetSetClose(t *testing.T) { require.NoError(t, err) // recover from the file - val, ok, err = b.Get("key") + val, ok, err = b.Get([]byte("key")) require.NoError(t, err) require.True(t, ok) require.Equal(t, []byte("value"), val) @@ -70,14 +70,14 @@ func TestAsyncSet(t *testing.T) { eg, _ := errgroup.New(context.Background()) for k, v := range kv { - b.AsyncSet(&eg, k, []byte(v)) + b.AsyncSet(&eg, []byte(k), []byte(v)) } // wait until all set is done eg.Wait() for k := range kv { - _, ok, err := b.Get(k) + _, ok, err := b.Get([]byte(k)) require.NoError(t, err) require.True(t, ok) }