mirror of
https://github.com/grafana/grafana.git
synced 2025-08-06 20:59:35 +08:00
Added function hasAccessToExplore in ContextSrv and refactored tests
This commit is contained in:
@ -59,6 +59,10 @@ export class ContextSrv {
|
|||||||
this.sidemenu = !this.sidemenu;
|
this.sidemenu = !this.sidemenu;
|
||||||
store.set('grafana.sidemenu', this.sidemenu);
|
store.set('grafana.sidemenu', this.sidemenu);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
hasAccessToExplore() {
|
||||||
|
return (this.isEditor || config.viewersCanEdit) && config.exploreEnabled;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const contextSrv = new ContextSrv();
|
const contextSrv = new ContextSrv();
|
||||||
|
@ -1,7 +1,6 @@
|
|||||||
import $ from 'jquery';
|
import $ from 'jquery';
|
||||||
import _ from 'lodash';
|
import _ from 'lodash';
|
||||||
|
|
||||||
import config from 'app/core/config';
|
|
||||||
import coreModule from 'app/core/core_module';
|
import coreModule from 'app/core/core_module';
|
||||||
import appEvents from 'app/core/app_events';
|
import appEvents from 'app/core/app_events';
|
||||||
import { getExploreUrl } from 'app/core/utils/explore';
|
import { getExploreUrl } from 'app/core/utils/explore';
|
||||||
@ -197,7 +196,7 @@ export class KeybindingSrv {
|
|||||||
});
|
});
|
||||||
|
|
||||||
// jump to explore if permissions allow
|
// jump to explore if permissions allow
|
||||||
if ((this.contextSrv.isEditor || config.viewersCanEdit) && config.exploreEnabled) {
|
if (this.contextSrv.hasAccessToExplore()) {
|
||||||
this.bind('x', async () => {
|
this.bind('x', async () => {
|
||||||
if (dashboard.meta.focusPanelId) {
|
if (dashboard.meta.focusPanelId) {
|
||||||
const panel = dashboard.getPanelById(dashboard.meta.focusPanelId);
|
const panel = dashboard.getPanelById(dashboard.meta.focusPanelId);
|
||||||
|
@ -1,18 +1,18 @@
|
|||||||
import _ from 'lodash';
|
import _ from 'lodash';
|
||||||
|
|
||||||
import kbn from 'app/core/utils/kbn';
|
import kbn from 'app/core/utils/kbn';
|
||||||
import config from 'app/core/config';
|
|
||||||
|
|
||||||
import { PanelCtrl } from 'app/features/panel/panel_ctrl';
|
import { PanelCtrl } from 'app/features/panel/panel_ctrl';
|
||||||
import { getExploreUrl } from 'app/core/utils/explore';
|
import { getExploreUrl } from 'app/core/utils/explore';
|
||||||
import { applyPanelTimeOverrides, getResolution } from 'app/features/dashboard/utils/panel';
|
import { applyPanelTimeOverrides, getResolution } from 'app/features/dashboard/utils/panel';
|
||||||
|
import { ContextSrv } from 'app/core/services/context_srv';
|
||||||
|
|
||||||
class MetricsPanelCtrl extends PanelCtrl {
|
class MetricsPanelCtrl extends PanelCtrl {
|
||||||
scope: any;
|
scope: any;
|
||||||
datasource: any;
|
datasource: any;
|
||||||
$q: any;
|
$q: any;
|
||||||
$timeout: any;
|
$timeout: any;
|
||||||
contextSrv: any;
|
contextSrv: ContextSrv;
|
||||||
datasourceSrv: any;
|
datasourceSrv: any;
|
||||||
timeSrv: any;
|
timeSrv: any;
|
||||||
templateSrv: any;
|
templateSrv: any;
|
||||||
@ -231,7 +231,7 @@ class MetricsPanelCtrl extends PanelCtrl {
|
|||||||
|
|
||||||
getAdditionalMenuItems() {
|
getAdditionalMenuItems() {
|
||||||
const items = [];
|
const items = [];
|
||||||
if (config.exploreEnabled && (this.contextSrv.isEditor || config.viewersCanEdit) && this.datasource) {
|
if (this.contextSrv.hasAccessToExplore() && this.datasource) {
|
||||||
items.push({
|
items.push({
|
||||||
text: 'Explore',
|
text: 'Explore',
|
||||||
click: 'ctrl.explore();',
|
click: 'ctrl.explore();',
|
||||||
|
@ -1,8 +1,6 @@
|
|||||||
jest.mock('app/core/core', () => ({}));
|
jest.mock('app/core/core', () => ({}));
|
||||||
jest.mock('app/core/config', () => {
|
jest.mock('app/core/config', () => {
|
||||||
return {
|
return {
|
||||||
exploreEnabled: true,
|
|
||||||
viewersCanEdit: false,
|
|
||||||
panels: {
|
panels: {
|
||||||
test: {
|
test: {
|
||||||
id: 'test',
|
id: 'test',
|
||||||
@ -15,62 +13,47 @@ jest.mock('app/core/config', () => {
|
|||||||
import q from 'q';
|
import q from 'q';
|
||||||
import { PanelModel } from 'app/features/dashboard/panel_model';
|
import { PanelModel } from 'app/features/dashboard/panel_model';
|
||||||
import { MetricsPanelCtrl } from '../metrics_panel_ctrl';
|
import { MetricsPanelCtrl } from '../metrics_panel_ctrl';
|
||||||
import config from 'app/core/config';
|
|
||||||
|
|
||||||
describe('MetricsPanelCtrl', () => {
|
describe('MetricsPanelCtrl', () => {
|
||||||
let ctrl;
|
|
||||||
|
|
||||||
beforeEach(() => {
|
|
||||||
ctrl = setupController();
|
|
||||||
});
|
|
||||||
|
|
||||||
describe('when getting additional menu items', () => {
|
describe('when getting additional menu items', () => {
|
||||||
let additionalItems;
|
describe('and has no datasource set but user has access to explore', () => {
|
||||||
|
|
||||||
describe('and has no datasource set', () => {
|
|
||||||
beforeEach(() => {
|
|
||||||
additionalItems = ctrl.getAdditionalMenuItems();
|
|
||||||
});
|
|
||||||
|
|
||||||
it('should not return any items', () => {
|
it('should not return any items', () => {
|
||||||
expect(additionalItems.length).toBe(0);
|
const ctrl = setupController({ hasAccessToExplore: true });
|
||||||
|
|
||||||
|
expect(ctrl.getAdditionalMenuItems().length).toBe(0);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
describe('and has datasource set that supports explore and user has powers', () => {
|
describe('and has datasource set that supports explore and user does not have access to explore', () => {
|
||||||
beforeEach(() => {
|
it('should not return any items', () => {
|
||||||
ctrl.contextSrv = { isEditor: true };
|
const ctrl = setupController({ hasAccessToExplore: false });
|
||||||
ctrl.datasource = { meta: { explore: true } };
|
ctrl.datasource = { meta: { explore: true } };
|
||||||
additionalItems = ctrl.getAdditionalMenuItems();
|
|
||||||
});
|
|
||||||
|
|
||||||
it('should not return any items', () => {
|
expect(ctrl.getAdditionalMenuItems().length).toBe(0);
|
||||||
expect(additionalItems.length).toBe(1);
|
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
describe('and has datasource set that supports explore and viewersCanEdit is true', () => {
|
describe('and has datasource set that supports explore and user has access to explore', () => {
|
||||||
beforeEach(() => {
|
it('should return one item', () => {
|
||||||
config.viewersCanEdit = true;
|
const ctrl = setupController({ hasAccessToExplore: true });
|
||||||
ctrl.contextSrv = { isEditor: false };
|
|
||||||
ctrl.datasource = { meta: { explore: true } };
|
ctrl.datasource = { meta: { explore: true } };
|
||||||
additionalItems = ctrl.getAdditionalMenuItems();
|
|
||||||
});
|
|
||||||
|
|
||||||
it('should not return any items', () => {
|
expect(ctrl.getAdditionalMenuItems().length).toBe(1);
|
||||||
expect(additionalItems.length).toBe(1);
|
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
function setupController() {
|
function setupController({ hasAccessToExplore } = { hasAccessToExplore: false }) {
|
||||||
const injectorStub = {
|
const injectorStub = {
|
||||||
get: type => {
|
get: type => {
|
||||||
switch (type) {
|
switch (type) {
|
||||||
case '$q': {
|
case '$q': {
|
||||||
return q;
|
return q;
|
||||||
}
|
}
|
||||||
|
case 'contextSrv': {
|
||||||
|
return { hasAccessToExplore: () => hasAccessToExplore };
|
||||||
|
}
|
||||||
default: {
|
default: {
|
||||||
return jest.fn();
|
return jest.fn();
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user