2015-03-18 00:05:18 +00:00
|
|
|
package framework
|
2015-03-18 00:03:00 +00:00
|
|
|
|
|
|
|
import (
|
|
|
|
"reflect"
|
|
|
|
"testing"
|
2015-03-18 00:05:18 +00:00
|
|
|
|
|
|
|
"github.com/hashicorp/vault/logical"
|
2015-03-18 00:03:00 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestWAL(t *testing.T) {
|
2015-03-18 00:05:18 +00:00
|
|
|
s := new(logical.InmemStorage)
|
2015-03-18 00:03:00 +00:00
|
|
|
|
|
|
|
// WAL should be empty to start
|
|
|
|
keys, err := ListWAL(s)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
if len(keys) > 0 {
|
|
|
|
t.Fatalf("bad: %#v", keys)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Write an entry to the WAL
|
2015-03-18 00:23:18 +00:00
|
|
|
id, err := PutWAL(s, "foo", "bar")
|
2015-03-18 00:03:00 +00:00
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
// The key should be in the WAL
|
|
|
|
keys, err = ListWAL(s)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
if !reflect.DeepEqual(keys, []string{id}) {
|
|
|
|
t.Fatalf("bad: %#v", keys)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Should be able to get the value
|
2015-03-18 00:58:05 +00:00
|
|
|
entry, err := GetWAL(s, id)
|
2015-03-18 00:03:00 +00:00
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
2015-03-18 00:58:05 +00:00
|
|
|
if entry.Kind != "foo" {
|
|
|
|
t.Fatalf("bad: %#v", entry)
|
2015-03-18 00:23:18 +00:00
|
|
|
}
|
2015-03-18 00:58:05 +00:00
|
|
|
if entry.Data != "bar" {
|
|
|
|
t.Fatalf("bad: %#v", entry)
|
2015-03-18 00:03:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Should be able to delete the value
|
|
|
|
if err := DeleteWAL(s, id); err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
2015-03-18 00:58:05 +00:00
|
|
|
entry, err = GetWAL(s, id)
|
2015-03-18 00:03:00 +00:00
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
2015-03-18 00:58:05 +00:00
|
|
|
if entry != nil {
|
|
|
|
t.Fatalf("bad: %#v", entry)
|
2015-03-18 00:03:00 +00:00
|
|
|
}
|
|
|
|
}
|