stack_and_upgrade_controller_test.js 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582
  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/main/admin/stack_and_upgrade_controller');
  20. describe('App.MainAdminStackAndUpgradeController', function() {
  21. var controller = App.MainAdminStackAndUpgradeController.create({
  22. getDBProperty: Em.K,
  23. setDBProperty: Em.K
  24. });
  25. describe("#services", function () {
  26. before(function () {
  27. sinon.stub(App.StackService, 'find').returns([
  28. Em.Object.create({serviceName: 'S1', isInstalled: false}),
  29. Em.Object.create({serviceName: 'S2', isInstalled: false})
  30. ]);
  31. sinon.stub(App.Service, 'find').returns([
  32. Em.Object.create({serviceName: 'S1'})
  33. ]);
  34. });
  35. after(function () {
  36. App.StackService.find.restore();
  37. App.Service.find.restore();
  38. });
  39. it("", function () {
  40. controller.propertyDidChange('services');
  41. expect(controller.get('services')).to.eql([
  42. Em.Object.create({serviceName: 'S1', isInstalled: true}),
  43. Em.Object.create({serviceName: 'S2', isInstalled: false})
  44. ])
  45. });
  46. });
  47. describe("#goToAddService()" , function() {
  48. beforeEach(function() {
  49. sinon.stub(App.get('router'), 'transitionTo', Em.K);
  50. });
  51. afterEach(function() {
  52. App.get('router').transitionTo.restore();
  53. });
  54. it("routes to Add Service Wizard", function() {
  55. controller.goToAddService({context: "serviceName"});
  56. expect(App.get('router').transitionTo.calledOnce).to.be.true;
  57. expect(controller.get('serviceToInstall')).to.be.equal("serviceName");
  58. });
  59. });
  60. describe("#loadVersionsInfo()", function() {
  61. before(function () {
  62. sinon.stub(App.ajax, 'send', Em.K);
  63. });
  64. after(function () {
  65. App.ajax.send.restore();
  66. });
  67. it("make ajax call", function() {
  68. controller.loadVersionsInfo();
  69. expect(App.ajax.send.getCall(0).args[0]).to.eql({
  70. name: 'admin.stack_versions.all',
  71. sender: controller,
  72. data: {},
  73. success: 'loadVersionsInfoSuccessCallback'
  74. })
  75. });
  76. });
  77. describe("#loadVersionsInfoSuccessCallback()", function() {
  78. beforeEach(function(){
  79. sinon.stub(controller, 'parseVersionsData', function (data) {
  80. return data;
  81. });
  82. });
  83. afterEach(function(){
  84. controller.parseVersionsData.restore();
  85. });
  86. it("target version installed and higher than current", function() {
  87. var data = [
  88. {
  89. "state": "CURRENT",
  90. "repository_version": "2.2.0.1-885"
  91. },
  92. {
  93. "state": "INSTALLED",
  94. "repository_version": "2.2.1.1-885"
  95. }
  96. ];
  97. controller.loadVersionsInfoSuccessCallback(data);
  98. expect(controller.get('currentVersion')).to.eql({
  99. "state": "CURRENT",
  100. "repository_version": "2.2.0.1-885"
  101. });
  102. expect(controller.get('targetVersions')).to.eql([{
  103. "state": "INSTALLED",
  104. "repository_version": "2.2.1.1-885"
  105. }]);
  106. });
  107. it("target version installed and lower than current", function() {
  108. var data = [
  109. {
  110. "state": "CURRENT",
  111. "repository_version": "2.2.0.1-885"
  112. },
  113. {
  114. "state": "INSTALLED",
  115. "repository_version" : "2.2.0.1-885"
  116. }
  117. ];
  118. controller.loadVersionsInfoSuccessCallback(data);
  119. expect(controller.get('currentVersion')).to.eql({
  120. "state": "CURRENT",
  121. "repository_version": "2.2.0.1-885"
  122. });
  123. expect(controller.get('targetVersions')).to.be.empty;
  124. });
  125. it("target version not installed and lower than current", function() {
  126. var data = [
  127. {
  128. "state": "CURRENT",
  129. "repository_version": "2.2.0.1-885"
  130. },
  131. {
  132. "state": "INIT",
  133. "repository_version" : "2.2.0.1-885"
  134. }
  135. ];
  136. controller.loadVersionsInfoSuccessCallback(data);
  137. expect(controller.get('currentVersion')).to.eql({
  138. "state": "CURRENT",
  139. "repository_version": "2.2.0.1-885"
  140. });
  141. expect(controller.get('targetVersions')).to.be.empty;
  142. });
  143. });
  144. describe("#loadUpgradeData()", function() {
  145. beforeEach(function () {
  146. sinon.stub(App.ajax, 'send').returns({
  147. then: Em.K
  148. });
  149. });
  150. afterEach(function () {
  151. App.ajax.send.restore();
  152. });
  153. it("get entire data", function() {
  154. controller.set('upgradeId', 1);
  155. controller.loadUpgradeData();
  156. expect(App.ajax.send.getCall(0).args[0]).to.eql({
  157. name: 'admin.upgrade.data',
  158. sender: controller,
  159. data: {
  160. id: 1
  161. },
  162. success: 'loadUpgradeDataSuccessCallback'
  163. })
  164. });
  165. it("get only state", function() {
  166. controller.set('upgradeId', 1);
  167. controller.loadUpgradeData(true);
  168. expect(App.ajax.send.getCall(0).args[0]).to.eql({
  169. name: 'admin.upgrade.state',
  170. sender: controller,
  171. data: {
  172. id: 1
  173. },
  174. success: 'loadUpgradeDataSuccessCallback'
  175. })
  176. });
  177. it("upgrade id is null", function() {
  178. controller.set('upgradeId', null);
  179. controller.loadUpgradeData();
  180. expect(App.ajax.send.called).to.be.false;
  181. });
  182. });
  183. describe("#loadUpgradeDataSuccessCallback()", function() {
  184. beforeEach(function () {
  185. sinon.stub(controller, 'updateUpgradeData', Em.K);
  186. });
  187. afterEach(function () {
  188. controller.updateUpgradeData.restore();
  189. });
  190. it("", function() {
  191. var data = {
  192. "Upgrade": {
  193. "request_status": "COMPLETED"
  194. },
  195. "upgrade_groups": [
  196. {
  197. "UpgradeGroup": {
  198. "id": 1
  199. },
  200. "upgrade_items": []
  201. }
  202. ]};
  203. controller.loadUpgradeDataSuccessCallback(data);
  204. expect(App.get('upgradeState')).to.equal('COMPLETED');
  205. expect(controller.updateUpgradeData.called).to.be.true;
  206. });
  207. });
  208. describe("#openUpgradeDialog()", function () {
  209. before(function () {
  210. sinon.stub(App.router, 'transitionTo', Em.K);
  211. });
  212. after(function () {
  213. App.router.transitionTo.restore();
  214. });
  215. it("should open dialog", function () {
  216. controller.openUpgradeDialog();
  217. expect(App.router.transitionTo.calledWith('admin.stackUpgrade')).to.be.true;
  218. });
  219. });
  220. describe("#runPreUpgradeCheck()", function() {
  221. before(function () {
  222. sinon.stub(App.ajax, 'send', Em.K);
  223. });
  224. after(function () {
  225. App.ajax.send.restore();
  226. });
  227. it("make ajax call", function() {
  228. controller.runPreUpgradeCheck({
  229. value: '2.2',
  230. label: 'HDP-2.2'
  231. });
  232. expect(App.ajax.send.getCall(0).args[0]).to.eql({
  233. name: "admin.rolling_upgrade.pre_upgrade_check",
  234. sender: controller,
  235. data: {
  236. value: '2.2',
  237. label: 'HDP-2.2'
  238. },
  239. success: "runPreUpgradeCheckSuccess"
  240. });
  241. });
  242. });
  243. describe("#runPreUpgradeCheckSuccess()", function () {
  244. beforeEach(function () {
  245. sinon.stub(App, 'showClusterCheckPopup', Em.K);
  246. sinon.stub(controller, 'upgrade', Em.K);
  247. });
  248. afterEach(function () {
  249. App.showClusterCheckPopup.restore();
  250. controller.upgrade.restore();
  251. });
  252. it("shows popup", function () {
  253. var check = { items: [{
  254. UpgradeChecks: {
  255. "check": "Work-preserving RM/NM restart is enabled in YARN configs",
  256. "status": "FAIL",
  257. "reason": "FAIL",
  258. "failed_on": [],
  259. "check_type": "SERVICE"
  260. }
  261. }]};
  262. controller.runPreUpgradeCheckSuccess(check,null,{label: "name"});
  263. expect(controller.upgrade.called).to.be.false;
  264. expect(App.showClusterCheckPopup.called).to.be.true;
  265. });
  266. it("runs upgrade popup", function () {
  267. var check = { items: [{
  268. UpgradeChecks: {
  269. "check": "Work-preserving RM/NM restart is enabled in YARN configs",
  270. "status": "PASS",
  271. "reason": "OK",
  272. "failed_on": [],
  273. "check_type": "SERVICE"
  274. }
  275. }]};
  276. controller.runPreUpgradeCheckSuccess(check,null,{label: "name"});
  277. expect(controller.upgrade.called).to.be.true;
  278. expect(App.showClusterCheckPopup.called).to.be.false;
  279. });
  280. });
  281. describe("#initDBProperties()", function() {
  282. before(function () {
  283. sinon.stub(controller, 'getDBProperty', function (prop) {
  284. return prop;
  285. });
  286. });
  287. after(function () {
  288. controller.getDBProperty.restore();
  289. });
  290. it("set properties", function () {
  291. controller.set('wizardStorageProperties', ['prop1']);
  292. controller.initDBProperties();
  293. expect(controller.get('prop1')).to.equal('prop1');
  294. });
  295. });
  296. describe("#init()", function() {
  297. before(function () {
  298. sinon.stub(controller, 'initDBProperties', Em.K);
  299. });
  300. after(function () {
  301. controller.initDBProperties.restore();
  302. });
  303. it("call initDBProperties", function () {
  304. controller.init();
  305. expect(controller.initDBProperties.calledOnce).to.be.true;
  306. });
  307. });
  308. describe("#parseVersionsData()", function() {
  309. it("", function() {
  310. var data = {
  311. items: [
  312. {
  313. ClusterStackVersions: {},
  314. repository_versions: [
  315. {
  316. RepositoryVersions: {
  317. repository_version: '2.2',
  318. display_name: 'v1',
  319. id: '1'
  320. }
  321. }
  322. ]
  323. }
  324. ]
  325. };
  326. expect(controller.parseVersionsData(data)).to.eql([
  327. {
  328. "repository_name": "v1",
  329. "repository_id": "1",
  330. "repository_version": "2.2"
  331. }
  332. ]);
  333. });
  334. });
  335. describe("#upgrade()", function() {
  336. before(function () {
  337. sinon.stub(App.ajax, 'send', Em.K);
  338. sinon.stub(controller, 'setDBProperty', Em.K);
  339. });
  340. after(function () {
  341. App.ajax.send.restore();
  342. controller.setDBProperty.restore();
  343. });
  344. it("make ajax call", function() {
  345. controller.set('currentVersion', {
  346. repository_version: '2.2'
  347. });
  348. controller.upgrade({
  349. value: '2.2',
  350. label: 'HDP-2.2'
  351. });
  352. expect(App.ajax.send.getCall(0).args[0]).to.eql({
  353. name: 'admin.upgrade.start',
  354. sender: controller,
  355. data: {
  356. value: '2.2',
  357. label: 'HDP-2.2'
  358. },
  359. success: 'upgradeSuccessCallback'
  360. });
  361. expect(controller.setDBProperty.calledWith('currentVersion', {
  362. repository_version: '2.2'
  363. })).to.be.true;
  364. });
  365. });
  366. describe("#upgradeSuccessCallback()", function() {
  367. before(function () {
  368. sinon.stub(App.clusterStatus, 'setClusterStatus', Em.K);
  369. sinon.stub(controller, 'openUpgradeDialog', Em.K);
  370. sinon.stub(controller, 'setDBProperty', Em.K);
  371. });
  372. after(function () {
  373. App.clusterStatus.setClusterStatus.restore();
  374. controller.openUpgradeDialog.restore();
  375. controller.setDBProperty.restore();
  376. });
  377. it("open upgrade dialog", function() {
  378. var data = {
  379. resources: [
  380. {
  381. Upgrade: {
  382. request_id: 1
  383. }
  384. }
  385. ]
  386. };
  387. controller.upgradeSuccessCallback(data, {}, {label: 'HDP-2.2.1'});
  388. expect(controller.setDBProperty.calledWith('upgradeId', 1)).to.be.true;
  389. expect(controller.setDBProperty.calledWith('upgradeVersion', 'HDP-2.2.1')).to.be.true;
  390. expect(controller.get('upgradeVersion')).to.equal('HDP-2.2.1');
  391. expect(App.clusterStatus.setClusterStatus.calledOnce).to.be.true;
  392. expect(controller.openUpgradeDialog.calledOnce).to.be.true;
  393. });
  394. });
  395. describe("#updateUpgradeData()", function() {
  396. beforeEach(function () {
  397. sinon.stub(controller, 'initUpgradeData', Em.K);
  398. });
  399. afterEach(function () {
  400. controller.initUpgradeData.restore();
  401. });
  402. it("data loaded first time", function() {
  403. controller.set('upgradeData', null);
  404. controller.updateUpgradeData({});
  405. expect(controller.initUpgradeData.calledWith({})).to.be.true;
  406. });
  407. it("update loaded data", function() {
  408. var oldData = Em.Object.create({
  409. upgradeGroups: [
  410. Em.Object.create({
  411. group_id: 1,
  412. upgradeItems: [
  413. Em.Object.create({
  414. stage_id: 1,
  415. tasks: [
  416. Em.Object.create({
  417. id: 1
  418. })
  419. ]
  420. })
  421. ]
  422. })
  423. ]
  424. });
  425. var newData = {
  426. Upgrade: {
  427. request_id: 1
  428. },
  429. upgrade_groups: [
  430. {
  431. UpgradeGroup: {
  432. group_id: 1,
  433. status: 'COMPLETED',
  434. progress_percent: 100
  435. },
  436. upgrade_items: [
  437. {
  438. UpgradeItem: {
  439. stage_id: 1,
  440. status: 'COMPLETED',
  441. progress_percent: 100
  442. },
  443. tasks: [
  444. {
  445. Tasks: {
  446. id: 1,
  447. status: 'COMPLETED'
  448. }
  449. }
  450. ]
  451. }
  452. ]
  453. }
  454. ]
  455. };
  456. controller.set('upgradeData', oldData);
  457. controller.updateUpgradeData(newData);
  458. expect(controller.get('upgradeData.upgradeGroups')[0].get('status')).to.equal('COMPLETED');
  459. expect(controller.get('upgradeData.upgradeGroups')[0].get('progress_percent')).to.equal(100);
  460. expect(controller.get('upgradeData.upgradeGroups')[0].get('upgradeItems')[0].get('status')).to.equal('COMPLETED');
  461. expect(controller.get('upgradeData.upgradeGroups')[0].get('upgradeItems')[0].get('progress_percent')).to.equal(100);
  462. expect(controller.get('upgradeData.upgradeGroups')[0].get('upgradeItems')[0].get('tasks')[0].get('status')).to.equal('COMPLETED');
  463. });
  464. });
  465. describe("#initUpgradeData()", function() {
  466. it("", function() {
  467. var newData = {
  468. Upgrade: {
  469. request_id: 1
  470. },
  471. upgrade_groups: [
  472. {
  473. UpgradeGroup: {
  474. group_id: 1
  475. },
  476. upgrade_items: [
  477. {
  478. UpgradeItem: {
  479. stage_id: 1
  480. },
  481. tasks: [
  482. {
  483. Tasks: {
  484. id: 1
  485. }
  486. }
  487. ]
  488. }
  489. ]
  490. }
  491. ]
  492. };
  493. controller.initUpgradeData(newData);
  494. expect(controller.get('upgradeData.Upgrade.request_id')).to.equal(1);
  495. expect(controller.get('upgradeData.upgradeGroups')[0].get('group_id')).to.equal(1);
  496. expect(controller.get('upgradeData.upgradeGroups')[0].get('upgradeItems')[0].get('stage_id')).to.equal(1);
  497. expect(controller.get('upgradeData.upgradeGroups')[0].get('upgradeItems')[0].get('tasks')[0].get('id')).to.equal(1);
  498. });
  499. });
  500. describe("#finish()", function() {
  501. before(function () {
  502. sinon.stub(App.clusterStatus, 'setClusterStatus', Em.K);
  503. sinon.stub(controller, 'setDBProperty', Em.K);
  504. });
  505. after(function () {
  506. App.clusterStatus.setClusterStatus.restore();
  507. controller.setDBProperty.restore();
  508. });
  509. it("reset upgrade info", function() {
  510. controller.finish();
  511. expect(controller.get('upgradeId')).to.be.null;
  512. expect(controller.setDBProperty.calledWith('upgradeId', undefined)).to.be.true;
  513. expect(App.get('upgradeState')).to.equal('INIT');
  514. expect(controller.get('upgradeVersion')).to.be.null;
  515. expect(controller.setDBProperty.calledWith('upgradeVersion', undefined)).to.be.true;
  516. expect(App.clusterStatus.setClusterStatus.calledOnce).to.be.true;
  517. });
  518. });
  519. describe("#confirmDowngrade()", function() {
  520. before(function () {
  521. sinon.stub(App, 'showConfirmationPopup', Em.K);
  522. });
  523. after(function () {
  524. App.showConfirmationPopup.restore();
  525. });
  526. it("show confirmation popup", function() {
  527. controller.set('currentVersion', Em.Object.create({
  528. repository_version: '2.2',
  529. repository_name: 'HDP-2.2'
  530. }));
  531. controller.confirmDowngrade();
  532. expect(App.showConfirmationPopup.calledOnce).to.be.true;
  533. });
  534. });
  535. describe("#downgrade()", function() {
  536. before(function () {
  537. sinon.stub(App.ajax, 'send', Em.K);
  538. });
  539. after(function () {
  540. App.ajax.send.restore();
  541. });
  542. it("make ajax call", function() {
  543. controller.downgrade(Em.Object.create({
  544. repository_version: '2.2',
  545. repository_name: 'HDP-2.2'
  546. }));
  547. expect(App.ajax.send.getCall(0).args[0]).to.eql({
  548. name: 'admin.downgrade.start',
  549. sender: controller,
  550. data: {
  551. value: '2.2',
  552. label: 'HDP-2.2'
  553. },
  554. success: 'upgradeSuccessCallback'
  555. });
  556. });
  557. });
  558. });