mirror of
https://github.com/grafana/grafana.git
synced 2025-02-25 18:55:37 -06:00
Merge pull request #12809 from dehrax/12224-share-modal-ctrl
Karma to Jest: share_modal_ctrl
This commit is contained in:
commit
77ee032e41
@ -2,9 +2,8 @@ import angular from 'angular';
|
|||||||
import config from 'app/core/config';
|
import config from 'app/core/config';
|
||||||
import moment from 'moment';
|
import moment from 'moment';
|
||||||
|
|
||||||
export class ShareModalCtrl {
|
|
||||||
/** @ngInject */
|
/** @ngInject */
|
||||||
constructor($scope, $rootScope, $location, $timeout, timeSrv, templateSrv, linkSrv) {
|
export function ShareModalCtrl($scope, $rootScope, $location, $timeout, timeSrv, templateSrv, linkSrv) {
|
||||||
$scope.options = {
|
$scope.options = {
|
||||||
forCurrent: true,
|
forCurrent: true,
|
||||||
includeTemplateVars: true,
|
includeTemplateVars: true,
|
||||||
@ -116,6 +115,5 @@ export class ShareModalCtrl {
|
|||||||
return $scope.shareUrl;
|
return $scope.shareUrl;
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
angular.module('grafana.controllers').controller('ShareModalCtrl', ShareModalCtrl);
|
angular.module('grafana.controllers').controller('ShareModalCtrl', ShareModalCtrl);
|
||||||
|
150
public/app/features/dashboard/specs/share_modal_ctrl.jest.ts
Normal file
150
public/app/features/dashboard/specs/share_modal_ctrl.jest.ts
Normal file
@ -0,0 +1,150 @@
|
|||||||
|
import '../shareModalCtrl';
|
||||||
|
import { ShareModalCtrl } from '../shareModalCtrl';
|
||||||
|
import config from 'app/core/config';
|
||||||
|
import { LinkSrv } from 'app/features/panellinks/link_srv';
|
||||||
|
|
||||||
|
describe('ShareModalCtrl', () => {
|
||||||
|
var ctx = <any>{
|
||||||
|
timeSrv: {
|
||||||
|
timeRange: () => {
|
||||||
|
return { from: new Date(1000), to: new Date(2000) };
|
||||||
|
},
|
||||||
|
},
|
||||||
|
$location: {
|
||||||
|
absUrl: () => 'http://server/#!/test',
|
||||||
|
search: () => {
|
||||||
|
return { from: '', to: '' };
|
||||||
|
},
|
||||||
|
},
|
||||||
|
scope: {
|
||||||
|
dashboard: {
|
||||||
|
meta: {
|
||||||
|
isSnapshot: true,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
templateSrv: {
|
||||||
|
fillVariableValuesForUrl: () => {},
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
(<any>window).Intl.DateTimeFormat = () => {
|
||||||
|
return {
|
||||||
|
resolvedOptions: () => {
|
||||||
|
return { timeZone: 'UTC' };
|
||||||
|
},
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
beforeEach(() => {
|
||||||
|
config.bootData = {
|
||||||
|
user: {
|
||||||
|
orgId: 1,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
ctx.ctrl = new ShareModalCtrl(
|
||||||
|
ctx.scope,
|
||||||
|
{},
|
||||||
|
ctx.$location,
|
||||||
|
{},
|
||||||
|
ctx.timeSrv,
|
||||||
|
ctx.templateSrv,
|
||||||
|
new LinkSrv({}, ctx.stimeSrv)
|
||||||
|
);
|
||||||
|
});
|
||||||
|
|
||||||
|
describe('shareUrl with current time range and panel', () => {
|
||||||
|
it('should generate share url absolute time', () => {
|
||||||
|
ctx.scope.panel = { id: 22 };
|
||||||
|
|
||||||
|
ctx.scope.init();
|
||||||
|
expect(ctx.scope.shareUrl).toBe('http://server/#!/test?from=1000&to=2000&orgId=1&panelId=22&fullscreen');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should generate render url', () => {
|
||||||
|
ctx.$location.absUrl = () => 'http://dashboards.grafana.com/d/abcdefghi/my-dash';
|
||||||
|
|
||||||
|
ctx.scope.panel = { id: 22 };
|
||||||
|
|
||||||
|
ctx.scope.init();
|
||||||
|
var base = 'http://dashboards.grafana.com/render/d-solo/abcdefghi/my-dash';
|
||||||
|
var params = '?from=1000&to=2000&orgId=1&panelId=22&width=1000&height=500&tz=UTC';
|
||||||
|
expect(ctx.scope.imageUrl).toContain(base + params);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should generate render url for scripted dashboard', () => {
|
||||||
|
ctx.$location.absUrl = () => 'http://dashboards.grafana.com/dashboard/script/my-dash.js';
|
||||||
|
|
||||||
|
ctx.scope.panel = { id: 22 };
|
||||||
|
|
||||||
|
ctx.scope.init();
|
||||||
|
var base = 'http://dashboards.grafana.com/render/dashboard-solo/script/my-dash.js';
|
||||||
|
var params = '?from=1000&to=2000&orgId=1&panelId=22&width=1000&height=500&tz=UTC';
|
||||||
|
expect(ctx.scope.imageUrl).toContain(base + params);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should remove panel id when no panel in scope', () => {
|
||||||
|
ctx.$location.absUrl = () => 'http://server/#!/test';
|
||||||
|
ctx.scope.options.forCurrent = true;
|
||||||
|
ctx.scope.panel = null;
|
||||||
|
|
||||||
|
ctx.scope.init();
|
||||||
|
expect(ctx.scope.shareUrl).toBe('http://server/#!/test?from=1000&to=2000&orgId=1');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should add theme when specified', () => {
|
||||||
|
ctx.scope.options.theme = 'light';
|
||||||
|
ctx.scope.panel = null;
|
||||||
|
|
||||||
|
ctx.scope.init();
|
||||||
|
expect(ctx.scope.shareUrl).toBe('http://server/#!/test?from=1000&to=2000&orgId=1&theme=light');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should remove fullscreen from image url when is first param in querystring and modeSharePanel is true', () => {
|
||||||
|
ctx.$location.search = () => {
|
||||||
|
return { fullscreen: true, edit: true };
|
||||||
|
};
|
||||||
|
ctx.$location.absUrl = () => 'http://server/#!/test?fullscreen&edit';
|
||||||
|
ctx.scope.modeSharePanel = true;
|
||||||
|
ctx.scope.panel = { id: 1 };
|
||||||
|
|
||||||
|
ctx.scope.buildUrl();
|
||||||
|
|
||||||
|
expect(ctx.scope.shareUrl).toContain('?fullscreen&edit&from=1000&to=2000&orgId=1&panelId=1');
|
||||||
|
expect(ctx.scope.imageUrl).toContain('?from=1000&to=2000&orgId=1&panelId=1&width=1000&height=500&tz=UTC');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should remove edit from image url when is first param in querystring and modeSharePanel is true', () => {
|
||||||
|
ctx.$location.search = () => {
|
||||||
|
return { edit: true, fullscreen: true };
|
||||||
|
};
|
||||||
|
ctx.$location.absUrl = () => 'http://server/#!/test?edit&fullscreen';
|
||||||
|
ctx.scope.modeSharePanel = true;
|
||||||
|
ctx.scope.panel = { id: 1 };
|
||||||
|
|
||||||
|
ctx.scope.buildUrl();
|
||||||
|
|
||||||
|
expect(ctx.scope.shareUrl).toContain('?edit&fullscreen&from=1000&to=2000&orgId=1&panelId=1');
|
||||||
|
expect(ctx.scope.imageUrl).toContain('?from=1000&to=2000&orgId=1&panelId=1&width=1000&height=500&tz=UTC');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should include template variables in url', () => {
|
||||||
|
ctx.$location.search = () => {
|
||||||
|
return {};
|
||||||
|
};
|
||||||
|
ctx.$location.absUrl = () => 'http://server/#!/test';
|
||||||
|
ctx.scope.options.includeTemplateVars = true;
|
||||||
|
|
||||||
|
ctx.templateSrv.fillVariableValuesForUrl = function(params) {
|
||||||
|
params['var-app'] = 'mupp';
|
||||||
|
params['var-server'] = 'srv-01';
|
||||||
|
};
|
||||||
|
|
||||||
|
ctx.scope.buildUrl();
|
||||||
|
expect(ctx.scope.shareUrl).toContain(
|
||||||
|
'http://server/#!/test?from=1000&to=2000&orgId=1&var-app=mupp&var-server=srv-01'
|
||||||
|
);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
@ -1,122 +0,0 @@
|
|||||||
import { describe, beforeEach, it, expect, sinon, angularMocks } from 'test/lib/common';
|
|
||||||
import helpers from 'test/specs/helpers';
|
|
||||||
import '../shareModalCtrl';
|
|
||||||
import config from 'app/core/config';
|
|
||||||
import 'app/features/panellinks/link_srv';
|
|
||||||
|
|
||||||
describe('ShareModalCtrl', function() {
|
|
||||||
var ctx = new helpers.ControllerTestContext();
|
|
||||||
|
|
||||||
function setTime(range) {
|
|
||||||
ctx.timeSrv.timeRange = sinon.stub().returns(range);
|
|
||||||
}
|
|
||||||
|
|
||||||
beforeEach(function() {
|
|
||||||
config.bootData = {
|
|
||||||
user: {
|
|
||||||
orgId: 1,
|
|
||||||
},
|
|
||||||
};
|
|
||||||
});
|
|
||||||
|
|
||||||
setTime({ from: new Date(1000), to: new Date(2000) });
|
|
||||||
|
|
||||||
beforeEach(angularMocks.module('grafana.controllers'));
|
|
||||||
beforeEach(angularMocks.module('grafana.services'));
|
|
||||||
beforeEach(
|
|
||||||
angularMocks.module(function($compileProvider) {
|
|
||||||
$compileProvider.preAssignBindingsEnabled(true);
|
|
||||||
})
|
|
||||||
);
|
|
||||||
|
|
||||||
beforeEach(ctx.providePhase());
|
|
||||||
|
|
||||||
beforeEach(ctx.createControllerPhase('ShareModalCtrl'));
|
|
||||||
|
|
||||||
describe('shareUrl with current time range and panel', function() {
|
|
||||||
it('should generate share url absolute time', function() {
|
|
||||||
ctx.$location.path('/test');
|
|
||||||
ctx.scope.panel = { id: 22 };
|
|
||||||
|
|
||||||
ctx.scope.init();
|
|
||||||
expect(ctx.scope.shareUrl).to.be('http://server/#!/test?from=1000&to=2000&orgId=1&panelId=22&fullscreen');
|
|
||||||
});
|
|
||||||
|
|
||||||
it('should generate render url', function() {
|
|
||||||
ctx.$location.$$absUrl = 'http://dashboards.grafana.com/d/abcdefghi/my-dash';
|
|
||||||
|
|
||||||
ctx.scope.panel = { id: 22 };
|
|
||||||
|
|
||||||
ctx.scope.init();
|
|
||||||
var base = 'http://dashboards.grafana.com/render/d-solo/abcdefghi/my-dash';
|
|
||||||
var params = '?from=1000&to=2000&orgId=1&panelId=22&width=1000&height=500&tz=UTC';
|
|
||||||
expect(ctx.scope.imageUrl).to.contain(base + params);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('should generate render url for scripted dashboard', function() {
|
|
||||||
ctx.$location.$$absUrl = 'http://dashboards.grafana.com/dashboard/script/my-dash.js';
|
|
||||||
|
|
||||||
ctx.scope.panel = { id: 22 };
|
|
||||||
|
|
||||||
ctx.scope.init();
|
|
||||||
var base = 'http://dashboards.grafana.com/render/dashboard-solo/script/my-dash.js';
|
|
||||||
var params = '?from=1000&to=2000&orgId=1&panelId=22&width=1000&height=500&tz=UTC';
|
|
||||||
expect(ctx.scope.imageUrl).to.contain(base + params);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('should remove panel id when no panel in scope', function() {
|
|
||||||
ctx.$location.path('/test');
|
|
||||||
ctx.scope.options.forCurrent = true;
|
|
||||||
ctx.scope.panel = null;
|
|
||||||
|
|
||||||
ctx.scope.init();
|
|
||||||
expect(ctx.scope.shareUrl).to.be('http://server/#!/test?from=1000&to=2000&orgId=1');
|
|
||||||
});
|
|
||||||
|
|
||||||
it('should add theme when specified', function() {
|
|
||||||
ctx.$location.path('/test');
|
|
||||||
ctx.scope.options.theme = 'light';
|
|
||||||
ctx.scope.panel = null;
|
|
||||||
|
|
||||||
ctx.scope.init();
|
|
||||||
expect(ctx.scope.shareUrl).to.be('http://server/#!/test?from=1000&to=2000&orgId=1&theme=light');
|
|
||||||
});
|
|
||||||
|
|
||||||
it('should remove fullscreen from image url when is first param in querystring and modeSharePanel is true', function() {
|
|
||||||
ctx.$location.url('/test?fullscreen&edit');
|
|
||||||
ctx.scope.modeSharePanel = true;
|
|
||||||
ctx.scope.panel = { id: 1 };
|
|
||||||
|
|
||||||
ctx.scope.buildUrl();
|
|
||||||
|
|
||||||
expect(ctx.scope.shareUrl).to.contain('?fullscreen&edit&from=1000&to=2000&orgId=1&panelId=1');
|
|
||||||
expect(ctx.scope.imageUrl).to.contain('?from=1000&to=2000&orgId=1&panelId=1&width=1000&height=500&tz=UTC');
|
|
||||||
});
|
|
||||||
|
|
||||||
it('should remove edit from image url when is first param in querystring and modeSharePanel is true', function() {
|
|
||||||
ctx.$location.url('/test?edit&fullscreen');
|
|
||||||
ctx.scope.modeSharePanel = true;
|
|
||||||
ctx.scope.panel = { id: 1 };
|
|
||||||
|
|
||||||
ctx.scope.buildUrl();
|
|
||||||
|
|
||||||
expect(ctx.scope.shareUrl).to.contain('?edit&fullscreen&from=1000&to=2000&orgId=1&panelId=1');
|
|
||||||
expect(ctx.scope.imageUrl).to.contain('?from=1000&to=2000&orgId=1&panelId=1&width=1000&height=500&tz=UTC');
|
|
||||||
});
|
|
||||||
|
|
||||||
it('should include template variables in url', function() {
|
|
||||||
ctx.$location.path('/test');
|
|
||||||
ctx.scope.options.includeTemplateVars = true;
|
|
||||||
|
|
||||||
ctx.templateSrv.fillVariableValuesForUrl = function(params) {
|
|
||||||
params['var-app'] = 'mupp';
|
|
||||||
params['var-server'] = 'srv-01';
|
|
||||||
};
|
|
||||||
|
|
||||||
ctx.scope.buildUrl();
|
|
||||||
expect(ctx.scope.shareUrl).to.be(
|
|
||||||
'http://server/#!/test?from=1000&to=2000&orgId=1&var-app=mupp&var-server=srv-01'
|
|
||||||
);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
});
|
|
Loading…
Reference in New Issue
Block a user