9816963355
* Move SudoPrivilege out of SystemView We only use this in token store and it literally doesn't work anything that isn't the token store or system mount, so we should stop exposing something that doesn't work. * Reconcile extended system view with sdk/logical a bit and put an explanation for why SudoPrivilege isn't moved over
214 lines
5.3 KiB
Go
214 lines
5.3 KiB
Go
package plugin
|
|
|
|
import (
|
|
"context"
|
|
"testing"
|
|
|
|
"google.golang.org/grpc"
|
|
|
|
"reflect"
|
|
|
|
"github.com/golang/protobuf/proto"
|
|
plugin "github.com/hashicorp/go-plugin"
|
|
"github.com/hashicorp/vault/sdk/helper/consts"
|
|
"github.com/hashicorp/vault/sdk/logical"
|
|
"github.com/hashicorp/vault/sdk/plugin/pb"
|
|
)
|
|
|
|
func TestSystem_GRPC_GRPC_impl(t *testing.T) {
|
|
var _ logical.SystemView = new(gRPCSystemViewClient)
|
|
}
|
|
|
|
func TestSystem_GRPC_defaultLeaseTTL(t *testing.T) {
|
|
sys := logical.TestSystemView()
|
|
client, _ := plugin.TestGRPCConn(t, func(s *grpc.Server) {
|
|
pb.RegisterSystemViewServer(s, &gRPCSystemViewServer{
|
|
impl: sys,
|
|
})
|
|
})
|
|
defer client.Close()
|
|
testSystemView := newGRPCSystemView(client)
|
|
|
|
expected := sys.DefaultLeaseTTL()
|
|
actual := testSystemView.DefaultLeaseTTL()
|
|
if !reflect.DeepEqual(expected, actual) {
|
|
t.Fatalf("expected: %v, got: %v", expected, actual)
|
|
}
|
|
}
|
|
|
|
func TestSystem_GRPC_maxLeaseTTL(t *testing.T) {
|
|
sys := logical.TestSystemView()
|
|
client, _ := plugin.TestGRPCConn(t, func(s *grpc.Server) {
|
|
pb.RegisterSystemViewServer(s, &gRPCSystemViewServer{
|
|
impl: sys,
|
|
})
|
|
})
|
|
defer client.Close()
|
|
testSystemView := newGRPCSystemView(client)
|
|
|
|
expected := sys.MaxLeaseTTL()
|
|
actual := testSystemView.MaxLeaseTTL()
|
|
if !reflect.DeepEqual(expected, actual) {
|
|
t.Fatalf("expected: %v, got: %v", expected, actual)
|
|
}
|
|
}
|
|
|
|
func TestSystem_GRPC_tainted(t *testing.T) {
|
|
sys := logical.TestSystemView()
|
|
sys.TaintedVal = true
|
|
client, _ := plugin.TestGRPCConn(t, func(s *grpc.Server) {
|
|
pb.RegisterSystemViewServer(s, &gRPCSystemViewServer{
|
|
impl: sys,
|
|
})
|
|
})
|
|
defer client.Close()
|
|
testSystemView := newGRPCSystemView(client)
|
|
|
|
expected := sys.Tainted()
|
|
actual := testSystemView.Tainted()
|
|
if !reflect.DeepEqual(expected, actual) {
|
|
t.Fatalf("expected: %v, got: %v", expected, actual)
|
|
}
|
|
}
|
|
|
|
func TestSystem_GRPC_cachingDisabled(t *testing.T) {
|
|
sys := logical.TestSystemView()
|
|
sys.CachingDisabledVal = true
|
|
client, _ := plugin.TestGRPCConn(t, func(s *grpc.Server) {
|
|
pb.RegisterSystemViewServer(s, &gRPCSystemViewServer{
|
|
impl: sys,
|
|
})
|
|
})
|
|
defer client.Close()
|
|
testSystemView := newGRPCSystemView(client)
|
|
|
|
expected := sys.CachingDisabled()
|
|
actual := testSystemView.CachingDisabled()
|
|
if !reflect.DeepEqual(expected, actual) {
|
|
t.Fatalf("expected: %v, got: %v", expected, actual)
|
|
}
|
|
}
|
|
|
|
func TestSystem_GRPC_replicationState(t *testing.T) {
|
|
sys := logical.TestSystemView()
|
|
sys.ReplicationStateVal = consts.ReplicationPerformancePrimary
|
|
client, _ := plugin.TestGRPCConn(t, func(s *grpc.Server) {
|
|
pb.RegisterSystemViewServer(s, &gRPCSystemViewServer{
|
|
impl: sys,
|
|
})
|
|
})
|
|
defer client.Close()
|
|
testSystemView := newGRPCSystemView(client)
|
|
|
|
expected := sys.ReplicationState()
|
|
actual := testSystemView.ReplicationState()
|
|
if !reflect.DeepEqual(expected, actual) {
|
|
t.Fatalf("expected: %v, got: %v", expected, actual)
|
|
}
|
|
}
|
|
|
|
func TestSystem_GRPC_responseWrapData(t *testing.T) {
|
|
t.SkipNow()
|
|
}
|
|
|
|
func TestSystem_GRPC_lookupPlugin(t *testing.T) {
|
|
sys := logical.TestSystemView()
|
|
client, _ := plugin.TestGRPCConn(t, func(s *grpc.Server) {
|
|
pb.RegisterSystemViewServer(s, &gRPCSystemViewServer{
|
|
impl: sys,
|
|
})
|
|
})
|
|
defer client.Close()
|
|
|
|
testSystemView := newGRPCSystemView(client)
|
|
|
|
if _, err := testSystemView.LookupPlugin(context.Background(), "foo", consts.PluginTypeDatabase); err == nil {
|
|
t.Fatal("LookPlugin(): expected error on due to unsupported call from plugin")
|
|
}
|
|
}
|
|
|
|
func TestSystem_GRPC_mlockEnabled(t *testing.T) {
|
|
sys := logical.TestSystemView()
|
|
sys.EnableMlock = true
|
|
client, _ := plugin.TestGRPCConn(t, func(s *grpc.Server) {
|
|
pb.RegisterSystemViewServer(s, &gRPCSystemViewServer{
|
|
impl: sys,
|
|
})
|
|
})
|
|
defer client.Close()
|
|
|
|
testSystemView := newGRPCSystemView(client)
|
|
|
|
expected := sys.MlockEnabled()
|
|
actual := testSystemView.MlockEnabled()
|
|
if !reflect.DeepEqual(expected, actual) {
|
|
t.Fatalf("expected: %v, got: %v", expected, actual)
|
|
}
|
|
}
|
|
|
|
func TestSystem_GRPC_entityInfo(t *testing.T) {
|
|
sys := logical.TestSystemView()
|
|
sys.EntityVal = &logical.Entity{
|
|
ID: "id",
|
|
Name: "name",
|
|
Metadata: map[string]string{
|
|
"foo": "bar",
|
|
},
|
|
Aliases: []*logical.Alias{
|
|
&logical.Alias{
|
|
MountType: "logical",
|
|
MountAccessor: "accessor",
|
|
Name: "name",
|
|
Metadata: map[string]string{
|
|
"zip": "zap",
|
|
},
|
|
},
|
|
},
|
|
Disabled: true,
|
|
}
|
|
client, _ := plugin.TestGRPCConn(t, func(s *grpc.Server) {
|
|
pb.RegisterSystemViewServer(s, &gRPCSystemViewServer{
|
|
impl: sys,
|
|
})
|
|
})
|
|
defer client.Close()
|
|
testSystemView := newGRPCSystemView(client)
|
|
|
|
actual, err := testSystemView.EntityInfo("")
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
if !proto.Equal(sys.EntityVal, actual) {
|
|
t.Fatalf("expected: %v, got: %v", sys.EntityVal, actual)
|
|
}
|
|
}
|
|
|
|
func TestSystem_GRPC_pluginEnv(t *testing.T) {
|
|
sys := logical.TestSystemView()
|
|
sys.PluginEnvironment = &logical.PluginEnvironment{
|
|
VaultVersion: "0.10.42",
|
|
}
|
|
client, _ := plugin.TestGRPCConn(t, func(s *grpc.Server) {
|
|
pb.RegisterSystemViewServer(s, &gRPCSystemViewServer{
|
|
impl: sys,
|
|
})
|
|
})
|
|
defer client.Close()
|
|
|
|
testSystemView := newGRPCSystemView(client)
|
|
|
|
expected, err := sys.PluginEnv(context.Background())
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
actual, err := testSystemView.PluginEnv(context.Background())
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
if !proto.Equal(expected, actual) {
|
|
t.Fatalf("expected: %v, got: %v", expected, actual)
|
|
}
|
|
}
|