aboutsummaryrefslogtreecommitdiff
path: root/cmd/bolt/get_test.go
diff options
context:
space:
mode:
authorBen Johnson <benbjohnson@yahoo.com>2014-03-27 22:36:05 -0600
committerBen Johnson <benbjohnson@yahoo.com>2014-03-27 22:36:05 -0600
commitfea388b03d67a26a6bb13e9b9363b15e72b7f2c5 (patch)
treef05305e130e8dba68d82eb5537accf9502b3ed51 /cmd/bolt/get_test.go
parentMerge pull request #92 from benbjohnson/safe-copy (diff)
downloaddedo-fea388b03d67a26a6bb13e9b9363b15e72b7f2c5.tar.gz
dedo-fea388b03d67a26a6bb13e9b9363b15e72b7f2c5.tar.xz
Refactor bolt commands into individual files.
Diffstat (limited to 'cmd/bolt/get_test.go')
-rw-r--r--cmd/bolt/get_test.go51
1 files changed, 51 insertions, 0 deletions
diff --git a/cmd/bolt/get_test.go b/cmd/bolt/get_test.go
new file mode 100644
index 0000000..4498086
--- /dev/null
+++ b/cmd/bolt/get_test.go
@@ -0,0 +1,51 @@
+package main_test
+
+import (
+ "testing"
+
+ "github.com/boltdb/bolt"
+ . "github.com/boltdb/bolt/cmd/bolt"
+ "github.com/stretchr/testify/assert"
+)
+
+// Ensure that a value can be retrieved from the CLI.
+func TestGet(t *testing.T) {
+ SetTestMode(true)
+ open(func(db *bolt.DB) {
+ db.Update(func(tx *bolt.Tx) error {
+ tx.CreateBucket("widgets")
+ tx.Bucket("widgets").Put([]byte("foo"), []byte("bar"))
+ return nil
+ })
+ output := run("get", db.Path(), "widgets", "foo")
+ assert.Equal(t, "bar", output)
+ })
+}
+
+// Ensure that an error is reported if the database is not found.
+func TestGetDBNotFound(t *testing.T) {
+ SetTestMode(true)
+ output := run("get", "no/such/db", "widgets", "foo")
+ assert.Equal(t, "stat no/such/db: no such file or directory", output)
+}
+
+// Ensure that an error is reported if the bucket is not found.
+func TestGetBucketNotFound(t *testing.T) {
+ SetTestMode(true)
+ open(func(db *bolt.DB) {
+ output := run("get", db.Path(), "widgets", "foo")
+ assert.Equal(t, "bucket not found: widgets", output)
+ })
+}
+
+// Ensure that an error is reported if the key is not found.
+func TestGetKeyNotFound(t *testing.T) {
+ SetTestMode(true)
+ open(func(db *bolt.DB) {
+ db.Update(func(tx *bolt.Tx) error {
+ return tx.CreateBucket("widgets")
+ })
+ output := run("get", db.Path(), "widgets", "foo")
+ assert.Equal(t, "key not found: foo", output)
+ })
+}