cluster_controller_test.js 14 KB

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