cluster_controller_test.js 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494
  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. require('controllers/global/cluster_controller');
  21. require('models/host_component');
  22. require('utils/http_client');
  23. require('models/service');
  24. require('models/host');
  25. require('utils/ajax/ajax');
  26. require('utils/string_utils');
  27. var modelSetup = require('test/init_model_test');
  28. describe('App.clusterController', function () {
  29. var controller = App.ClusterController.create();
  30. App.Service.FIXTURES = [
  31. {service_name: 'GANGLIA'}
  32. ];
  33. App.TestAliases.testAsComputedAlias(controller, 'clusterName', 'App.clusterName', 'string');
  34. describe('#updateLoadStatus()', function () {
  35. controller.set('dataLoadList', Em.Object.create({
  36. 'item1': false,
  37. 'item2': false
  38. }));
  39. it('when none item is loaded then width should be "width:0"', function () {
  40. expect(controller.get('clusterDataLoadedPercent')).to.equal('width:0');
  41. });
  42. it('when first item is loaded then isLoaded should be false', function () {
  43. controller.updateLoadStatus.call(controller, 'item1');
  44. expect(controller.get('isLoaded')).to.equal(false);
  45. });
  46. it('when first item is loaded then width should be "width:50%"', function () {
  47. controller.updateLoadStatus.call(controller, 'item1');
  48. expect(controller.get('clusterDataLoadedPercent')).to.equal('width:50%');
  49. });
  50. it('when all items are loaded then isLoaded should be true', function () {
  51. controller.updateLoadStatus.call(controller, 'item2');
  52. expect(controller.get('isLoaded')).to.equal(true);
  53. });
  54. it('when all items are loaded then width should be "width:100%"', function () {
  55. controller.updateLoadStatus.call(controller, 'item2');
  56. expect(controller.get('clusterDataLoadedPercent')).to.equal('width:100%');
  57. });
  58. });
  59. describe('#loadClusterName()', function () {
  60. beforeEach(function () {
  61. modelSetup.setupStackVersion(this, 'HDP-2.0.5');
  62. sinon.stub(App.ajax, 'send', function () {
  63. return {
  64. then: function (successCallback) {
  65. App.set('clusterName', 'clusterNameFromServer');
  66. App.set('currentStackVersion', 'HDP-2.0.5');
  67. successCallback();
  68. }
  69. }
  70. });
  71. });
  72. afterEach(function () {
  73. modelSetup.restoreStackVersion(this);
  74. App.ajax.send.restore();
  75. });
  76. it('if clusterName is "mycluster" and reload is false then clusterName stays the same', function () {
  77. App.set('clusterName', 'mycluster');
  78. controller.loadClusterName(false);
  79. expect(App.ajax.send.called).to.be.false;
  80. expect(App.get('clusterName')).to.equal('mycluster');
  81. });
  82. it('reload is true and clusterName is not empty', function () {
  83. controller.loadClusterName(true);
  84. expect(App.ajax.send.calledOnce).to.be.true;
  85. expect(App.get('clusterName')).to.equal('clusterNameFromServer');
  86. expect(App.get('currentStackVersion')).to.equal('HDP-2.0.5');
  87. });
  88. it('reload is false and clusterName is empty', function () {
  89. App.set('clusterName', '');
  90. controller.loadClusterName(false);
  91. expect(App.ajax.send.calledOnce).to.be.true;
  92. expect(App.get('clusterName')).to.equal('clusterNameFromServer');
  93. expect(App.get('currentStackVersion')).to.equal('HDP-2.0.5');
  94. });
  95. });
  96. describe('#reloadSuccessCallback', function () {
  97. var test_data = {
  98. "items": [
  99. {
  100. "Clusters": {
  101. "cluster_name": "tdk",
  102. "version": "HDP-1.3.0"
  103. }
  104. }
  105. ]
  106. };
  107. it('Check cluster', function () {
  108. controller.reloadSuccessCallback(test_data);
  109. expect(App.get('clusterName')).to.equal('tdk');
  110. expect(App.get('currentStackVersion')).to.equal('HDP-1.3.0');
  111. });
  112. });
  113. describe('#getServerClockSuccessCallback()', function () {
  114. var testCases = [
  115. {
  116. title: 'if server clock is 1 then currentServerTime should be 1000',
  117. data: {
  118. RootServiceComponents: {
  119. server_clock: 1
  120. }
  121. },
  122. result: 1000
  123. },
  124. {
  125. title: 'if server clock is 0 then currentServerTime should be 0',
  126. data: {
  127. RootServiceComponents: {
  128. server_clock: 0
  129. }
  130. },
  131. result: 0
  132. },
  133. {
  134. title: 'if server clock is 111111111111 then currentServerTime should be 111111111111000',
  135. data: {
  136. RootServiceComponents: {
  137. server_clock: 111111111111
  138. }
  139. },
  140. result: 111111111111000
  141. },
  142. {
  143. title: 'if server clock is 1111111111113 then currentServerTime should be 1111111111113',
  144. data: {
  145. RootServiceComponents: {
  146. server_clock: 1111111111113
  147. }
  148. },
  149. result: 1111111111113
  150. }
  151. ];
  152. var currentServerTime = App.get('currentServerTime');
  153. var clockDistance = App.get('clockDistance');
  154. testCases.forEach(function (test) {
  155. it(test.title, function () {
  156. controller.getServerClockSuccessCallback(test.data);
  157. expect(App.get('currentServerTime')).to.equal(test.result);
  158. App.set('clockDistance', clockDistance);
  159. App.set('currentServerTime', currentServerTime);
  160. });
  161. });
  162. });
  163. describe('#getUrl', function () {
  164. controller.set('clusterName', 'tdk');
  165. var tests = ['test1', 'test2', 'test3'];
  166. it('testMode = true', function () {
  167. App.testMode = true;
  168. tests.forEach(function (test) {
  169. expect(controller.getUrl(test, test)).to.equal(test);
  170. });
  171. });
  172. it('testMode = false', function () {
  173. App.testMode = false;
  174. tests.forEach(function (test) {
  175. expect(controller.getUrl(test, test)).to.equal(App.apiPrefix + '/clusters/' + controller.get('clusterName') + test);
  176. });
  177. });
  178. });
  179. describe("#createKerberosAdminSession()", function() {
  180. beforeEach(function () {
  181. sinon.stub(App.ajax, 'send', function() {
  182. return {success: Em.K}
  183. });
  184. sinon.stub(credentialUtils, 'createOrUpdateCredentials', function() {
  185. return $.Deferred().resolve().promise();
  186. });
  187. });
  188. afterEach(function () {
  189. App.ajax.send.restore();
  190. credentialUtils.createOrUpdateCredentials.restore();
  191. });
  192. it("KDC Store supports disabled, credentials updated via kdc session call", function() {
  193. sinon.stub(App, 'get')
  194. .withArgs('supports.storeKDCCredentials').returns(false)
  195. .withArgs('clusterName').returns('test');
  196. controller.createKerberosAdminSession({
  197. principal: 'admin',
  198. key: 'pass',
  199. type: 'persistent'
  200. }, {});
  201. App.get.restore();
  202. expect(App.ajax.send.getCall(0).args[0]).to.eql({
  203. name: 'common.cluster.update',
  204. sender: controller,
  205. data: {
  206. clusterName: 'test',
  207. data: [{
  208. session_attributes: {
  209. kerberos_admin: {principal: "admin", password: "pass"}
  210. }
  211. }]
  212. }
  213. });
  214. });
  215. it("KDC Store supports enabled, credentials updated via credentials storage call", function() {
  216. sinon.stub(App, 'get')
  217. .withArgs('supports.storeKDCCredentials').returns(true)
  218. .withArgs('clusterName').returns('test');
  219. controller.createKerberosAdminSession({
  220. principal: 'admin',
  221. key: 'pass',
  222. type: 'persistent'
  223. }, {});
  224. App.get.restore();
  225. expect(App.ajax.send.called).to.be.eql(false);
  226. expect(credentialUtils.createOrUpdateCredentials.getCall(0).args).to.eql([
  227. 'test', 'kdc.admin.credential', {
  228. principal: 'admin',
  229. key: 'pass',
  230. type: 'persistent'
  231. }
  232. ]);
  233. });
  234. });
  235. describe('#checkDetailedRepoVersion()', function () {
  236. var cases = [
  237. {
  238. currentStackName: 'HDP',
  239. currentStackVersionNumber: '2.1',
  240. isStormMetricsSupported: false,
  241. title: 'HDP < 2.2'
  242. },
  243. {
  244. currentStackName: 'HDP',
  245. currentStackVersionNumber: '2.3',
  246. isStormMetricsSupported: true,
  247. title: 'HDP > 2.2'
  248. },
  249. {
  250. currentStackName: 'BIGTOP',
  251. currentStackVersionNumber: '0.8',
  252. isStormMetricsSupported: true,
  253. title: 'not HDP'
  254. }
  255. ];
  256. beforeEach(function () {
  257. sinon.stub(App.ajax, 'send').returns({
  258. promise: Em.K
  259. });
  260. });
  261. afterEach(function () {
  262. App.ajax.send.restore();
  263. App.get.restore();
  264. });
  265. it('should check detailed repo version for HDP 2.2', function () {
  266. sinon.stub(App, 'get').withArgs('currentStackName').returns('HDP').withArgs('currentStackVersionNumber').returns('2.2');
  267. controller.checkDetailedRepoVersion();
  268. expect(App.ajax.send.calledOnce).to.be.true;
  269. });
  270. cases.forEach(function (item) {
  271. it(item.title, function () {
  272. sinon.stub(App, 'get', function (key) {
  273. return item[key] || Em.get(App, key);
  274. });
  275. controller.checkDetailedRepoVersion();
  276. expect(App.ajax.send.called).to.be.false;
  277. expect(App.get('isStormMetricsSupported')).to.equal(item.isStormMetricsSupported);
  278. });
  279. });
  280. });
  281. describe('#checkDetailedRepoVersionSuccessCallback()', function () {
  282. var cases = [
  283. {
  284. items: [
  285. {
  286. repository_versions: [
  287. {
  288. RepositoryVersions: {
  289. repository_version: '2.1'
  290. }
  291. }
  292. ]
  293. }
  294. ],
  295. isStormMetricsSupported: false,
  296. title: 'HDP < 2.2.2'
  297. },
  298. {
  299. items: [
  300. {
  301. repository_versions: [
  302. {
  303. RepositoryVersions: {
  304. repository_version: '2.2.2'
  305. }
  306. }
  307. ]
  308. }
  309. ],
  310. isStormMetricsSupported: true,
  311. title: 'HDP 2.2.2'
  312. },
  313. {
  314. items: [
  315. {
  316. repository_versions: [
  317. {
  318. RepositoryVersions: {
  319. repository_version: '2.2.3'
  320. }
  321. }
  322. ]
  323. }
  324. ],
  325. isStormMetricsSupported: true,
  326. title: 'HDP > 2.2.2'
  327. },
  328. {
  329. items: null,
  330. isStormMetricsSupported: true,
  331. title: 'empty response'
  332. },
  333. {
  334. items: [],
  335. isStormMetricsSupported: true,
  336. title: 'no items'
  337. },
  338. {
  339. items: [{}],
  340. isStormMetricsSupported: true,
  341. title: 'empty item'
  342. },
  343. {
  344. items: [{
  345. repository_versions: []
  346. }],
  347. isStormMetricsSupported: true,
  348. title: 'no versions'
  349. },
  350. {
  351. items: [{
  352. repository_versions: [{}]
  353. }],
  354. isStormMetricsSupported: true,
  355. title: 'no version info'
  356. },
  357. {
  358. items: [{
  359. repository_versions: [
  360. {
  361. RepositoryVersions: {}
  362. }
  363. ]
  364. }],
  365. isStormMetricsSupported: true,
  366. title: 'empty version info'
  367. }
  368. ];
  369. cases.forEach(function (item) {
  370. it(item.title, function () {
  371. controller.checkDetailedRepoVersionSuccessCallback({
  372. items: item.items
  373. });
  374. expect(App.get('isStormMetricsSupported')).to.equal(item.isStormMetricsSupported);
  375. });
  376. });
  377. });
  378. describe('#checkDetailedRepoVersionErrorCallback()', function () {
  379. it('should set isStormMetricsSupported to default value', function () {
  380. controller.checkDetailedRepoVersionErrorCallback();
  381. expect(App.get('isStormMetricsSupported')).to.be.true;
  382. });
  383. });
  384. describe('#getAllUpgrades()', function () {
  385. beforeEach(function () {
  386. sinon.stub(App.ajax, 'send', Em.K);
  387. });
  388. afterEach(function () {
  389. App.ajax.send.restore();
  390. });
  391. it('should send request to get upgrades data', function () {
  392. controller.getAllUpgrades();
  393. expect(App.ajax.send.calledOnce).to.be.true;
  394. });
  395. });
  396. describe("#restoreUpgradeState()", function() {
  397. var data = {upgradeData: {}};
  398. var mock = {done: function(callback) {
  399. callback(data.upgradeData);
  400. }};
  401. var upgradeController = Em.Object.create({
  402. restoreLastUpgrade: Em.K,
  403. initDBProperties: Em.K,
  404. loadUpgradeData: Em.K,
  405. loadStackVersionsToModel: function(){return {done: Em.K};}
  406. });
  407. beforeEach(function () {
  408. sinon.stub(controller, 'getAllUpgrades').returns(mock);
  409. sinon.spy(mock, 'done');
  410. sinon.stub(App.router, 'get').returns(upgradeController);
  411. sinon.stub(App.db, 'get').returns('PENDING');
  412. sinon.spy(upgradeController, 'restoreLastUpgrade');
  413. sinon.spy(upgradeController, 'initDBProperties');
  414. sinon.spy(upgradeController, 'loadUpgradeData');
  415. sinon.spy(upgradeController, 'loadStackVersionsToModel');
  416. });
  417. afterEach(function () {
  418. mock.done.restore();
  419. controller.getAllUpgrades.restore();
  420. App.router.get.restore();
  421. App.db.get.restore();
  422. upgradeController.restoreLastUpgrade.restore();
  423. upgradeController.initDBProperties.restore();
  424. upgradeController.loadUpgradeData.restore();
  425. upgradeController.loadStackVersionsToModel.restore();
  426. });
  427. it("has upgrade request", function() {
  428. data.upgradeData = {items: [
  429. {
  430. Upgrade: {
  431. request_id: 1
  432. }
  433. }
  434. ]};
  435. controller.restoreUpgradeState();
  436. expect(controller.getAllUpgrades.calledOnce).to.be.true;
  437. expect(App.get('upgradeState')).to.equal('PENDING');
  438. expect(upgradeController.restoreLastUpgrade.calledWith(data.upgradeData.items[0])).to.be.true;
  439. expect(upgradeController.loadStackVersionsToModel.calledWith(true)).to.be.true;
  440. expect(upgradeController.initDBProperties.called).to.be.false;
  441. expect(upgradeController.loadUpgradeData.called).to.be.false;
  442. });
  443. it("does not have upgrade request", function() {
  444. data.upgradeData = {items: []};
  445. controller.restoreUpgradeState();
  446. expect(controller.getAllUpgrades.calledOnce).to.be.true;
  447. expect(App.get('upgradeState')).to.equal('PENDING');
  448. expect(upgradeController.restoreLastUpgrade.called).to.be.false;
  449. expect(upgradeController.loadStackVersionsToModel.calledWith(true)).to.be.true;
  450. expect(upgradeController.initDBProperties.calledOnce).to.be.true;
  451. expect(upgradeController.loadUpgradeData.calledWith(true)).to.be.true;
  452. });
  453. });
  454. });