diff options
author | Ben Johnson <benbjohnson@yahoo.com> | 2014-03-27 22:36:05 -0600 |
---|---|---|
committer | Ben Johnson <benbjohnson@yahoo.com> | 2014-03-27 22:36:05 -0600 |
commit | fea388b03d67a26a6bb13e9b9363b15e72b7f2c5 (patch) | |
tree | f05305e130e8dba68d82eb5537accf9502b3ed51 /cmd/bolt/set_test.go | |
parent | Merge pull request #92 from benbjohnson/safe-copy (diff) | |
download | dedo-fea388b03d67a26a6bb13e9b9363b15e72b7f2c5.tar.gz dedo-fea388b03d67a26a6bb13e9b9363b15e72b7f2c5.tar.xz |
Refactor bolt commands into individual files.
Diffstat (limited to 'cmd/bolt/set_test.go')
-rw-r--r-- | cmd/bolt/set_test.go | 38 |
1 files changed, 38 insertions, 0 deletions
diff --git a/cmd/bolt/set_test.go b/cmd/bolt/set_test.go new file mode 100644 index 0000000..d76b3c0 --- /dev/null +++ b/cmd/bolt/set_test.go @@ -0,0 +1,38 @@ +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 set from the CLI. +func TestSet(t *testing.T) { + SetTestMode(true) + open(func(db *bolt.DB) { + db.Update(func(tx *bolt.Tx) error { + tx.CreateBucket("widgets") + return nil + }) + assert.Equal(t, "", run("set", db.Path(), "widgets", "foo", "bar")) + assert.Equal(t, "bar", run("get", db.Path(), "widgets", "foo")) + }) +} + +// Ensure that an error is reported if the database is not found. +func TestSetDBNotFound(t *testing.T) { + SetTestMode(true) + output := run("set", "no/such/db", "widgets", "foo", "bar") + 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 TestSetBucketNotFound(t *testing.T) { + SetTestMode(true) + open(func(db *bolt.DB) { + output := run("set", db.Path(), "widgets", "foo", "bar") + assert.Equal(t, "bucket not found: widgets", output) + }) +} |