manage_dashboards.test.ts 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566
  1. import { ManageDashboardsCtrl } from 'app/core/components/manage_dashboards/manage_dashboards';
  2. import { SearchSrv } from 'app/core/services/search_srv';
  3. import q from 'q';
  4. describe('ManageDashboards', () => {
  5. let ctrl;
  6. describe('when browsing dashboards', () => {
  7. beforeEach(() => {
  8. const response = [
  9. {
  10. id: 410,
  11. title: 'afolder',
  12. type: 'dash-folder',
  13. items: [
  14. {
  15. id: 399,
  16. title: 'Dashboard Test',
  17. url: 'dashboard/db/dashboard-test',
  18. icon: 'fa fa-folder',
  19. tags: [],
  20. isStarred: false,
  21. },
  22. ],
  23. tags: [],
  24. isStarred: false,
  25. },
  26. {
  27. id: 0,
  28. title: 'General',
  29. icon: 'fa fa-folder-open',
  30. uri: 'db/something-else',
  31. type: 'dash-db',
  32. items: [
  33. {
  34. id: 500,
  35. title: 'Dashboard Test',
  36. url: 'dashboard/db/dashboard-test',
  37. icon: 'fa fa-folder',
  38. tags: [],
  39. isStarred: false,
  40. },
  41. ],
  42. tags: [],
  43. isStarred: false,
  44. },
  45. ];
  46. ctrl = createCtrlWithStubs(response);
  47. return ctrl.refreshList();
  48. });
  49. it('should set checked to false on all sections and children', () => {
  50. expect(ctrl.sections.length).toEqual(2);
  51. expect(ctrl.sections[0].checked).toEqual(false);
  52. expect(ctrl.sections[0].items[0].checked).toEqual(false);
  53. expect(ctrl.sections[1].checked).toEqual(false);
  54. expect(ctrl.sections[1].items[0].checked).toEqual(false);
  55. expect(ctrl.sections[0].hideHeader).toBeFalsy();
  56. });
  57. });
  58. describe('when browsing dashboards for a folder', () => {
  59. beforeEach(() => {
  60. const response = [
  61. {
  62. id: 410,
  63. title: 'afolder',
  64. type: 'dash-folder',
  65. items: [
  66. {
  67. id: 399,
  68. title: 'Dashboard Test',
  69. url: 'dashboard/db/dashboard-test',
  70. icon: 'fa fa-folder',
  71. tags: [],
  72. isStarred: false,
  73. },
  74. ],
  75. tags: [],
  76. isStarred: false,
  77. },
  78. ];
  79. ctrl = createCtrlWithStubs(response);
  80. ctrl.folderId = 410;
  81. return ctrl.refreshList();
  82. });
  83. it('should set hide header to true on section', () => {
  84. expect(ctrl.sections[0].hideHeader).toBeTruthy();
  85. });
  86. });
  87. describe('when searching dashboards', () => {
  88. beforeEach(() => {
  89. const response = [
  90. {
  91. checked: false,
  92. expanded: true,
  93. hideHeader: true,
  94. items: [
  95. {
  96. id: 399,
  97. title: 'Dashboard Test',
  98. url: 'dashboard/db/dashboard-test',
  99. icon: 'fa fa-folder',
  100. tags: [],
  101. isStarred: false,
  102. folderId: 410,
  103. folderUid: 'uid',
  104. folderTitle: 'Folder',
  105. folderUrl: '/dashboards/f/uid/folder',
  106. },
  107. {
  108. id: 500,
  109. title: 'Dashboard Test',
  110. url: 'dashboard/db/dashboard-test',
  111. icon: 'fa fa-folder',
  112. tags: [],
  113. folderId: 499,
  114. isStarred: false,
  115. },
  116. ],
  117. },
  118. ];
  119. ctrl = createCtrlWithStubs(response);
  120. });
  121. describe('with query filter', () => {
  122. beforeEach(() => {
  123. ctrl.query.query = 'd';
  124. ctrl.canMove = true;
  125. ctrl.canDelete = true;
  126. ctrl.selectAllChecked = true;
  127. return ctrl.refreshList();
  128. });
  129. it('should set checked to false on all sections and children', () => {
  130. expect(ctrl.sections.length).toEqual(1);
  131. expect(ctrl.sections[0].checked).toEqual(false);
  132. expect(ctrl.sections[0].items[0].checked).toEqual(false);
  133. expect(ctrl.sections[0].items[1].checked).toEqual(false);
  134. });
  135. it('should uncheck select all', () => {
  136. expect(ctrl.selectAllChecked).toBeFalsy();
  137. });
  138. it('should disable Move To button', () => {
  139. expect(ctrl.canMove).toBeFalsy();
  140. });
  141. it('should disable delete button', () => {
  142. expect(ctrl.canDelete).toBeFalsy();
  143. });
  144. it('should have active filters', () => {
  145. expect(ctrl.hasFilters).toBeTruthy();
  146. });
  147. describe('when select all is checked', () => {
  148. beforeEach(() => {
  149. ctrl.selectAllChecked = true;
  150. ctrl.onSelectAllChanged();
  151. });
  152. it('should select all dashboards', () => {
  153. expect(ctrl.sections[0].checked).toBeFalsy();
  154. expect(ctrl.sections[0].items[0].checked).toBeTruthy();
  155. expect(ctrl.sections[0].items[1].checked).toBeTruthy();
  156. });
  157. it('should enable Move To button', () => {
  158. expect(ctrl.canMove).toBeTruthy();
  159. });
  160. it('should enable delete button', () => {
  161. expect(ctrl.canDelete).toBeTruthy();
  162. });
  163. describe('when clearing filters', () => {
  164. beforeEach(() => {
  165. return ctrl.clearFilters();
  166. });
  167. it('should reset query filter', () => {
  168. expect(ctrl.query.query).toEqual('');
  169. });
  170. });
  171. });
  172. });
  173. describe('with tag filter', () => {
  174. beforeEach(() => {
  175. return ctrl.filterByTag('test');
  176. });
  177. it('should set tag filter', () => {
  178. expect(ctrl.sections.length).toEqual(1);
  179. expect(ctrl.query.tag[0]).toEqual('test');
  180. });
  181. it('should have active filters', () => {
  182. expect(ctrl.hasFilters).toBeTruthy();
  183. });
  184. describe('when clearing filters', () => {
  185. beforeEach(() => {
  186. return ctrl.clearFilters();
  187. });
  188. it('should reset tag filter', () => {
  189. expect(ctrl.query.tag.length).toEqual(0);
  190. });
  191. });
  192. });
  193. describe('with starred filter', () => {
  194. beforeEach(() => {
  195. const yesOption: any = ctrl.starredFilterOptions[1];
  196. ctrl.selectedStarredFilter = yesOption;
  197. return ctrl.onStarredFilterChange();
  198. });
  199. it('should set starred filter', () => {
  200. expect(ctrl.sections.length).toEqual(1);
  201. expect(ctrl.query.starred).toEqual(true);
  202. });
  203. it('should have active filters', () => {
  204. expect(ctrl.hasFilters).toBeTruthy();
  205. });
  206. describe('when clearing filters', () => {
  207. beforeEach(() => {
  208. return ctrl.clearFilters();
  209. });
  210. it('should reset starred filter', () => {
  211. expect(ctrl.query.starred).toEqual(false);
  212. });
  213. });
  214. });
  215. });
  216. describe('when selecting dashboards', () => {
  217. let ctrl;
  218. beforeEach(() => {
  219. ctrl = createCtrlWithStubs([]);
  220. });
  221. describe('and no dashboards are selected', () => {
  222. beforeEach(() => {
  223. ctrl.sections = [
  224. {
  225. id: 1,
  226. items: [{ id: 2, checked: false }],
  227. checked: false,
  228. },
  229. {
  230. id: 0,
  231. items: [{ id: 3, checked: false }],
  232. checked: false,
  233. },
  234. ];
  235. ctrl.selectionChanged();
  236. });
  237. it('should disable Move To button', () => {
  238. expect(ctrl.canMove).toBeFalsy();
  239. });
  240. it('should disable delete button', () => {
  241. expect(ctrl.canDelete).toBeFalsy();
  242. });
  243. describe('when select all is checked', () => {
  244. beforeEach(() => {
  245. ctrl.selectAllChecked = true;
  246. ctrl.onSelectAllChanged();
  247. });
  248. it('should select all folders and dashboards', () => {
  249. expect(ctrl.sections[0].checked).toBeTruthy();
  250. expect(ctrl.sections[0].items[0].checked).toBeTruthy();
  251. expect(ctrl.sections[1].checked).toBeTruthy();
  252. expect(ctrl.sections[1].items[0].checked).toBeTruthy();
  253. });
  254. it('should enable Move To button', () => {
  255. expect(ctrl.canMove).toBeTruthy();
  256. });
  257. it('should enable delete button', () => {
  258. expect(ctrl.canDelete).toBeTruthy();
  259. });
  260. });
  261. });
  262. describe('and all folders and dashboards are selected', () => {
  263. beforeEach(() => {
  264. ctrl.sections = [
  265. {
  266. id: 1,
  267. items: [{ id: 2, checked: true }],
  268. checked: true,
  269. },
  270. {
  271. id: 0,
  272. items: [{ id: 3, checked: true }],
  273. checked: true,
  274. },
  275. ];
  276. ctrl.selectionChanged();
  277. });
  278. it('should enable Move To button', () => {
  279. expect(ctrl.canMove).toBeTruthy();
  280. });
  281. it('should enable delete button', () => {
  282. expect(ctrl.canDelete).toBeTruthy();
  283. });
  284. describe('when select all is unchecked', () => {
  285. beforeEach(() => {
  286. ctrl.selectAllChecked = false;
  287. ctrl.onSelectAllChanged();
  288. });
  289. it('should uncheck all checked folders and dashboards', () => {
  290. expect(ctrl.sections[0].checked).toBeFalsy();
  291. expect(ctrl.sections[0].items[0].checked).toBeFalsy();
  292. expect(ctrl.sections[1].checked).toBeFalsy();
  293. expect(ctrl.sections[1].items[0].checked).toBeFalsy();
  294. });
  295. it('should disable Move To button', () => {
  296. expect(ctrl.canMove).toBeFalsy();
  297. });
  298. it('should disable delete button', () => {
  299. expect(ctrl.canDelete).toBeFalsy();
  300. });
  301. });
  302. });
  303. describe('and one dashboard in root is selected', () => {
  304. beforeEach(() => {
  305. ctrl.sections = [
  306. {
  307. id: 1,
  308. title: 'folder',
  309. items: [{ id: 2, checked: false }],
  310. checked: false,
  311. },
  312. {
  313. id: 0,
  314. title: 'General',
  315. items: [{ id: 3, checked: true }],
  316. checked: false,
  317. },
  318. ];
  319. ctrl.selectionChanged();
  320. });
  321. it('should enable Move To button', () => {
  322. expect(ctrl.canMove).toBeTruthy();
  323. });
  324. it('should enable delete button', () => {
  325. expect(ctrl.canDelete).toBeTruthy();
  326. });
  327. });
  328. describe('and one child dashboard is selected', () => {
  329. beforeEach(() => {
  330. ctrl.sections = [
  331. {
  332. id: 1,
  333. title: 'folder',
  334. items: [{ id: 2, checked: true }],
  335. checked: false,
  336. },
  337. {
  338. id: 0,
  339. title: 'General',
  340. items: [{ id: 3, checked: false }],
  341. checked: false,
  342. },
  343. ];
  344. ctrl.selectionChanged();
  345. });
  346. it('should enable Move To button', () => {
  347. expect(ctrl.canMove).toBeTruthy();
  348. });
  349. it('should enable delete button', () => {
  350. expect(ctrl.canDelete).toBeTruthy();
  351. });
  352. });
  353. describe('and one child dashboard and one dashboard is selected', () => {
  354. beforeEach(() => {
  355. ctrl.sections = [
  356. {
  357. id: 1,
  358. title: 'folder',
  359. items: [{ id: 2, checked: true }],
  360. checked: false,
  361. },
  362. {
  363. id: 0,
  364. title: 'General',
  365. items: [{ id: 3, checked: true }],
  366. checked: false,
  367. },
  368. ];
  369. ctrl.selectionChanged();
  370. });
  371. it('should enable Move To button', () => {
  372. expect(ctrl.canMove).toBeTruthy();
  373. });
  374. it('should enable delete button', () => {
  375. expect(ctrl.canDelete).toBeTruthy();
  376. });
  377. });
  378. describe('and one child dashboard and one folder is selected', () => {
  379. beforeEach(() => {
  380. ctrl.sections = [
  381. {
  382. id: 1,
  383. title: 'folder',
  384. items: [{ id: 2, checked: false }],
  385. checked: true,
  386. },
  387. {
  388. id: 3,
  389. title: 'folder',
  390. items: [{ id: 4, checked: true }],
  391. checked: false,
  392. },
  393. {
  394. id: 0,
  395. title: 'General',
  396. items: [{ id: 3, checked: false }],
  397. checked: false,
  398. },
  399. ];
  400. ctrl.selectionChanged();
  401. });
  402. it('should enable Move To button', () => {
  403. expect(ctrl.canMove).toBeTruthy();
  404. });
  405. it('should enable delete button', () => {
  406. expect(ctrl.canDelete).toBeTruthy();
  407. });
  408. });
  409. });
  410. describe('when deleting dashboards', () => {
  411. let toBeDeleted: any;
  412. beforeEach(() => {
  413. ctrl = createCtrlWithStubs([]);
  414. ctrl.sections = [
  415. {
  416. id: 1,
  417. uid: 'folder',
  418. title: 'folder',
  419. items: [{ id: 2, checked: true, uid: 'folder-dash' }],
  420. checked: true,
  421. },
  422. {
  423. id: 3,
  424. title: 'folder-2',
  425. items: [{ id: 3, checked: true, uid: 'folder-2-dash' }],
  426. checked: false,
  427. uid: 'folder-2',
  428. },
  429. {
  430. id: 0,
  431. title: 'General',
  432. items: [{ id: 3, checked: true, uid: 'root-dash' }],
  433. checked: true,
  434. },
  435. ];
  436. toBeDeleted = ctrl.getFoldersAndDashboardsToDelete();
  437. });
  438. it('should return 1 folder', () => {
  439. expect(toBeDeleted.folders.length).toEqual(1);
  440. });
  441. it('should return 2 dashboards', () => {
  442. expect(toBeDeleted.dashboards.length).toEqual(2);
  443. });
  444. it('should filter out children if parent is checked', () => {
  445. expect(toBeDeleted.folders[0]).toEqual('folder');
  446. });
  447. it('should not filter out children if parent not is checked', () => {
  448. expect(toBeDeleted.dashboards[0]).toEqual('folder-2-dash');
  449. });
  450. it('should not filter out children if parent is checked and root', () => {
  451. expect(toBeDeleted.dashboards[1]).toEqual('root-dash');
  452. });
  453. });
  454. describe('when moving dashboards', () => {
  455. beforeEach(() => {
  456. ctrl = createCtrlWithStubs([]);
  457. ctrl.sections = [
  458. {
  459. id: 1,
  460. title: 'folder',
  461. items: [{ id: 2, checked: true, uid: 'dash' }],
  462. checked: false,
  463. uid: 'folder',
  464. },
  465. {
  466. id: 0,
  467. title: 'General',
  468. items: [{ id: 3, checked: true, uid: 'dash-2' }],
  469. checked: false,
  470. },
  471. ];
  472. });
  473. it('should get selected dashboards', () => {
  474. const toBeMove = ctrl.getDashboardsToMove();
  475. expect(toBeMove.length).toEqual(2);
  476. expect(toBeMove[0]).toEqual('dash');
  477. expect(toBeMove[1]).toEqual('dash-2');
  478. });
  479. });
  480. });
  481. function createCtrlWithStubs(searchResponse: any, tags?: any) {
  482. const searchSrvStub = {
  483. search: (options: any) => {
  484. return q.resolve(searchResponse);
  485. },
  486. getDashboardTags: () => {
  487. return q.resolve(tags || []);
  488. },
  489. };
  490. return new ManageDashboardsCtrl({}, { getNav: () => {} }, searchSrvStub as SearchSrv, { isEditor: true });
  491. }