open-vault/physical/etcd_test.go
Sean Chittenden aeea7628d6 Add a *log.Logger argument to physical.Factory
Logging in the backend is a good thing.  This is a noisy interface change but should be a functional noop.
2016-04-25 20:10:32 -07:00

67 lines
1.2 KiB
Go

package physical
import (
"fmt"
"log"
"os"
"testing"
"time"
"github.com/coreos/etcd/client"
"golang.org/x/net/context"
)
func TestEtcdBackend(t *testing.T) {
addr := os.Getenv("ETCD_ADDR")
if addr == "" {
t.SkipNow()
}
cfg := client.Config{
Endpoints: []string{addr},
Transport: client.DefaultTransport,
}
c, err := client.New(cfg)
if err != nil {
t.Fatalf("err: %s", err)
}
ctx, cancel := context.WithTimeout(context.Background(), client.DefaultRequestTimeout)
syncErr := c.Sync(ctx)
cancel()
if syncErr != nil {
t.Fatalf("err: %v", EtcdSyncClusterError)
}
kAPI := client.NewKeysAPI(c)
randPath := fmt.Sprintf("/vault-%d", time.Now().Unix())
defer func() {
delOpts := &client.DeleteOptions{
Recursive: true,
}
if _, err := kAPI.Delete(context.Background(), randPath, delOpts); err != nil {
t.Fatalf("err: %v", err)
}
}()
logger := log.New(os.Stderr, "", log.LstdFlags)
b, err := NewBackend("etcd", logger, map[string]string{
"address": addr,
"path": randPath,
})
if err != nil {
t.Fatalf("err: %s", err)
}
testBackend(t, b)
testBackend_ListPrefix(t, b)
ha, ok := b.(HABackend)
if !ok {
t.Fatalf("etcd does not implement HABackend")
}
testHABackend(t, ha, ha)
}