123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108 |
- // Minimalist test(s) to confirm that basic functionality works.
- package main
- import (
- "os"
- "testing"
- badger "github.com/dgraph-io/badger/v4"
- )
- func TestMinimalistSLKVDB(t *testing.T) {
- // Open the Badger database located in the /tmp/badger directory.
- // It will be created if it doesn't exist.
- // db, err := badger.Open(badger.DefaultOptions("/tmp/badger"))
- t.Log("Testing basic Badger functionality with a simple database read")
- db, err := badger.Open(badger.DefaultOptions("slkvdb/gosl-database.db"))
- if err != nil {
- t.Fatal(err)
- }
- defer func() {
- db.Close() // First close database,
- // then remove all the directories and files
- // Using RemoveAll() function
- if err = os.RemoveAll("slkvdb"); err != nil {
- t.Fatal(err)
- } else {
- t.Log("cleaning up test database successful")
- }
- }()
- err = db.Update(func(txn *badger.Txn) error {
- err = txn.Set([]byte("answer"), []byte("42"))
- return err
- })
- handle(t, err)
- err = db.View(func(txn *badger.Txn) error {
- item, err := txn.Get([]byte("answer"))
- handle(t, err)
- var valCopy []byte
- err = item.Value(func(val []byte) error {
- // This func with val would only be called if item.Value encounters no error.
- // Accessing val here is valid.
- t.Logf("(Inside item.Value()) The answer is: %q\n", val)
- // Copying or parsing val is valid.
- valCopy = append([]byte{}, val...)
- return nil
- })
- handle(t, err)
- // You must copy it to use it outside item.Value(...).
- t.Logf("(inside db.View()) The answer is: %q\n", valCopy)
- // Alternatively, you could also use item.ValueCopy().
- valCopy, err = item.ValueCopy(nil)
- handle(t, err)
- t.Logf("(inside db.View() using ValueCopy) The answer is: %s\n", valCopy)
- return nil
- })
- handle(t, err)
- }
- func TestRealDataseSLKVDB(t *testing.T) { // Open the Badger database located in the /tmp/badger directory.
- t.Log("Testing Badger functionality reading actual database (first 20 entries only)")
- db, err := badger.Open(badger.DefaultOptions("../slkvdb/gosl-database.db"))
- if err != nil {
- t.Fatal(err)
- }
- defer db.Close()
- err = db.View(func(txn *badger.Txn) error {
- opts := badger.DefaultIteratorOptions
- opts.PrefetchSize = 10
- it := txn.NewIterator(opts)
- defer it.Close()
- maxItems := 0 // to display only the first N entries (gwyneth 20211102)
- for it.Rewind(); it.Valid(); it.Next() {
- item := it.Item()
- k := item.Key()
- err := item.Value(func(v []byte) error {
- t.Logf("key=%s, value=%s\n", k, v)
- return nil
- })
- if err != nil {
- return err
- }
- if maxItems > 20 {
- break
- }
- maxItems++
- }
- t.Logf("%d item(s) read.\n", maxItems)
- return nil
- })
- handle(t, err)
- }
- // Handles errors for this very simple test.
- func handle(t *testing.T, err error) {
- if err != nil {
- t.Logf("error was: %q\n", err)
- }
- }
|