2017-08-03 17:24:27 +00:00
|
|
|
package etcd
|
2015-05-24 16:38:49 +00:00
|
|
|
|
|
|
|
import (
|
2018-07-13 14:59:34 +00:00
|
|
|
"context"
|
2015-05-24 16:38:49 +00:00
|
|
|
"fmt"
|
|
|
|
"os"
|
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
2018-04-03 00:46:59 +00:00
|
|
|
log "github.com/hashicorp/go-hclog"
|
|
|
|
"github.com/hashicorp/vault/helper/logging"
|
2017-08-03 17:24:27 +00:00
|
|
|
"github.com/hashicorp/vault/physical"
|
2016-08-19 20:45:17 +00:00
|
|
|
|
2015-11-16 06:12:06 +00:00
|
|
|
"github.com/coreos/etcd/client"
|
2015-05-24 16:38:49 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestEtcdBackend(t *testing.T) {
|
|
|
|
addr := os.Getenv("ETCD_ADDR")
|
|
|
|
if addr == "" {
|
|
|
|
t.SkipNow()
|
|
|
|
}
|
|
|
|
|
2015-11-16 06:12:06 +00:00
|
|
|
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 {
|
2015-05-24 16:38:49 +00:00
|
|
|
t.Fatalf("err: %v", EtcdSyncClusterError)
|
|
|
|
}
|
|
|
|
|
2015-11-16 06:12:06 +00:00
|
|
|
kAPI := client.NewKeysAPI(c)
|
|
|
|
|
2015-05-24 16:38:49 +00:00
|
|
|
randPath := fmt.Sprintf("/vault-%d", time.Now().Unix())
|
|
|
|
defer func() {
|
2015-11-16 06:12:06 +00:00
|
|
|
delOpts := &client.DeleteOptions{
|
|
|
|
Recursive: true,
|
|
|
|
}
|
|
|
|
if _, err := kAPI.Delete(context.Background(), randPath, delOpts); err != nil {
|
2015-05-24 16:38:49 +00:00
|
|
|
t.Fatalf("err: %v", err)
|
|
|
|
}
|
|
|
|
}()
|
|
|
|
|
2016-06-30 18:46:00 +00:00
|
|
|
// Generate new etcd backend. The etcd address is read from ETCD_ADDR. No
|
2016-06-30 19:10:15 +00:00
|
|
|
// need to provide it explicitly.
|
2018-04-03 00:46:59 +00:00
|
|
|
logger := logging.NewVaultLogger(log.Debug)
|
2018-11-01 17:31:09 +00:00
|
|
|
config := map[string]string{
|
2016-06-30 18:46:00 +00:00
|
|
|
"path": randPath,
|
2018-11-01 17:31:09 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
b, err := NewEtcdBackend(config, logger)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
b2, err := NewEtcdBackend(config, logger)
|
2015-05-24 16:38:49 +00:00
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
|
2017-08-03 17:24:27 +00:00
|
|
|
physical.ExerciseBackend(t, b)
|
|
|
|
physical.ExerciseBackend_ListPrefix(t, b)
|
2018-11-01 17:31:09 +00:00
|
|
|
physical.ExerciseHABackend(t, b.(physical.HABackend), b2.(physical.HABackend))
|
2015-05-24 16:38:49 +00:00
|
|
|
}
|