mirror of
https://github.com/grafana/grafana.git
synced 2025-02-16 02:23:31 -06:00
* Try to parse 8 and 15 digit numbers as timestamps if parsing as date fails Fixes #19738 * Add tests
253 lines
7.6 KiB
TypeScript
253 lines
7.6 KiB
TypeScript
import { TimeSrv } from './TimeSrv';
|
|
import { ContextSrvStub } from 'test/specs/helpers';
|
|
import { isDateTime, dateTime } from '@grafana/data';
|
|
|
|
jest.mock('app/core/core', () => ({
|
|
appEvents: {
|
|
on: () => {},
|
|
},
|
|
}));
|
|
|
|
describe('timeSrv', () => {
|
|
const rootScope = {
|
|
$on: jest.fn(),
|
|
onAppEvent: jest.fn(),
|
|
appEvent: jest.fn(),
|
|
};
|
|
|
|
const timer = {
|
|
register: jest.fn(),
|
|
cancel: jest.fn(),
|
|
cancelAll: jest.fn(),
|
|
};
|
|
|
|
let location = {
|
|
search: jest.fn(() => ({})),
|
|
};
|
|
|
|
let timeSrv: TimeSrv;
|
|
|
|
const _dashboard: any = {
|
|
time: { from: 'now-6h', to: 'now' },
|
|
getTimezone: jest.fn(() => 'browser'),
|
|
};
|
|
|
|
beforeEach(() => {
|
|
timeSrv = new TimeSrv(rootScope as any, jest.fn() as any, location as any, timer, new ContextSrvStub() as any);
|
|
timeSrv.init(_dashboard);
|
|
_dashboard.refresh = false;
|
|
});
|
|
|
|
describe('timeRange', () => {
|
|
it('should return unparsed when parse is false', () => {
|
|
timeSrv.setTime({ from: 'now', to: 'now-1h' });
|
|
const time = timeSrv.timeRange();
|
|
expect(time.raw.from).toBe('now');
|
|
expect(time.raw.to).toBe('now-1h');
|
|
});
|
|
|
|
it('should return parsed when parse is true', () => {
|
|
timeSrv.setTime({ from: 'now', to: 'now-1h' });
|
|
const time = timeSrv.timeRange();
|
|
expect(isDateTime(time.from)).toBe(true);
|
|
expect(isDateTime(time.to)).toBe(true);
|
|
});
|
|
});
|
|
|
|
describe('init time from url', () => {
|
|
it('should handle relative times', () => {
|
|
location = {
|
|
search: jest.fn(() => ({
|
|
from: 'now-2d',
|
|
to: 'now',
|
|
})),
|
|
};
|
|
|
|
timeSrv = new TimeSrv(rootScope as any, jest.fn() as any, location as any, timer, new ContextSrvStub() as any);
|
|
timeSrv.init(_dashboard);
|
|
const time = timeSrv.timeRange();
|
|
expect(time.raw.from).toBe('now-2d');
|
|
expect(time.raw.to).toBe('now');
|
|
});
|
|
|
|
it('should handle formatted dates', () => {
|
|
location = {
|
|
search: jest.fn(() => ({
|
|
from: '20140410T052010',
|
|
to: '20140520T031022',
|
|
})),
|
|
};
|
|
|
|
timeSrv = new TimeSrv(rootScope as any, jest.fn() as any, location as any, timer, new ContextSrvStub() as any);
|
|
|
|
timeSrv.init(_dashboard);
|
|
const time = timeSrv.timeRange();
|
|
expect(time.from.valueOf()).toEqual(new Date('2014-04-10T05:20:10Z').getTime());
|
|
expect(time.to.valueOf()).toEqual(new Date('2014-05-20T03:10:22Z').getTime());
|
|
});
|
|
|
|
it('should ignore refresh if time absolute', () => {
|
|
location = {
|
|
search: jest.fn(() => ({
|
|
from: '20140410T052010',
|
|
to: '20140520T031022',
|
|
})),
|
|
};
|
|
|
|
timeSrv = new TimeSrv(rootScope as any, jest.fn() as any, location as any, timer, new ContextSrvStub() as any);
|
|
|
|
// dashboard saved with refresh on
|
|
_dashboard.refresh = true;
|
|
timeSrv.init(_dashboard);
|
|
|
|
expect(timeSrv.refresh).toBe(false);
|
|
});
|
|
|
|
it('should handle formatted dates without time', () => {
|
|
location = {
|
|
search: jest.fn(() => ({
|
|
from: '20140410',
|
|
to: '20140520',
|
|
})),
|
|
};
|
|
|
|
timeSrv = new TimeSrv(rootScope as any, jest.fn() as any, location as any, timer, new ContextSrvStub() as any);
|
|
|
|
timeSrv.init(_dashboard);
|
|
const time = timeSrv.timeRange();
|
|
expect(time.from.valueOf()).toEqual(new Date('2014-04-10T00:00:00Z').getTime());
|
|
expect(time.to.valueOf()).toEqual(new Date('2014-05-20T00:00:00Z').getTime());
|
|
});
|
|
|
|
it('should handle epochs', () => {
|
|
location = {
|
|
search: jest.fn(() => ({
|
|
from: '1410337646373',
|
|
to: '1410337665699',
|
|
})),
|
|
};
|
|
|
|
timeSrv = new TimeSrv(rootScope as any, jest.fn() as any, location as any, timer, new ContextSrvStub() as any);
|
|
|
|
timeSrv.init(_dashboard);
|
|
const time = timeSrv.timeRange();
|
|
expect(time.from.valueOf()).toEqual(1410337646373);
|
|
expect(time.to.valueOf()).toEqual(1410337665699);
|
|
});
|
|
|
|
it('should handle epochs that look like formatted date without time', () => {
|
|
location = {
|
|
search: jest.fn(() => ({
|
|
from: '20149999',
|
|
to: '20159999',
|
|
})),
|
|
};
|
|
|
|
timeSrv = new TimeSrv(rootScope as any, jest.fn() as any, location as any, timer, new ContextSrvStub() as any);
|
|
|
|
timeSrv.init(_dashboard);
|
|
const time = timeSrv.timeRange();
|
|
expect(time.from.valueOf()).toEqual(20149999);
|
|
expect(time.to.valueOf()).toEqual(20159999);
|
|
});
|
|
|
|
it('should handle epochs that look like formatted date', () => {
|
|
location = {
|
|
search: jest.fn(() => ({
|
|
from: '201499991234567',
|
|
to: '201599991234567',
|
|
})),
|
|
};
|
|
|
|
timeSrv = new TimeSrv(rootScope as any, jest.fn() as any, location as any, timer, new ContextSrvStub() as any);
|
|
|
|
timeSrv.init(_dashboard);
|
|
const time = timeSrv.timeRange();
|
|
expect(time.from.valueOf()).toEqual(201499991234567);
|
|
expect(time.to.valueOf()).toEqual(201599991234567);
|
|
});
|
|
|
|
it('should handle bad dates', () => {
|
|
location = {
|
|
search: jest.fn(() => ({
|
|
from: '20151126T00010%3C%2Fp%3E%3Cspan%20class',
|
|
to: 'now',
|
|
})),
|
|
};
|
|
|
|
timeSrv = new TimeSrv(rootScope as any, jest.fn() as any, location as any, timer, new ContextSrvStub() as any);
|
|
|
|
_dashboard.time.from = 'now-6h';
|
|
timeSrv.init(_dashboard);
|
|
expect(timeSrv.time.from).toEqual('now-6h');
|
|
expect(timeSrv.time.to).toEqual('now');
|
|
});
|
|
|
|
describe('data point windowing', () => {
|
|
it('handles time window specfied as interval string', () => {
|
|
location = {
|
|
search: jest.fn(() => ({
|
|
time: '1410337645000',
|
|
'time.window': '10s',
|
|
})),
|
|
};
|
|
|
|
timeSrv = new TimeSrv(rootScope as any, jest.fn() as any, location as any, timer, new ContextSrvStub() as any);
|
|
|
|
timeSrv.init(_dashboard);
|
|
const time = timeSrv.timeRange();
|
|
expect(time.from.valueOf()).toEqual(1410337640000);
|
|
expect(time.to.valueOf()).toEqual(1410337650000);
|
|
});
|
|
it('handles time window specified in ms', () => {
|
|
location = {
|
|
search: jest.fn(() => ({
|
|
time: '1410337645000',
|
|
'time.window': '10000',
|
|
})),
|
|
};
|
|
|
|
timeSrv = new TimeSrv(rootScope as any, jest.fn() as any, location as any, timer, new ContextSrvStub() as any);
|
|
|
|
timeSrv.init(_dashboard);
|
|
const time = timeSrv.timeRange();
|
|
expect(time.from.valueOf()).toEqual(1410337640000);
|
|
expect(time.to.valueOf()).toEqual(1410337650000);
|
|
});
|
|
});
|
|
});
|
|
|
|
describe('setTime', () => {
|
|
it('should return disable refresh if refresh is disabled for any range', () => {
|
|
_dashboard.refresh = false;
|
|
|
|
timeSrv.setTime({ from: '2011-01-01', to: '2015-01-01' });
|
|
expect(_dashboard.refresh).toBe(false);
|
|
});
|
|
|
|
it('should restore refresh for absolute time range', () => {
|
|
_dashboard.refresh = '30s';
|
|
|
|
timeSrv.setTime({ from: '2011-01-01', to: '2015-01-01' });
|
|
expect(_dashboard.refresh).toBe('30s');
|
|
});
|
|
|
|
it('should restore refresh after relative time range is set', () => {
|
|
_dashboard.refresh = '10s';
|
|
timeSrv.setTime({
|
|
from: dateTime([2011, 1, 1]),
|
|
to: dateTime([2015, 1, 1]),
|
|
});
|
|
expect(_dashboard.refresh).toBe(false);
|
|
timeSrv.setTime({ from: '2011-01-01', to: 'now' });
|
|
expect(_dashboard.refresh).toBe('10s');
|
|
});
|
|
|
|
it('should keep refresh after relative time range is changed and now delay exists', () => {
|
|
_dashboard.refresh = '10s';
|
|
timeSrv.setTime({ from: 'now-1h', to: 'now-10s' });
|
|
expect(_dashboard.refresh).toBe('10s');
|
|
});
|
|
});
|
|
});
|