2017-02-23 22:02:53 +00:00
|
|
|
|
package enterprise_test
|
2017-02-21 19:28:54 +00:00
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"context"
|
|
|
|
|
"fmt"
|
|
|
|
|
"reflect"
|
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
|
|
"github.com/influxdata/chronograf"
|
2017-02-23 22:02:53 +00:00
|
|
|
|
"github.com/influxdata/chronograf/enterprise"
|
2017-02-21 19:28:54 +00:00
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
func TestClient_Add(t *testing.T) {
|
|
|
|
|
type fields struct {
|
|
|
|
|
Ctrl *mockCtrl
|
|
|
|
|
Logger chronograf.Logger
|
|
|
|
|
}
|
|
|
|
|
type args struct {
|
|
|
|
|
ctx context.Context
|
|
|
|
|
u *chronograf.User
|
|
|
|
|
}
|
|
|
|
|
tests := []struct {
|
|
|
|
|
name string
|
|
|
|
|
fields fields
|
|
|
|
|
args args
|
|
|
|
|
want *chronograf.User
|
|
|
|
|
wantErr bool
|
|
|
|
|
}{
|
|
|
|
|
{
|
|
|
|
|
name: "Successful Create User",
|
|
|
|
|
fields: fields{
|
|
|
|
|
Ctrl: &mockCtrl{
|
|
|
|
|
createUser: func(ctx context.Context, name, passwd string) error {
|
|
|
|
|
return nil
|
|
|
|
|
},
|
2017-02-24 07:16:28 +00:00
|
|
|
|
setUserPerms: func(ctx context.Context, name string, perms enterprise.Permissions) error {
|
|
|
|
|
return nil
|
|
|
|
|
},
|
2017-03-10 19:24:48 +00:00
|
|
|
|
user: func(ctx context.Context, name string) (*enterprise.User, error) {
|
|
|
|
|
return &enterprise.User{
|
|
|
|
|
Name: "marty",
|
|
|
|
|
Password: "johnny be good",
|
|
|
|
|
Permissions: map[string][]string{
|
|
|
|
|
"": {
|
|
|
|
|
"ViewChronograf",
|
|
|
|
|
"ReadData",
|
|
|
|
|
"WriteData",
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
}, nil
|
|
|
|
|
},
|
|
|
|
|
userRoles: func(ctx context.Context) (map[string]enterprise.Roles, error) {
|
|
|
|
|
return map[string]enterprise.Roles{}, nil
|
|
|
|
|
},
|
2017-02-21 19:28:54 +00:00
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
args: args{
|
|
|
|
|
ctx: context.Background(),
|
|
|
|
|
u: &chronograf.User{
|
|
|
|
|
Name: "marty",
|
|
|
|
|
Passwd: "johnny be good",
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
want: &chronograf.User{
|
2017-03-10 19:24:48 +00:00
|
|
|
|
Name: "marty",
|
|
|
|
|
Permissions: chronograf.Permissions{
|
|
|
|
|
{
|
|
|
|
|
Scope: chronograf.AllScope,
|
|
|
|
|
Allowed: chronograf.Allowances{"ViewChronograf", "ReadData", "WriteData"},
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
Roles: []chronograf.Role{},
|
2017-02-21 19:28:54 +00:00
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
name: "Failure to Create User",
|
|
|
|
|
fields: fields{
|
|
|
|
|
Ctrl: &mockCtrl{
|
|
|
|
|
createUser: func(ctx context.Context, name, passwd string) error {
|
|
|
|
|
return fmt.Errorf("1.21 Gigawatts! Tom, how could I have been so careless?")
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
args: args{
|
|
|
|
|
ctx: context.Background(),
|
|
|
|
|
u: &chronograf.User{
|
|
|
|
|
Name: "marty",
|
|
|
|
|
Passwd: "johnny be good",
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
wantErr: true,
|
|
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
for _, tt := range tests {
|
2017-02-23 22:02:53 +00:00
|
|
|
|
c := &enterprise.UserStore{
|
2017-02-21 19:28:54 +00:00
|
|
|
|
Ctrl: tt.fields.Ctrl,
|
|
|
|
|
Logger: tt.fields.Logger,
|
|
|
|
|
}
|
|
|
|
|
got, err := c.Add(tt.args.ctx, tt.args.u)
|
|
|
|
|
if (err != nil) != tt.wantErr {
|
|
|
|
|
t.Errorf("%q. Client.Add() error = %v, wantErr %v", tt.name, err, tt.wantErr)
|
|
|
|
|
continue
|
|
|
|
|
}
|
|
|
|
|
if !reflect.DeepEqual(got, tt.want) {
|
|
|
|
|
t.Errorf("%q. Client.Add() = %v, want %v", tt.name, got, tt.want)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestClient_Delete(t *testing.T) {
|
|
|
|
|
type fields struct {
|
|
|
|
|
Ctrl *mockCtrl
|
|
|
|
|
Logger chronograf.Logger
|
|
|
|
|
}
|
|
|
|
|
type args struct {
|
|
|
|
|
ctx context.Context
|
|
|
|
|
u *chronograf.User
|
|
|
|
|
}
|
|
|
|
|
tests := []struct {
|
|
|
|
|
name string
|
|
|
|
|
fields fields
|
|
|
|
|
args args
|
|
|
|
|
wantErr bool
|
|
|
|
|
}{
|
|
|
|
|
{
|
|
|
|
|
name: "Successful Delete User",
|
|
|
|
|
fields: fields{
|
|
|
|
|
Ctrl: &mockCtrl{
|
|
|
|
|
deleteUser: func(ctx context.Context, name string) error {
|
|
|
|
|
return nil
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
args: args{
|
|
|
|
|
ctx: context.Background(),
|
|
|
|
|
u: &chronograf.User{
|
|
|
|
|
Name: "marty",
|
|
|
|
|
Passwd: "johnny be good",
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
name: "Failure to Delete User",
|
|
|
|
|
fields: fields{
|
|
|
|
|
Ctrl: &mockCtrl{
|
|
|
|
|
deleteUser: func(ctx context.Context, name string) error {
|
|
|
|
|
return fmt.Errorf("1.21 Gigawatts! Tom, how could I have been so careless?")
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
args: args{
|
|
|
|
|
ctx: context.Background(),
|
|
|
|
|
u: &chronograf.User{
|
|
|
|
|
Name: "marty",
|
|
|
|
|
Passwd: "johnny be good",
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
wantErr: true,
|
|
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
for _, tt := range tests {
|
2017-02-23 22:02:53 +00:00
|
|
|
|
c := &enterprise.UserStore{
|
2017-02-21 19:28:54 +00:00
|
|
|
|
Ctrl: tt.fields.Ctrl,
|
|
|
|
|
Logger: tt.fields.Logger,
|
|
|
|
|
}
|
|
|
|
|
if err := c.Delete(tt.args.ctx, tt.args.u); (err != nil) != tt.wantErr {
|
|
|
|
|
t.Errorf("%q. Client.Delete() error = %v, wantErr %v", tt.name, err, tt.wantErr)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestClient_Get(t *testing.T) {
|
|
|
|
|
type fields struct {
|
2017-02-23 22:02:53 +00:00
|
|
|
|
Ctrl *mockCtrl
|
|
|
|
|
Logger chronograf.Logger
|
2017-02-21 19:28:54 +00:00
|
|
|
|
}
|
|
|
|
|
type args struct {
|
|
|
|
|
ctx context.Context
|
|
|
|
|
name string
|
|
|
|
|
}
|
|
|
|
|
tests := []struct {
|
|
|
|
|
name string
|
|
|
|
|
fields fields
|
|
|
|
|
args args
|
|
|
|
|
want *chronograf.User
|
|
|
|
|
wantErr bool
|
|
|
|
|
}{
|
|
|
|
|
{
|
|
|
|
|
name: "Successful Get User",
|
|
|
|
|
fields: fields{
|
|
|
|
|
Ctrl: &mockCtrl{
|
2017-02-23 22:02:53 +00:00
|
|
|
|
user: func(ctx context.Context, name string) (*enterprise.User, error) {
|
|
|
|
|
return &enterprise.User{
|
2017-02-21 19:28:54 +00:00
|
|
|
|
Name: "marty",
|
|
|
|
|
Password: "johnny be good",
|
|
|
|
|
Permissions: map[string][]string{
|
|
|
|
|
"": {
|
|
|
|
|
"ViewChronograf",
|
|
|
|
|
"ReadData",
|
|
|
|
|
"WriteData",
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
}, nil
|
|
|
|
|
},
|
2017-03-02 01:13:44 +00:00
|
|
|
|
userRoles: func(ctx context.Context) (map[string]enterprise.Roles, error) {
|
|
|
|
|
return map[string]enterprise.Roles{}, nil
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
args: args{
|
|
|
|
|
ctx: context.Background(),
|
|
|
|
|
name: "marty",
|
|
|
|
|
},
|
|
|
|
|
want: &chronograf.User{
|
|
|
|
|
Name: "marty",
|
|
|
|
|
Permissions: chronograf.Permissions{
|
|
|
|
|
{
|
|
|
|
|
Scope: chronograf.AllScope,
|
|
|
|
|
Allowed: chronograf.Allowances{"ViewChronograf", "ReadData", "WriteData"},
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
Roles: []chronograf.Role{},
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
name: "Successful Get User with roles",
|
|
|
|
|
fields: fields{
|
|
|
|
|
Ctrl: &mockCtrl{
|
|
|
|
|
user: func(ctx context.Context, name string) (*enterprise.User, error) {
|
|
|
|
|
return &enterprise.User{
|
|
|
|
|
Name: "marty",
|
|
|
|
|
Password: "johnny be good",
|
|
|
|
|
Permissions: map[string][]string{
|
|
|
|
|
"": {
|
|
|
|
|
"ViewChronograf",
|
|
|
|
|
"ReadData",
|
|
|
|
|
"WriteData",
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
}, nil
|
|
|
|
|
},
|
|
|
|
|
userRoles: func(ctx context.Context) (map[string]enterprise.Roles, error) {
|
|
|
|
|
return map[string]enterprise.Roles{
|
|
|
|
|
"marty": enterprise.Roles{
|
|
|
|
|
Roles: []enterprise.Role{
|
|
|
|
|
{
|
|
|
|
|
Name: "timetravels",
|
|
|
|
|
Permissions: map[string][]string{
|
|
|
|
|
"": {
|
|
|
|
|
"ViewChronograf",
|
|
|
|
|
"ReadData",
|
|
|
|
|
"WriteData",
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
Users: []string{"marty", "docbrown"},
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
}, nil
|
|
|
|
|
},
|
2017-02-21 19:28:54 +00:00
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
args: args{
|
|
|
|
|
ctx: context.Background(),
|
|
|
|
|
name: "marty",
|
|
|
|
|
},
|
|
|
|
|
want: &chronograf.User{
|
|
|
|
|
Name: "marty",
|
|
|
|
|
Permissions: chronograf.Permissions{
|
|
|
|
|
{
|
|
|
|
|
Scope: chronograf.AllScope,
|
|
|
|
|
Allowed: chronograf.Allowances{"ViewChronograf", "ReadData", "WriteData"},
|
|
|
|
|
},
|
|
|
|
|
},
|
2017-03-02 01:13:44 +00:00
|
|
|
|
Roles: []chronograf.Role{
|
|
|
|
|
{
|
|
|
|
|
Name: "timetravels",
|
|
|
|
|
Permissions: chronograf.Permissions{
|
|
|
|
|
{
|
|
|
|
|
Scope: chronograf.AllScope,
|
|
|
|
|
Allowed: chronograf.Allowances{"ViewChronograf", "ReadData", "WriteData"},
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
Users: []chronograf.User{},
|
|
|
|
|
},
|
|
|
|
|
},
|
2017-02-21 19:28:54 +00:00
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
name: "Failure to get User",
|
|
|
|
|
fields: fields{
|
|
|
|
|
Ctrl: &mockCtrl{
|
2017-02-23 22:02:53 +00:00
|
|
|
|
user: func(ctx context.Context, name string) (*enterprise.User, error) {
|
2017-02-21 19:28:54 +00:00
|
|
|
|
return nil, fmt.Errorf("1.21 Gigawatts! Tom, how could I have been so careless?")
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
args: args{
|
|
|
|
|
ctx: context.Background(),
|
|
|
|
|
name: "marty",
|
|
|
|
|
},
|
|
|
|
|
wantErr: true,
|
|
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
for _, tt := range tests {
|
2017-02-23 22:02:53 +00:00
|
|
|
|
c := &enterprise.UserStore{
|
|
|
|
|
Ctrl: tt.fields.Ctrl,
|
|
|
|
|
Logger: tt.fields.Logger,
|
2017-02-21 19:28:54 +00:00
|
|
|
|
}
|
|
|
|
|
got, err := c.Get(tt.args.ctx, tt.args.name)
|
|
|
|
|
if (err != nil) != tt.wantErr {
|
|
|
|
|
t.Errorf("%q. Client.Get() error = %v, wantErr %v", tt.name, err, tt.wantErr)
|
|
|
|
|
continue
|
|
|
|
|
}
|
|
|
|
|
if !reflect.DeepEqual(got, tt.want) {
|
|
|
|
|
t.Errorf("%q. Client.Get() = %v, want %v", tt.name, got, tt.want)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestClient_Update(t *testing.T) {
|
|
|
|
|
type fields struct {
|
|
|
|
|
Ctrl *mockCtrl
|
|
|
|
|
Logger chronograf.Logger
|
|
|
|
|
}
|
|
|
|
|
type args struct {
|
|
|
|
|
ctx context.Context
|
|
|
|
|
u *chronograf.User
|
|
|
|
|
}
|
|
|
|
|
tests := []struct {
|
|
|
|
|
name string
|
|
|
|
|
fields fields
|
|
|
|
|
args args
|
|
|
|
|
wantErr bool
|
|
|
|
|
}{
|
|
|
|
|
{
|
|
|
|
|
name: "Successful Change Password",
|
|
|
|
|
fields: fields{
|
|
|
|
|
Ctrl: &mockCtrl{
|
|
|
|
|
changePassword: func(ctx context.Context, name, passwd string) error {
|
|
|
|
|
return nil
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
args: args{
|
|
|
|
|
ctx: context.Background(),
|
|
|
|
|
u: &chronograf.User{
|
|
|
|
|
Name: "marty",
|
|
|
|
|
Passwd: "johnny be good",
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
name: "Failure to Change Password",
|
|
|
|
|
fields: fields{
|
|
|
|
|
Ctrl: &mockCtrl{
|
|
|
|
|
changePassword: func(ctx context.Context, name, passwd string) error {
|
|
|
|
|
return fmt.Errorf("Ronald Reagan, the actor?! Ha Then who’s Vice President Jerry Lewis? I suppose Jane Wyman is First Lady")
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
args: args{
|
|
|
|
|
ctx: context.Background(),
|
|
|
|
|
u: &chronograf.User{
|
|
|
|
|
Name: "marty",
|
|
|
|
|
Passwd: "johnny be good",
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
wantErr: true,
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
name: "Success setting permissions User",
|
|
|
|
|
fields: fields{
|
|
|
|
|
Ctrl: &mockCtrl{
|
2017-02-23 22:02:53 +00:00
|
|
|
|
setUserPerms: func(ctx context.Context, name string, perms enterprise.Permissions) error {
|
2017-02-21 19:28:54 +00:00
|
|
|
|
return nil
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
args: args{
|
|
|
|
|
ctx: context.Background(),
|
|
|
|
|
u: &chronograf.User{
|
|
|
|
|
Name: "marty",
|
|
|
|
|
Permissions: chronograf.Permissions{
|
|
|
|
|
{
|
|
|
|
|
Scope: chronograf.AllScope,
|
|
|
|
|
Allowed: chronograf.Allowances{"ViewChronograf", "KapacitorAPI"},
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
wantErr: false,
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
name: "Failure setting permissions User",
|
|
|
|
|
fields: fields{
|
|
|
|
|
Ctrl: &mockCtrl{
|
2017-02-23 22:02:53 +00:00
|
|
|
|
setUserPerms: func(ctx context.Context, name string, perms enterprise.Permissions) error {
|
2017-02-21 19:28:54 +00:00
|
|
|
|
return fmt.Errorf("They found me, I don't know how, but they found me.")
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
args: args{
|
|
|
|
|
ctx: context.Background(),
|
|
|
|
|
u: &chronograf.User{
|
|
|
|
|
Name: "marty",
|
|
|
|
|
Permissions: chronograf.Permissions{
|
|
|
|
|
{
|
|
|
|
|
Scope: chronograf.AllScope,
|
|
|
|
|
Allowed: chronograf.Allowances{"ViewChronograf", "KapacitorAPI"},
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
wantErr: true,
|
|
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
for _, tt := range tests {
|
2017-02-23 22:02:53 +00:00
|
|
|
|
c := &enterprise.UserStore{
|
2017-02-21 19:28:54 +00:00
|
|
|
|
Ctrl: tt.fields.Ctrl,
|
|
|
|
|
Logger: tt.fields.Logger,
|
|
|
|
|
}
|
|
|
|
|
if err := c.Update(tt.args.ctx, tt.args.u); (err != nil) != tt.wantErr {
|
|
|
|
|
t.Errorf("%q. Client.Update() error = %v, wantErr %v", tt.name, err, tt.wantErr)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestClient_All(t *testing.T) {
|
|
|
|
|
type fields struct {
|
|
|
|
|
Ctrl *mockCtrl
|
|
|
|
|
Logger chronograf.Logger
|
|
|
|
|
}
|
|
|
|
|
type args struct {
|
|
|
|
|
ctx context.Context
|
|
|
|
|
}
|
|
|
|
|
tests := []struct {
|
|
|
|
|
name string
|
|
|
|
|
fields fields
|
|
|
|
|
args args
|
|
|
|
|
want []chronograf.User
|
|
|
|
|
wantErr bool
|
|
|
|
|
}{
|
|
|
|
|
{
|
|
|
|
|
name: "Successful Get User",
|
|
|
|
|
fields: fields{
|
|
|
|
|
Ctrl: &mockCtrl{
|
2017-02-23 22:02:53 +00:00
|
|
|
|
users: func(ctx context.Context, name *string) (*enterprise.Users, error) {
|
|
|
|
|
return &enterprise.Users{
|
|
|
|
|
Users: []enterprise.User{
|
2017-02-21 19:28:54 +00:00
|
|
|
|
{
|
|
|
|
|
Name: "marty",
|
|
|
|
|
Password: "johnny be good",
|
|
|
|
|
Permissions: map[string][]string{
|
|
|
|
|
"": {
|
|
|
|
|
"ViewChronograf",
|
|
|
|
|
"ReadData",
|
|
|
|
|
"WriteData",
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
}, nil
|
|
|
|
|
},
|
2017-03-02 01:13:44 +00:00
|
|
|
|
userRoles: func(ctx context.Context) (map[string]enterprise.Roles, error) {
|
|
|
|
|
return map[string]enterprise.Roles{}, nil
|
|
|
|
|
},
|
2017-02-21 19:28:54 +00:00
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
args: args{
|
|
|
|
|
ctx: context.Background(),
|
|
|
|
|
},
|
|
|
|
|
want: []chronograf.User{
|
|
|
|
|
{
|
|
|
|
|
Name: "marty",
|
|
|
|
|
Permissions: chronograf.Permissions{
|
|
|
|
|
{
|
|
|
|
|
Scope: chronograf.AllScope,
|
|
|
|
|
Allowed: chronograf.Allowances{"ViewChronograf", "ReadData", "WriteData"},
|
|
|
|
|
},
|
|
|
|
|
},
|
2017-03-02 01:13:44 +00:00
|
|
|
|
Roles: []chronograf.Role{},
|
2017-02-21 19:28:54 +00:00
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
name: "Failure to get User",
|
|
|
|
|
fields: fields{
|
|
|
|
|
Ctrl: &mockCtrl{
|
2017-02-23 22:02:53 +00:00
|
|
|
|
users: func(ctx context.Context, name *string) (*enterprise.Users, error) {
|
2017-02-21 19:28:54 +00:00
|
|
|
|
return nil, fmt.Errorf("1.21 Gigawatts! Tom, how could I have been so careless?")
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
args: args{
|
|
|
|
|
ctx: context.Background(),
|
|
|
|
|
},
|
|
|
|
|
wantErr: true,
|
|
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
for _, tt := range tests {
|
2017-02-23 22:02:53 +00:00
|
|
|
|
c := &enterprise.UserStore{
|
2017-02-21 19:28:54 +00:00
|
|
|
|
Ctrl: tt.fields.Ctrl,
|
|
|
|
|
Logger: tt.fields.Logger,
|
|
|
|
|
}
|
|
|
|
|
got, err := c.All(tt.args.ctx)
|
|
|
|
|
if (err != nil) != tt.wantErr {
|
|
|
|
|
t.Errorf("%q. Client.All() error = %v, wantErr %v", tt.name, err, tt.wantErr)
|
|
|
|
|
continue
|
|
|
|
|
}
|
|
|
|
|
if !reflect.DeepEqual(got, tt.want) {
|
|
|
|
|
t.Errorf("%q. Client.All() = %v, want %v", tt.name, got, tt.want)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2017-02-23 22:02:53 +00:00
|
|
|
|
func Test_ToEnterprise(t *testing.T) {
|
2017-02-21 19:28:54 +00:00
|
|
|
|
tests := []struct {
|
|
|
|
|
name string
|
|
|
|
|
perms chronograf.Permissions
|
2017-02-23 22:02:53 +00:00
|
|
|
|
want enterprise.Permissions
|
2017-02-21 19:28:54 +00:00
|
|
|
|
}{
|
|
|
|
|
{
|
|
|
|
|
name: "All Scopes",
|
2017-02-23 22:02:53 +00:00
|
|
|
|
want: enterprise.Permissions{"": []string{"ViewChronograf", "KapacitorAPI"}},
|
2017-02-21 19:28:54 +00:00
|
|
|
|
perms: chronograf.Permissions{
|
|
|
|
|
{
|
|
|
|
|
Scope: chronograf.AllScope,
|
|
|
|
|
Allowed: chronograf.Allowances{"ViewChronograf", "KapacitorAPI"},
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
name: "DB Scope",
|
2017-02-23 22:02:53 +00:00
|
|
|
|
want: enterprise.Permissions{"telegraf": []string{"ReadData", "WriteData"}},
|
2017-02-21 19:28:54 +00:00
|
|
|
|
perms: chronograf.Permissions{
|
|
|
|
|
{
|
|
|
|
|
Scope: chronograf.DBScope,
|
|
|
|
|
Name: "telegraf",
|
|
|
|
|
Allowed: chronograf.Allowances{"ReadData", "WriteData"},
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
for _, tt := range tests {
|
2017-02-23 22:02:53 +00:00
|
|
|
|
if got := enterprise.ToEnterprise(tt.perms); !reflect.DeepEqual(got, tt.want) {
|
|
|
|
|
t.Errorf("%q. ToEnterprise() = %v, want %v", tt.name, got, tt.want)
|
2017-02-21 19:28:54 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2017-02-23 22:02:53 +00:00
|
|
|
|
func Test_ToChronograf(t *testing.T) {
|
2017-02-21 19:28:54 +00:00
|
|
|
|
tests := []struct {
|
|
|
|
|
name string
|
2017-02-23 22:02:53 +00:00
|
|
|
|
perms enterprise.Permissions
|
2017-02-21 19:28:54 +00:00
|
|
|
|
want chronograf.Permissions
|
|
|
|
|
}{
|
|
|
|
|
{
|
|
|
|
|
name: "All Scopes",
|
2017-02-23 22:02:53 +00:00
|
|
|
|
perms: enterprise.Permissions{"": []string{"ViewChronograf", "KapacitorAPI"}},
|
2017-02-21 19:28:54 +00:00
|
|
|
|
want: chronograf.Permissions{
|
|
|
|
|
{
|
|
|
|
|
Scope: chronograf.AllScope,
|
|
|
|
|
Allowed: chronograf.Allowances{"ViewChronograf", "KapacitorAPI"},
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
name: "DB Scope",
|
2017-02-23 22:02:53 +00:00
|
|
|
|
perms: enterprise.Permissions{"telegraf": []string{"ReadData", "WriteData"}},
|
2017-02-21 19:28:54 +00:00
|
|
|
|
want: chronograf.Permissions{
|
|
|
|
|
{
|
|
|
|
|
Scope: chronograf.DBScope,
|
|
|
|
|
Name: "telegraf",
|
|
|
|
|
Allowed: chronograf.Allowances{"ReadData", "WriteData"},
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
for _, tt := range tests {
|
2017-02-23 22:02:53 +00:00
|
|
|
|
if got := enterprise.ToChronograf(tt.perms); !reflect.DeepEqual(got, tt.want) {
|
2017-02-21 19:28:54 +00:00
|
|
|
|
t.Errorf("%q. toChronograf() = %v, want %v", tt.name, got, tt.want)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
type mockCtrl struct {
|
2017-02-23 22:02:53 +00:00
|
|
|
|
showCluster func(ctx context.Context) (*enterprise.Cluster, error)
|
|
|
|
|
user func(ctx context.Context, name string) (*enterprise.User, error)
|
2017-02-21 19:28:54 +00:00
|
|
|
|
createUser func(ctx context.Context, name, passwd string) error
|
|
|
|
|
deleteUser func(ctx context.Context, name string) error
|
|
|
|
|
changePassword func(ctx context.Context, name, passwd string) error
|
2017-02-23 22:02:53 +00:00
|
|
|
|
users func(ctx context.Context, name *string) (*enterprise.Users, error)
|
|
|
|
|
setUserPerms func(ctx context.Context, name string, perms enterprise.Permissions) error
|
|
|
|
|
|
2017-03-02 01:13:44 +00:00
|
|
|
|
userRoles func(ctx context.Context) (map[string]enterprise.Roles, error)
|
|
|
|
|
|
2017-02-23 22:02:53 +00:00
|
|
|
|
roles func(ctx context.Context, name *string) (*enterprise.Roles, error)
|
|
|
|
|
role func(ctx context.Context, name string) (*enterprise.Role, error)
|
|
|
|
|
createRole func(ctx context.Context, name string) error
|
|
|
|
|
deleteRole func(ctx context.Context, name string) error
|
|
|
|
|
setRolePerms func(ctx context.Context, name string, perms enterprise.Permissions) error
|
|
|
|
|
setRoleUsers func(ctx context.Context, name string, users []string) error
|
2017-02-21 19:28:54 +00:00
|
|
|
|
}
|
|
|
|
|
|
2017-02-23 22:02:53 +00:00
|
|
|
|
func (m *mockCtrl) ShowCluster(ctx context.Context) (*enterprise.Cluster, error) {
|
2017-02-21 19:28:54 +00:00
|
|
|
|
return m.showCluster(ctx)
|
|
|
|
|
}
|
2017-03-02 01:13:44 +00:00
|
|
|
|
|
2017-02-23 22:02:53 +00:00
|
|
|
|
func (m *mockCtrl) User(ctx context.Context, name string) (*enterprise.User, error) {
|
2017-02-21 19:28:54 +00:00
|
|
|
|
return m.user(ctx, name)
|
|
|
|
|
}
|
2017-03-02 01:13:44 +00:00
|
|
|
|
|
2017-02-21 19:28:54 +00:00
|
|
|
|
func (m *mockCtrl) CreateUser(ctx context.Context, name, passwd string) error {
|
|
|
|
|
return m.createUser(ctx, name, passwd)
|
|
|
|
|
}
|
2017-03-02 01:13:44 +00:00
|
|
|
|
|
2017-02-21 19:28:54 +00:00
|
|
|
|
func (m *mockCtrl) DeleteUser(ctx context.Context, name string) error {
|
|
|
|
|
return m.deleteUser(ctx, name)
|
|
|
|
|
}
|
2017-03-02 01:13:44 +00:00
|
|
|
|
|
2017-02-21 19:28:54 +00:00
|
|
|
|
func (m *mockCtrl) ChangePassword(ctx context.Context, name, passwd string) error {
|
|
|
|
|
return m.changePassword(ctx, name, passwd)
|
|
|
|
|
}
|
2017-03-02 01:13:44 +00:00
|
|
|
|
|
2017-02-23 22:02:53 +00:00
|
|
|
|
func (m *mockCtrl) Users(ctx context.Context, name *string) (*enterprise.Users, error) {
|
2017-02-21 19:28:54 +00:00
|
|
|
|
return m.users(ctx, name)
|
|
|
|
|
}
|
2017-03-02 01:13:44 +00:00
|
|
|
|
|
2017-02-23 22:02:53 +00:00
|
|
|
|
func (m *mockCtrl) SetUserPerms(ctx context.Context, name string, perms enterprise.Permissions) error {
|
2017-02-21 19:28:54 +00:00
|
|
|
|
return m.setUserPerms(ctx, name, perms)
|
|
|
|
|
}
|
2017-02-23 22:02:53 +00:00
|
|
|
|
|
2017-03-02 01:13:44 +00:00
|
|
|
|
func (m *mockCtrl) UserRoles(ctx context.Context) (map[string]enterprise.Roles, error) {
|
|
|
|
|
return m.userRoles(ctx)
|
|
|
|
|
}
|
|
|
|
|
|
2017-02-23 22:02:53 +00:00
|
|
|
|
func (m *mockCtrl) Roles(ctx context.Context, name *string) (*enterprise.Roles, error) {
|
|
|
|
|
return m.roles(ctx, name)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (m *mockCtrl) Role(ctx context.Context, name string) (*enterprise.Role, error) {
|
|
|
|
|
return m.role(ctx, name)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (m *mockCtrl) CreateRole(ctx context.Context, name string) error {
|
|
|
|
|
return m.createRole(ctx, name)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (m *mockCtrl) DeleteRole(ctx context.Context, name string) error {
|
|
|
|
|
return m.deleteRole(ctx, name)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (m *mockCtrl) SetRolePerms(ctx context.Context, name string, perms enterprise.Permissions) error {
|
|
|
|
|
return m.setRolePerms(ctx, name, perms)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (m *mockCtrl) SetRoleUsers(ctx context.Context, name string, users []string) error {
|
|
|
|
|
return m.setRoleUsers(ctx, name, users)
|
|
|
|
|
}
|