mirror of https://github.com/grafana/grafana.git
				
				
				
			
		
			
				
	
	
		
			88 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			Go
		
	
	
	
			
		
		
	
	
			88 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			Go
		
	
	
	
package accesscontrol
 | 
						|
 | 
						|
import (
 | 
						|
	"context"
 | 
						|
	"testing"
 | 
						|
 | 
						|
	"github.com/stretchr/testify/assert"
 | 
						|
)
 | 
						|
 | 
						|
func TestGetResourcesMetadata(t *testing.T) {
 | 
						|
	tests := []struct {
 | 
						|
		desc         string
 | 
						|
		prefix       string
 | 
						|
		resourcesIDs map[string]bool
 | 
						|
		permissions  map[string][]string
 | 
						|
		expected     map[string]Metadata
 | 
						|
	}{
 | 
						|
		{
 | 
						|
			desc:         "Should return no permission for resources 1,2,3 given the user has no permission",
 | 
						|
			prefix:       "resources:id:",
 | 
						|
			resourcesIDs: map[string]bool{"1": true, "2": true, "3": true},
 | 
						|
			expected:     map[string]Metadata{},
 | 
						|
		},
 | 
						|
		{
 | 
						|
			desc:   "Should return no permission for resources 1,2,3 given the user has permissions for 4 only",
 | 
						|
			prefix: "resources:id:",
 | 
						|
			permissions: map[string][]string{
 | 
						|
				"resources:action1": {Scope("resources", "id", "4")},
 | 
						|
				"resources:action2": {Scope("resources", "id", "4")},
 | 
						|
				"resources:action3": {Scope("resources", "id", "4")},
 | 
						|
			},
 | 
						|
			resourcesIDs: map[string]bool{"1": true, "2": true, "3": true},
 | 
						|
			expected:     map[string]Metadata{},
 | 
						|
		},
 | 
						|
		{
 | 
						|
			desc:   "Should only return permissions for resources 1 and 2, given the user has no permissions for 3",
 | 
						|
			prefix: "resources:id:",
 | 
						|
			permissions: map[string][]string{
 | 
						|
				"resources:action1": {Scope("resources", "id", "1")},
 | 
						|
				"resources:action2": {Scope("resources", "id", "2")},
 | 
						|
				"resources:action3": {Scope("resources", "id", "2")},
 | 
						|
			},
 | 
						|
			resourcesIDs: map[string]bool{"1": true, "2": true, "3": true},
 | 
						|
			expected: map[string]Metadata{
 | 
						|
				"1": {"resources:action1": true},
 | 
						|
				"2": {"resources:action2": true, "resources:action3": true},
 | 
						|
			},
 | 
						|
		},
 | 
						|
		{
 | 
						|
			desc:   "Should return permissions with global scopes for resources 1,2,3",
 | 
						|
			prefix: "resources:id:",
 | 
						|
			permissions: map[string][]string{
 | 
						|
				"resources:action1": {Scope("resources", "id", "1")},
 | 
						|
				"resources:action2": {Scope("resources", "id", "2")},
 | 
						|
				"resources:action3": {Scope("resources", "id", "2")},
 | 
						|
				"resources:action4": {Scope("resources", "id", "*")},
 | 
						|
				"resources:action5": {Scope("resources", "*")},
 | 
						|
				"resources:action6": {"*"},
 | 
						|
			},
 | 
						|
			resourcesIDs: map[string]bool{"1": true, "2": true, "3": true},
 | 
						|
			expected: map[string]Metadata{
 | 
						|
				"1": {"resources:action1": true, "resources:action4": true, "resources:action5": true, "resources:action6": true},
 | 
						|
				"2": {"resources:action2": true, "resources:action3": true, "resources:action4": true, "resources:action5": true, "resources:action6": true},
 | 
						|
				"3": {"resources:action4": true, "resources:action5": true, "resources:action6": true},
 | 
						|
			},
 | 
						|
		},
 | 
						|
		{
 | 
						|
			desc:   "Should correctly filter out irrelevant permissions for resources 1,2,3",
 | 
						|
			prefix: "resources:id:",
 | 
						|
			permissions: map[string][]string{
 | 
						|
				"resources:action1":      {Scope("resources", "id", "1")},
 | 
						|
				"resources:action2":      {Scope("otherresources", "id", "*")},
 | 
						|
				"otherresources:action1": {Scope("resources", "id", "1"), Scope("otherresources", "id", "*")},
 | 
						|
			},
 | 
						|
			resourcesIDs: map[string]bool{"1": true, "2": true, "3": true},
 | 
						|
			expected: map[string]Metadata{
 | 
						|
				"1": {"resources:action1": true, "otherresources:action1": true},
 | 
						|
			},
 | 
						|
		},
 | 
						|
	}
 | 
						|
	for _, tt := range tests {
 | 
						|
		t.Run(tt.desc, func(t *testing.T) {
 | 
						|
			metadata := GetResourcesMetadata(context.Background(), tt.permissions, tt.prefix, tt.resourcesIDs)
 | 
						|
			assert.EqualValues(t, tt.expected, metadata)
 | 
						|
		})
 | 
						|
	}
 | 
						|
}
 |