mirror of https://github.com/grafana/grafana.git
				
				
				
			
		
			
				
	
	
		
			102 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			Go
		
	
	
	
			
		
		
	
	
			102 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			Go
		
	
	
	
| package api
 | |
| 
 | |
| import (
 | |
| 	"encoding/json"
 | |
| 	"testing"
 | |
| 
 | |
| 	"github.com/stretchr/testify/assert"
 | |
| 	"github.com/stretchr/testify/require"
 | |
| 
 | |
| 	"github.com/grafana/grafana/pkg/services/accesscontrol"
 | |
| 	"github.com/grafana/grafana/pkg/services/dashboards"
 | |
| 	"github.com/grafana/grafana/pkg/services/search/model"
 | |
| 	"github.com/grafana/grafana/pkg/setting"
 | |
| 	"github.com/grafana/grafana/pkg/web/webtest"
 | |
| )
 | |
| 
 | |
| func TestHTTPServer_Search(t *testing.T) {
 | |
| 	type testCase struct {
 | |
| 		desc             string
 | |
| 		includeMetadata  bool
 | |
| 		permissions      []accesscontrol.Permission
 | |
| 		expectedMetadata map[int64]map[string]struct{}
 | |
| 	}
 | |
| 
 | |
| 	type withMeta struct {
 | |
| 		model.Hit
 | |
| 		AccessControl accesscontrol.Metadata `json:"accessControl,omitempty"`
 | |
| 	}
 | |
| 
 | |
| 	tests := []testCase{
 | |
| 		{
 | |
| 			desc:            "should attach metadata to response",
 | |
| 			includeMetadata: true,
 | |
| 			expectedMetadata: map[int64]map[string]struct{}{
 | |
| 				1: {dashboards.ActionFoldersRead: {}},
 | |
| 				2: {dashboards.ActionFoldersRead: {}, dashboards.ActionFoldersWrite: {}, dashboards.ActionDashboardsWrite: {}},
 | |
| 				3: {dashboards.ActionDashboardsRead: {}, dashboards.ActionDashboardsWrite: {}},
 | |
| 			},
 | |
| 			permissions: []accesscontrol.Permission{
 | |
| 				{Action: "folders:read", Scope: "folders:*"},
 | |
| 				{Action: "folders:write", Scope: "folders:uid:folder2"},
 | |
| 				{Action: "dashboards:read", Scope: "dashboards:*"},
 | |
| 				{Action: "dashboards:write", Scope: "folders:uid:folder2"},
 | |
| 			},
 | |
| 		},
 | |
| 		{
 | |
| 			desc:             "not attach metadata",
 | |
| 			includeMetadata:  false,
 | |
| 			expectedMetadata: map[int64]map[string]struct{}{},
 | |
| 			permissions: []accesscontrol.Permission{
 | |
| 				{Action: "folders:read", Scope: "folders:*"},
 | |
| 				{Action: "folders:write", Scope: "folders:uid:folder2"},
 | |
| 				{Action: "dashboards:read", Scope: "dashboards:*"},
 | |
| 				{Action: "dashboards:write", Scope: "folders:uid:folder2"},
 | |
| 			},
 | |
| 		},
 | |
| 	}
 | |
| 
 | |
| 	for _, tt := range tests {
 | |
| 		t.Run(tt.desc, func(t *testing.T) {
 | |
| 			server := SetupAPITestServer(t, func(hs *HTTPServer) {
 | |
| 				hs.Cfg = setting.NewCfg()
 | |
| 				hs.SearchService = &mockSearchService{ExpectedResult: model.HitList{
 | |
| 					{ID: 1, UID: "folder1", Title: "folder1", Type: model.DashHitFolder},
 | |
| 					{ID: 2, UID: "folder2", Title: "folder2", Type: model.DashHitFolder},
 | |
| 					{ID: 3, UID: "dash3", Title: "dash3", FolderUID: "folder2", Type: model.DashHitDB},
 | |
| 				}}
 | |
| 			})
 | |
| 
 | |
| 			url := "/api/search"
 | |
| 			if tt.includeMetadata {
 | |
| 				url += "?accesscontrol=true"
 | |
| 			}
 | |
| 
 | |
| 			res, err := server.Send(
 | |
| 				webtest.RequestWithSignedInUser(
 | |
| 					server.NewGetRequest(url), userWithPermissions(1, tt.permissions),
 | |
| 				),
 | |
| 			)
 | |
| 			require.NoError(t, err)
 | |
| 
 | |
| 			var result []withMeta
 | |
| 			require.NoError(t, json.NewDecoder(res.Body).Decode(&result))
 | |
| 
 | |
| 			for _, r := range result {
 | |
| 				if !tt.includeMetadata {
 | |
| 					assert.Nil(t, r.AccessControl)
 | |
| 					continue
 | |
| 				}
 | |
| 
 | |
| 				assert.Len(t, r.AccessControl, len(tt.expectedMetadata[r.ID]))
 | |
| 				for action := range r.AccessControl {
 | |
| 					_, ok := tt.expectedMetadata[r.ID][action]
 | |
| 					assert.True(t, ok)
 | |
| 				}
 | |
| 			}
 | |
| 
 | |
| 			require.NoError(t, res.Body.Close())
 | |
| 		})
 | |
| 	}
 | |
| }
 |