cluster_controller_test.js 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574
  1. /**
  2. * Licensed to the Apache Software Foundation (ASF) under one
  3. * or more contributor license agreements. See the NOTICE file
  4. * distributed with this work for additional information
  5. * regarding copyright ownership. The ASF licenses this file
  6. * to you under the Apache License, Version 2.0 (the
  7. * "License"); you may not use this file except in compliance
  8. * with the License. You may obtain a copy of the License at
  9. *
  10. * http://www.apache.org/licenses/LICENSE-2.0
  11. *
  12. * Unless required by applicable law or agreed to in writing, software
  13. * distributed under the License is distributed on an "AS IS" BASIS,
  14. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  15. * See the License for the specific language governing permissions and
  16. * limitations under the License.
  17. */
  18. var App = require('app');
  19. var credentialUtils = require('utils/credentials');
  20. var testHelpers = require('test/helpers');
  21. require('controllers/global/cluster_controller');
  22. require('models/host_component');
  23. require('utils/http_client');
  24. require('models/service');
  25. require('models/host');
  26. require('utils/ajax/ajax');
  27. require('utils/string_utils');
  28. var modelSetup = require('test/init_model_test');
  29. describe('App.clusterController', function () {
  30. var controller = App.ClusterController.create();
  31. App.Service.FIXTURES = [
  32. {service_name: 'GANGLIA'}
  33. ];
  34. App.TestAliases.testAsComputedAnd(controller, 'isHostContentLoaded', ['isHostsLoaded', 'isComponentsStateLoaded']);
  35. App.TestAliases.testAsComputedAnd(controller, 'isServiceContentFullyLoaded', ['isServiceMetricsLoaded', 'isComponentsStateLoaded', 'isComponentsConfigLoaded']);
  36. App.TestAliases.testAsComputedAlias(controller, 'clusterName', 'App.clusterName', 'string');
  37. describe('#updateLoadStatus()', function () {
  38. controller.set('dataLoadList', Em.Object.create({
  39. 'item1': false,
  40. 'item2': false
  41. }));
  42. it('when none item is loaded then width should be "width:0"', function () {
  43. expect(controller.get('clusterDataLoadedPercent')).to.equal('width:0');
  44. });
  45. it('when first item is loaded then isLoaded should be false', function () {
  46. controller.updateLoadStatus('item1');
  47. expect(controller.get('isLoaded')).to.equal(false);
  48. });
  49. it('when first item is loaded then width should be "width:50%"', function () {
  50. controller.updateLoadStatus('item1');
  51. expect(controller.get('clusterDataLoadedPercent')).to.equal('width:50%');
  52. });
  53. it('when all items are loaded then isLoaded should be true', function () {
  54. controller.updateLoadStatus('item2');
  55. expect(controller.get('isLoaded')).to.equal(true);
  56. });
  57. it('when all items are loaded then width should be "width:100%"', function () {
  58. controller.updateLoadStatus('item2');
  59. expect(controller.get('clusterDataLoadedPercent')).to.equal('width:100%');
  60. });
  61. });
  62. describe('#loadClusterName()', function () {
  63. beforeEach(function () {
  64. modelSetup.setupStackVersion(this, 'HDP-2.0.5');
  65. App.ajax.send.restore(); // default ajax-mock can't be used here
  66. sinon.stub(App.ajax, 'send', function () {
  67. return {
  68. then: function (successCallback) {
  69. App.set('clusterName', 'clusterNameFromServer');
  70. App.set('currentStackVersion', 'HDP-2.0.5');
  71. successCallback();
  72. }
  73. }
  74. });
  75. this.args = testHelpers.findAjaxRequest('name', 'cluster.load_cluster_name');
  76. });
  77. afterEach(function () {
  78. modelSetup.restoreStackVersion(this);
  79. });
  80. it('if clusterName is "mycluster" and reload is false then clusterName stays the same', function () {
  81. App.set('clusterName', 'mycluster');
  82. controller.loadClusterName(false);
  83. expect(this.args).to.not.exists;
  84. expect(App.get('clusterName')).to.equal('mycluster');
  85. });
  86. it('reload is true and clusterName is not empty', function () {
  87. controller.loadClusterName(true);
  88. expect(this.args).to.exists;
  89. expect(App.get('clusterName')).to.equal('clusterNameFromServer');
  90. expect(App.get('currentStackVersion')).to.equal('HDP-2.0.5');
  91. });
  92. it('reload is false and clusterName is empty', function () {
  93. App.set('clusterName', '');
  94. controller.loadClusterName(false);
  95. expect(this.args).to.exists;
  96. expect(App.get('clusterName')).to.equal('clusterNameFromServer');
  97. expect(App.get('currentStackVersion')).to.equal('HDP-2.0.5');
  98. });
  99. });
  100. describe('#reloadSuccessCallback', function () {
  101. var testData = {
  102. "items": [
  103. {
  104. "Clusters": {
  105. "cluster_name": "tdk",
  106. "version": "HDP-1.3.0"
  107. }
  108. }
  109. ]
  110. };
  111. it('Check cluster', function () {
  112. controller.reloadSuccessCallback(testData);
  113. expect(App.get('clusterName')).to.equal('tdk');
  114. expect(App.get('currentStackVersion')).to.equal('HDP-1.3.0');
  115. });
  116. });
  117. describe('#getServerClockSuccessCallback()', function () {
  118. var testCases = [
  119. {
  120. title: 'if server clock is 1 then currentServerTime should be 1000',
  121. data: {
  122. RootServiceComponents: {
  123. server_clock: 1
  124. }
  125. },
  126. result: 1000
  127. },
  128. {
  129. title: 'if server clock is 0 then currentServerTime should be 0',
  130. data: {
  131. RootServiceComponents: {
  132. server_clock: 0
  133. }
  134. },
  135. result: 0
  136. },
  137. {
  138. title: 'if server clock is 111111111111 then currentServerTime should be 111111111111000',
  139. data: {
  140. RootServiceComponents: {
  141. server_clock: 111111111111
  142. }
  143. },
  144. result: 111111111111000
  145. },
  146. {
  147. title: 'if server clock is 1111111111113 then currentServerTime should be 1111111111113',
  148. data: {
  149. RootServiceComponents: {
  150. server_clock: 1111111111113
  151. }
  152. },
  153. result: 1111111111113
  154. }
  155. ];
  156. var currentServerTime = App.get('currentServerTime');
  157. var clockDistance = App.get('clockDistance');
  158. testCases.forEach(function (test) {
  159. it(test.title, function () {
  160. controller.getServerClockSuccessCallback(test.data);
  161. expect(App.get('currentServerTime')).to.equal(test.result);
  162. App.set('clockDistance', clockDistance);
  163. App.set('currentServerTime', currentServerTime);
  164. });
  165. });
  166. });
  167. describe('#getUrl', function () {
  168. controller.set('clusterName', 'tdk');
  169. var tests = ['test1', 'test2', 'test3'];
  170. tests.forEach(function (test) {
  171. it(test, function () {
  172. expect(controller.getUrl(test, test)).to.equal(App.apiPrefix + '/clusters/' + controller.get('clusterName') + test);
  173. });
  174. });
  175. });
  176. describe("#createKerberosAdminSession()", function() {
  177. beforeEach(function () {
  178. sinon.stub(credentialUtils, 'createOrUpdateCredentials', function() {
  179. return $.Deferred().resolve().promise();
  180. });
  181. this.stub = sinon.stub(App, 'get');
  182. this.stub.withArgs('clusterName').returns('test');
  183. });
  184. afterEach(function () {
  185. credentialUtils.createOrUpdateCredentials.restore();
  186. App.get.restore();
  187. });
  188. it("credentials updated via credentials storage call", function() {
  189. controller.createKerberosAdminSession({
  190. principal: 'admin',
  191. key: 'pass',
  192. type: 'persistent'
  193. }, {});
  194. var args = testHelpers.findAjaxRequest('name', 'common.cluster.update');
  195. expect(args).to.not.exists;
  196. expect(credentialUtils.createOrUpdateCredentials.getCall(0).args).to.eql([
  197. 'test', 'kdc.admin.credential', {
  198. principal: 'admin',
  199. key: 'pass',
  200. type: 'persistent'
  201. }
  202. ]);
  203. });
  204. });
  205. describe('#checkDetailedRepoVersion()', function () {
  206. var cases = [
  207. {
  208. currentStackName: 'HDP',
  209. currentStackVersionNumber: '2.1',
  210. isStormMetricsSupported: false,
  211. title: 'HDP < 2.2'
  212. },
  213. {
  214. currentStackName: 'HDP',
  215. currentStackVersionNumber: '2.3',
  216. isStormMetricsSupported: true,
  217. title: 'HDP > 2.2'
  218. },
  219. {
  220. currentStackName: 'BIGTOP',
  221. currentStackVersionNumber: '0.8',
  222. isStormMetricsSupported: true,
  223. title: 'not HDP'
  224. }
  225. ];
  226. afterEach(function () {
  227. App.get.restore();
  228. });
  229. describe('should check detailed repo version for HDP 2.2', function () {
  230. beforeEach(function () {
  231. sinon.stub(App, 'get').withArgs('currentStackName').returns('HDP').withArgs('currentStackVersionNumber').returns('2.2');
  232. });
  233. it('request is sent', function () {
  234. controller.checkDetailedRepoVersion();
  235. var args = testHelpers.findAjaxRequest('name', 'cluster.load_detailed_repo_version');
  236. expect(args).to.exists;
  237. });
  238. });
  239. cases.forEach(function (item) {
  240. describe(item.title, function () {
  241. beforeEach(function () {
  242. sinon.stub(App, 'get', function (key) {
  243. return item[key] || Em.get(App, key);
  244. });
  245. controller.checkDetailedRepoVersion();
  246. });
  247. it('request is not sent', function () {
  248. var args = testHelpers.findAjaxRequest('name', 'cluster.load_detailed_repo_version');
  249. expect(args).to.not.exists;
  250. });
  251. it('App.isStormMetricsSupported is ' + item.isStormMetricsSupported, function () {
  252. expect(App.get('isStormMetricsSupported')).to.equal(item.isStormMetricsSupported);
  253. });
  254. });
  255. });
  256. });
  257. describe('#checkDetailedRepoVersionSuccessCallback()', function () {
  258. beforeEach(function () {
  259. sinon.stub(App, 'get', function(key) {
  260. if (key === 'currentStackName') {
  261. return 'HDP';
  262. }
  263. if (key === 'currentStackVersionNumber') {
  264. return '2.2';
  265. }
  266. return Em.get(App, key);
  267. });
  268. });
  269. afterEach(function() {
  270. App.get.restore();
  271. });
  272. var cases = [
  273. {
  274. items: [
  275. {
  276. ClusterStackVersions: {
  277. stack: 'HDP',
  278. version: '2.2'
  279. },
  280. repository_versions: [
  281. {
  282. RepositoryVersions: {
  283. repository_version: '2.1'
  284. }
  285. }
  286. ]
  287. }
  288. ],
  289. isStormMetricsSupported: false,
  290. title: 'HDP < 2.2.2'
  291. },
  292. {
  293. items: [
  294. {
  295. ClusterStackVersions: {
  296. stack: 'HDP',
  297. version: '2.2'
  298. },
  299. repository_versions: [
  300. {
  301. RepositoryVersions: {
  302. repository_version: '2.2.2'
  303. }
  304. }
  305. ]
  306. }
  307. ],
  308. isStormMetricsSupported: true,
  309. title: 'HDP 2.2.2'
  310. },
  311. {
  312. items: [
  313. {
  314. repository_versions: [
  315. {
  316. RepositoryVersions: {
  317. repository_version: '2.2.3'
  318. }
  319. }
  320. ]
  321. }
  322. ],
  323. isStormMetricsSupported: true,
  324. title: 'HDP > 2.2.2'
  325. },
  326. {
  327. items: null,
  328. isStormMetricsSupported: true,
  329. title: 'empty response'
  330. },
  331. {
  332. items: [],
  333. isStormMetricsSupported: true,
  334. title: 'no items'
  335. },
  336. {
  337. items: [{}],
  338. isStormMetricsSupported: true,
  339. title: 'empty item'
  340. },
  341. {
  342. items: [{
  343. repository_versions: []
  344. }],
  345. isStormMetricsSupported: true,
  346. title: 'no versions'
  347. },
  348. {
  349. items: [{
  350. repository_versions: [{}]
  351. }],
  352. isStormMetricsSupported: true,
  353. title: 'no version info'
  354. },
  355. {
  356. items: [{
  357. repository_versions: [
  358. {
  359. RepositoryVersions: {}
  360. }
  361. ]
  362. }],
  363. isStormMetricsSupported: true,
  364. title: 'empty version info'
  365. }
  366. ];
  367. cases.forEach(function (item) {
  368. it(item.title, function () {
  369. controller.checkDetailedRepoVersionSuccessCallback({
  370. items: item.items
  371. });
  372. expect(App.get('isStormMetricsSupported')).to.equal(item.isStormMetricsSupported);
  373. });
  374. });
  375. });
  376. describe('#checkDetailedRepoVersionErrorCallback()', function () {
  377. it('should set isStormMetricsSupported to default value', function () {
  378. controller.checkDetailedRepoVersionErrorCallback();
  379. expect(App.get('isStormMetricsSupported')).to.be.true;
  380. });
  381. });
  382. describe('#getAllUpgrades()', function () {
  383. it('should send request to get upgrades data', function () {
  384. controller.getAllUpgrades();
  385. var args = testHelpers.findAjaxRequest('name', 'cluster.load_last_upgrade');
  386. expect(args).to.exists;
  387. });
  388. });
  389. describe("#restoreUpgradeState()", function() {
  390. var data = {upgradeData: {}};
  391. var mock = {
  392. done: function (callback) {
  393. callback(data.upgradeData);
  394. }
  395. };
  396. var upgradeController = Em.Object.create({
  397. restoreLastUpgrade: Em.K,
  398. initDBProperties: Em.K,
  399. loadUpgradeData: Em.K,
  400. loadStackVersionsToModel: function () {
  401. return {done: Em.K};
  402. }
  403. });
  404. beforeEach(function () {
  405. sinon.stub(controller, 'getAllUpgrades').returns(mock);
  406. sinon.spy(mock, 'done');
  407. sinon.stub(App.router, 'get').returns(upgradeController);
  408. sinon.stub(App.db, 'get').returns('PENDING');
  409. sinon.spy(upgradeController, 'restoreLastUpgrade');
  410. sinon.spy(upgradeController, 'initDBProperties');
  411. sinon.spy(upgradeController, 'loadUpgradeData');
  412. sinon.spy(upgradeController, 'loadStackVersionsToModel');
  413. });
  414. afterEach(function () {
  415. mock.done.restore();
  416. controller.getAllUpgrades.restore();
  417. App.router.get.restore();
  418. App.db.get.restore();
  419. upgradeController.restoreLastUpgrade.restore();
  420. upgradeController.initDBProperties.restore();
  421. upgradeController.loadUpgradeData.restore();
  422. upgradeController.loadStackVersionsToModel.restore();
  423. });
  424. describe("has upgrade request", function() {
  425. beforeEach(function () {
  426. data.upgradeData = {items: [
  427. {
  428. Upgrade: {
  429. request_id: 1
  430. }
  431. }
  432. ]};
  433. controller.restoreUpgradeState();
  434. });
  435. it('getAllUpgrades is called once', function () {
  436. expect(controller.getAllUpgrades.calledOnce).to.be.true;
  437. });
  438. it('upgradeState is PENDING', function () {
  439. expect(App.get('upgradeState')).to.equal('PENDING');
  440. });
  441. it('restoreLastUpgrade is called with valid arguments', function () {
  442. expect(upgradeController.restoreLastUpgrade.calledWith(data.upgradeData.items[0])).to.be.true;
  443. });
  444. it('loadStackVersionsToModel is called with valid arguments', function () {
  445. expect(upgradeController.loadStackVersionsToModel.calledWith(true)).to.be.true;
  446. });
  447. it('initDBProperties is not called', function () {
  448. expect(upgradeController.initDBProperties.called).to.be.false;
  449. });
  450. it('loadUpgradeData is not called', function () {
  451. expect(upgradeController.loadUpgradeData.called).to.be.false;
  452. });
  453. });
  454. describe("has completed upgrade request", function() {
  455. beforeEach(function () {
  456. data.upgradeData = {items: [
  457. {
  458. Upgrade: {
  459. request_id: 1,
  460. request_status: 'COMPLETED'
  461. }
  462. }
  463. ]};
  464. controller.restoreUpgradeState();
  465. });
  466. it('getAllUpgrades is called once', function () {
  467. expect(controller.getAllUpgrades.calledOnce).to.be.true;
  468. });
  469. it('restoreLastUpgrade should not be called', function () {
  470. expect(upgradeController.restoreLastUpgrade.called).to.be.false;
  471. });
  472. it('loadStackVersionsToModel should be called', function () {
  473. expect(upgradeController.loadStackVersionsToModel).to.be.calledOnce;
  474. });
  475. });
  476. describe("does not have upgrade request", function() {
  477. beforeEach(function () {
  478. data.upgradeData = {items: []};
  479. controller.restoreUpgradeState();
  480. });
  481. it('getAllUpgrades is called once', function () {
  482. expect(controller.getAllUpgrades.calledOnce).to.be.true;
  483. });
  484. it('upgradeState is PENDING', function () {
  485. expect(App.get('upgradeState')).to.equal('PENDING');
  486. });
  487. it('restoreLastUpgrade is not called', function () {
  488. expect(upgradeController.restoreLastUpgrade.called).to.be.false;
  489. });
  490. it('loadStackVersionsToModel is called with valid arguments', function () {
  491. expect(upgradeController.loadStackVersionsToModel.calledWith(true)).to.be.true;
  492. });
  493. it('initDBProperties is called once', function () {
  494. expect(upgradeController.initDBProperties.calledOnce).to.be.true;
  495. });
  496. it('loadUpgradeData is called with valid arguments', function () {
  497. expect(upgradeController.loadUpgradeData.calledWith(true)).to.be.true;
  498. });
  499. });
  500. });
  501. });