aboutsummaryrefslogtreecommitdiff
path: root/cmd/bolt/export_test.go
diff options
context:
space:
mode:
authorBen Johnson <benbjohnson@yahoo.com>2014-04-11 14:31:34 -0600
committerBen Johnson <benbjohnson@yahoo.com>2014-04-11 14:31:34 -0600
commit714436100adf98a5132e6f4ddb3290231ff89dfd (patch)
tree8a9272322aa759b3d911d3698e6ec21cf71e78d7 /cmd/bolt/export_test.go
parentAdd nested buckets. (diff)
parentMerge pull request #128 from benbjohnson/import-export (diff)
downloaddedo-714436100adf98a5132e6f4ddb3290231ff89dfd.tar.gz
dedo-714436100adf98a5132e6f4ddb3290231ff89dfd.tar.xz
Merge branch 'master' into nested-keys
Conflicts: db_test.go tx_test.go
Diffstat (limited to 'cmd/bolt/export_test.go')
-rw-r--r--cmd/bolt/export_test.go37
1 files changed, 37 insertions, 0 deletions
diff --git a/cmd/bolt/export_test.go b/cmd/bolt/export_test.go
new file mode 100644
index 0000000..3d6c21a
--- /dev/null
+++ b/cmd/bolt/export_test.go
@@ -0,0 +1,37 @@
+package main_test
+
+import (
+ "testing"
+
+ "github.com/boltdb/bolt"
+ . "github.com/boltdb/bolt/cmd/bolt"
+ "github.com/stretchr/testify/assert"
+)
+
+// Ensure that a database can be exported.
+func TestExport(t *testing.T) {
+ SetTestMode(true)
+ open(func(db *bolt.DB, path string) {
+ db.Update(func(tx *bolt.Tx) error {
+ tx.CreateBucket("widgets")
+ b := tx.Bucket("widgets")
+ b.Put([]byte("foo"), []byte("0000"))
+ b.Put([]byte("bar"), []byte(""))
+
+ tx.CreateBucket("woojits")
+ b = tx.Bucket("woojits")
+ b.Put([]byte("baz"), []byte("XXXX"))
+ return nil
+ })
+ db.Close()
+ output := run("export", path)
+ assert.Equal(t, `[{"type":"bucket","key":"d2lkZ2V0cw==","value":[{"key":"YmFy","value":""},{"key":"Zm9v","value":"MDAwMA=="}]},{"type":"bucket","key":"d29vaml0cw==","value":[{"key":"YmF6","value":"WFhYWA=="}]}]`, output)
+ })
+}
+
+// Ensure that an error is reported if the database is not found.
+func TestExport_NotFound(t *testing.T) {
+ SetTestMode(true)
+ output := run("export", "no/such/db")
+ assert.Equal(t, "stat no/such/db: no such file or directory", output)
+}