stack_and_upgrade_controller_test.js 19 KB

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