//import { describe, beforeEach, it, sinon, expect, angularMocks } from 'test/lib/common'; import _ from 'lodash'; import { HistoryListCtrl } from 'app/features/dashboard/history/history'; import { versions, compare, restore } from './history_mocks'; import $q from 'q'; describe('HistoryListCtrl', () => { const RESTORE_ID = 4; const versionsResponse: any = versions(); restore(7, RESTORE_ID); //beforeEach(angularMocks.module('grafana.core')); //beforeEach(angularMocks.module('grafana.services')); // beforeEach( // angularMocks.inject($rootScope => { // ctx.scope = $rootScope.$new(); // }) // ); let historySrv; let $rootScope; let historyListCtrl; beforeEach(() => { historySrv = { // getHistoryList: jest.fn( ()=> $q.when(versionsResponse)), calculateDiff: jest.fn(), restoreDashboard: jest.fn(() => $q.when({})), }; $rootScope = { appEvent: jest.fn(), onAppEvent: jest.fn(), }; // historyListCtrl = new HistoryListCtrl({},$rootScope,{},$q,historySrv, {}); }); describe('when the history list component is loaded', () => { let deferred; beforeEach(() => { deferred = $q.defer({}); historySrv.getHistoryList = jest.fn(() => deferred.promise); historyListCtrl = new HistoryListCtrl({}, $rootScope, {}, $q, historySrv, {}); historyListCtrl.dashboard = { id: 2, version: 3, formatDate: jest.fn(() => 'date'), }; }); it('should immediately attempt to fetch the history list', () => { expect(historySrv.getHistoryList).toHaveBeenCalledTimes(1); }); describe('and the history list is successfully fetched', () => { beforeEach(async () => { //deferred.resolve(versionsResponse); //historyListCtrl.$scope.$apply(); deferred.resolve(versionsResponse); await historyListCtrl.getLog(); }); it("should reset the controller's state", async () => { expect(historyListCtrl.mode).toBe('list'); expect(historyListCtrl.delta).toEqual({ basic: '', json: '' }); expect(historyListCtrl.canCompare).toBe(false); expect(_.find(historyListCtrl.revisions, rev => rev.checked)).toBe(undefined); }); it('should indicate loading has finished', function() { expect(historyListCtrl.loading).toBe(false); }); it('should store the revisions sorted desc by version id', function() { expect(historyListCtrl.revisions[0].version).toBe(4); expect(historyListCtrl.revisions[1].version).toBe(3); expect(historyListCtrl.revisions[2].version).toBe(2); expect(historyListCtrl.revisions[3].version).toBe(1); }); it('should add a checked property to each revision', function() { var actual = _.filter(historyListCtrl.revisions, rev => rev.hasOwnProperty('checked')); expect(actual.length).toBe(4); }); it('should set all checked properties to false on reset', function() { historyListCtrl.revisions[0].checked = true; historyListCtrl.revisions[2].checked = true; historyListCtrl.reset(); var actual = _.filter(historyListCtrl.revisions, rev => !rev.checked); expect(actual.length).toBe(4); }); }); describe('and fetching the history list fails', () => { beforeEach(async () => { deferred = $q.defer(); historySrv.getHistoryList = jest.fn(() => deferred.promise); historyListCtrl = new HistoryListCtrl({}, $rootScope, {}, $q, historySrv, {}); deferred.reject(new Error('HistoryListError')); //historyListCtrl.$scope.$apply(); await historyListCtrl.getLog(); }); it("should reset the controller's state", function() { expect(historyListCtrl.mode).toBe('list'); expect(historyListCtrl.delta).toEqual({ basic: '', json: '' }); expect(_.find(historyListCtrl.revisions, rev => rev.checked)).toBe(undefined); }); it('should indicate loading has finished', function() { expect(historyListCtrl.loading).toBe(false); }); it('should have an empty revisions list', function() { expect(historyListCtrl.revisions).toEqual([]); }); }); describe('should update the history list when the dashboard is saved', function() { beforeEach(() => { historyListCtrl.dashboard = { version: 3 }; historyListCtrl.resetFromSource = jest.fn(); }); it('should listen for the `dashboard-saved` appEvent', function() { expect($rootScope.onAppEvent).toHaveBeenCalledTimes(1); expect($rootScope.onAppEvent.mock.calls[0][0]).toBe('dashboard-saved'); }); it('should call `onDashboardSaved` when the appEvent is received', function() { expect($rootScope.onAppEvent.mock.calls[0][1]).not.toBe(historyListCtrl.onDashboardSaved); expect($rootScope.onAppEvent.mock.calls[0][1].toString).toBe(historyListCtrl.onDashboardSaved.toString); }); }); }); describe('when the user wants to compare two revisions', function() { var deferred; // beforeEach( // angularMocks.inject(($controller, $q) => { // deferred = $q.defer(); // historySrv.getHistoryList.returns($q.when(versionsResponse)); // historySrv.calculateDiff.returns(deferred.promise); // historyListCtrl = $controller( // HistoryListCtrl, // { // historySrv, // $rootScope, // $scope: ctx.scope, // }, // { // dashboard: { // id: 2, // version: 3, // formatDate: sinon.stub().returns('date'), // }, // } // ); // historyListCtrl.$scope.onDashboardSaved = sinon.spy(); // historyListCtrl.$scope.$apply(); // }) // ); beforeEach(async () => { deferred = $q.defer({}); historySrv.getHistoryList = jest.fn(() => $q.when(versionsResponse)); historySrv.calculateDiff = jest.fn(() => deferred.promise); historyListCtrl = new HistoryListCtrl({}, $rootScope, {}, $q, historySrv, {}); historyListCtrl.dashboard = { id: 2, version: 3, formatDate: jest.fn(() => 'date'), }; deferred.resolve(versionsResponse); await historyListCtrl.getLog(); }); it('should have already fetched the history list', function() { expect(historySrv.getHistoryList).toHaveBeenCalledTimes(1); expect(historyListCtrl.revisions.length).toBeGreaterThan(0); }); it('should check that two valid versions are selected', function() { // [] expect(historyListCtrl.canCompare).toBe(false); // single value historyListCtrl.revisions = [{ checked: true }]; historyListCtrl.revisionSelectionChanged(); expect(historyListCtrl.canCompare).toBe(false); // both values in range historyListCtrl.revisions = [{ checked: true }, { checked: true }]; historyListCtrl.revisionSelectionChanged(); expect(historyListCtrl.canCompare).toBe(true); }); describe('and the basic diff is successfully fetched', function() { beforeEach(() => { //deferred = $q.defer(); deferred.resolve(compare('basic')); historyListCtrl.revisions[1].checked = true; historyListCtrl.revisions[3].checked = true; historyListCtrl.getDiff('basic'); //historyListCtrl.$scope.$apply(); }); it('should fetch the basic diff if two valid versions are selected', function() { expect(historySrv.calculateDiff).toHaveBeenCalledTimes(1); expect(historyListCtrl.delta.basic).toBe('
'); expect(historyListCtrl.delta.json).toBe(''); }); it('should set the basic diff view as active', function() { expect(historyListCtrl.mode).toBe('compare'); expect(historyListCtrl.diff).toBe('basic'); }); it('should indicate loading has finished', function() { expect(historyListCtrl.loading).toBe(false); }); }); describe('and the json diff is successfully fetched', function() { beforeEach(() => { deferred.resolve(compare('json')); historyListCtrl.revisions[1].checked = true; historyListCtrl.revisions[3].checked = true; historyListCtrl.getDiff('json'); //historyListCtrl.$scope.$apply(); }); it('should fetch the json diff if two valid versions are selected', function() { expect(historySrv.calculateDiff.calledOnce).toBe(true); expect(historyListCtrl.delta.basic).toBe(''); expect(historyListCtrl.delta.json).toBe('
'); }); it('should set the json diff view as active', function() { expect(historyListCtrl.mode).toBe('compare'); expect(historyListCtrl.diff).toBe('json'); }); it('should indicate loading has finished', function() { expect(historyListCtrl.loading).toBe(false); }); }); describe('and diffs have already been fetched', function() { beforeEach(async () => { deferred.resolve(compare('basic')); historyListCtrl.revisions[3].checked = true; historyListCtrl.revisions[1].checked = true; historyListCtrl.delta.basic = 'cached basic'; historyListCtrl.getDiff('basic'); }); it('should use the cached diffs instead of fetching', function() { expect(historySrv.calculateDiff.calledOnce).toBe(false); expect(historyListCtrl.delta.basic).toBe('cached basic'); }); it('should indicate loading has finished', function() { expect(historyListCtrl.loading).toBe(false); }); }); describe('and fetching the diff fails', () => { beforeEach(async () => { deferred = $q.defer({}); historySrv.calculateDiff = jest.fn(() => deferred.promise); historyListCtrl = new HistoryListCtrl({}, $rootScope, {}, $q, historySrv, {}); //await historyListCtrl.getLog(); historyListCtrl.revisions[3].checked = true; historyListCtrl.revisions[1].checked = true; historyListCtrl.getDiff('basic'); deferred.reject(new Error('DiffError')); await historySrv.calculateDiff(); }); it('should fetch the diff if two valid versions are selected', () => { expect(historySrv.calculateDiff).toHaveBeenCalledTimes(1); }); it('should return to the history list view', () => { //FAILS expect(historyListCtrl.mode).toBe('list'); }); it('should indicate loading has finished', () => { //FAILS expect(historyListCtrl.loading).toBe(false); }); it('should have an empty delta/changeset', () => { expect(historyListCtrl.delta).toEqual({ basic: '', json: '' }); }); }); }); describe('when the user wants to restore a revision', function() { var deferred; beforeEach(async () => { deferred = $q.defer(); historySrv.getHistoryList = jest.fn(() => $q.when(versionsResponse)); historySrv.restoreDashboard = jest.fn(() => deferred.promise); historyListCtrl = new HistoryListCtrl({}, $rootScope, {}, $q, historySrv, {}); historyListCtrl.dashboard = { id: 1, }; historyListCtrl.restore(); deferred.resolve(versionsResponse); await historyListCtrl.getLog(); }); it('should display a modal allowing the user to restore or cancel', () => { expect($rootScope.appEvent).toHaveBeenCalledTimes(1); expect($rootScope.appEvent.mock.calls[0][0]).toBe('confirm-modal'); }); describe('and restore fails to fetch', () => { beforeEach(async () => { deferred = $q.defer(); historySrv.getHistoryList = jest.fn(() => $q.when(versionsResponse)); historySrv.restoreDashboard = jest.fn(() => deferred.promise); historyListCtrl = new HistoryListCtrl({}, $rootScope, {}, $q, historySrv, {}); deferred.reject(new Error('RestoreError')); historyListCtrl.restoreConfirm(RESTORE_ID); await historyListCtrl.getLog(); }); it('should indicate loading has finished', () => { expect(historyListCtrl.loading).toBe(false); }); }); }); });