mirror of
https://github.com/grafana/grafana.git
synced 2024-11-22 17:06:57 -06:00
73 lines
1.2 KiB
Go
73 lines
1.2 KiB
Go
package accesscontrol
|
|
|
|
import (
|
|
"sort"
|
|
"strings"
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
func TestPredefinedRoles(t *testing.T) {
|
|
for name, r := range PredefinedRoles {
|
|
assert.Truef(t,
|
|
strings.HasPrefix(name, "grafana:roles:"),
|
|
"expected all predefined roles to be prefixed by 'grafana:roles:', found role '%s'", name,
|
|
)
|
|
assert.Equal(t, name, r.Name)
|
|
assert.NotZero(t, r.Version)
|
|
// assert.NotEmpty(t, r.Description)
|
|
}
|
|
}
|
|
|
|
func TestPredefinedRoleGrants(t *testing.T) {
|
|
for _, v := range PredefinedRoleGrants {
|
|
assert.True(t,
|
|
sort.SliceIsSorted(v, func(i, j int) bool {
|
|
return v[i] < v[j]
|
|
}),
|
|
"require role grant lists to be sorted",
|
|
)
|
|
for _, r := range v {
|
|
assert.Contains(t, PredefinedRoles, r)
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestConcatPermissions(t *testing.T) {
|
|
perms1 := []Permission{
|
|
{
|
|
Action: "test",
|
|
Scope: "test:*",
|
|
},
|
|
{
|
|
Action: "test1",
|
|
Scope: "test1:*",
|
|
},
|
|
}
|
|
perms2 := []Permission{
|
|
{
|
|
Action: "test1",
|
|
Scope: "*",
|
|
},
|
|
}
|
|
|
|
expected := []Permission{
|
|
{
|
|
Action: "test",
|
|
Scope: "test:*",
|
|
},
|
|
{
|
|
Action: "test1",
|
|
Scope: "test1:*",
|
|
},
|
|
{
|
|
Action: "test1",
|
|
Scope: "*",
|
|
},
|
|
}
|
|
|
|
perms := ConcatPermissions(perms1, perms2)
|
|
assert.ElementsMatch(t, perms, expected)
|
|
}
|