stack_and_upgrade_controller_test.js 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512
  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'});
  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.load.calledOnce).to.be.true;
  247. expect(controller.get('upgradeVersion')).to.equal('HDP-2.2.1');
  248. expect(controller.get('upgradeData')).to.be.null;
  249. expect(App.clusterStatus.setClusterStatus.calledOnce).to.be.true;
  250. expect(controller.openUpgradeDialog.calledOnce).to.be.true;
  251. });
  252. });
  253. describe("#updateUpgradeData()", function() {
  254. beforeEach(function () {
  255. sinon.stub(controller, 'initUpgradeData', Em.K);
  256. });
  257. afterEach(function () {
  258. controller.initUpgradeData.restore();
  259. });
  260. it("data loaded first time", function() {
  261. controller.set('upgradeData', null);
  262. controller.updateUpgradeData({});
  263. expect(controller.initUpgradeData.calledWith({})).to.be.true;
  264. });
  265. it("update loaded data", function() {
  266. var oldData = Em.Object.create({
  267. upgradeGroups: [
  268. Em.Object.create({
  269. group_id: 1,
  270. upgradeItems: [
  271. Em.Object.create({
  272. stage_id: 1,
  273. tasks: [
  274. Em.Object.create({
  275. id: 1
  276. })
  277. ]
  278. })
  279. ]
  280. })
  281. ]
  282. });
  283. var newData = {
  284. Upgrade: {
  285. request_id: 1
  286. },
  287. upgrade_groups: [
  288. {
  289. UpgradeGroup: {
  290. group_id: 1,
  291. status: 'COMPLETED',
  292. progress_percent: 100
  293. },
  294. upgrade_items: [
  295. {
  296. UpgradeItem: {
  297. stage_id: 1,
  298. status: 'COMPLETED',
  299. progress_percent: 100
  300. },
  301. tasks: [
  302. {
  303. Tasks: {
  304. id: 1,
  305. status: 'COMPLETED'
  306. }
  307. }
  308. ]
  309. }
  310. ]
  311. }
  312. ]
  313. };
  314. controller.set('upgradeData', oldData);
  315. controller.updateUpgradeData(newData);
  316. expect(controller.get('upgradeData.upgradeGroups')[0].get('status')).to.equal('COMPLETED');
  317. expect(controller.get('upgradeData.upgradeGroups')[0].get('progress_percent')).to.equal(100);
  318. expect(controller.get('upgradeData.upgradeGroups')[0].get('upgradeItems')[0].get('status')).to.equal('COMPLETED');
  319. expect(controller.get('upgradeData.upgradeGroups')[0].get('upgradeItems')[0].get('progress_percent')).to.equal(100);
  320. expect(controller.get('upgradeData.upgradeGroups')[0].get('upgradeItems')[0].get('tasks')[0].get('status')).to.equal('COMPLETED');
  321. });
  322. });
  323. describe("#initUpgradeData()", function() {
  324. it("", function() {
  325. var newData = {
  326. Upgrade: {
  327. request_id: 1
  328. },
  329. upgrade_groups: [
  330. {
  331. UpgradeGroup: {
  332. group_id: 1
  333. },
  334. upgrade_items: [
  335. {
  336. UpgradeItem: {
  337. stage_id: 1
  338. },
  339. tasks: [
  340. {
  341. Tasks: {
  342. id: 1
  343. }
  344. }
  345. ]
  346. }
  347. ]
  348. }
  349. ]
  350. };
  351. controller.initUpgradeData(newData);
  352. expect(controller.get('upgradeData.Upgrade.request_id')).to.equal(1);
  353. expect(controller.get('upgradeData.upgradeGroups')[0].get('group_id')).to.equal(1);
  354. expect(controller.get('upgradeData.upgradeGroups')[0].get('upgradeItems')[0].get('stage_id')).to.equal(1);
  355. expect(controller.get('upgradeData.upgradeGroups')[0].get('upgradeItems')[0].get('tasks')[0].get('id')).to.equal(1);
  356. });
  357. });
  358. describe.skip("#finish()", function() {
  359. before(function () {
  360. sinon.stub(App.clusterStatus, 'setClusterStatus', Em.K);
  361. sinon.stub(controller, 'setDBProperty', Em.K);
  362. });
  363. after(function () {
  364. App.clusterStatus.setClusterStatus.restore();
  365. controller.setDBProperty.restore();
  366. });
  367. it("upgradeState is COMPLETED", function() {
  368. App.set('upgradeState', 'COMPLETED');
  369. controller.finish();
  370. expect(controller.setDBProperty.calledWith('upgradeId', undefined)).to.be.true;
  371. expect(controller.setDBProperty.calledWith('upgradeVersion', undefined)).to.be.true;
  372. expect(controller.setDBProperty.calledWith('upgradeState', 'INIT')).to.be.true;
  373. expect(controller.setDBProperty.calledWith('currentVersion', undefined)).to.be.true;
  374. expect(App.get('upgradeState')).to.equal('INIT');
  375. expect(App.clusterStatus.setClusterStatus.calledOnce).to.be.false;
  376. });
  377. it("upgradeState is not COMPLETED", function() {
  378. App.set('upgradeState', 'UPGRADING');
  379. controller.finish();
  380. expect(App.clusterStatus.setClusterStatus.called).to.be.false;
  381. });
  382. });
  383. describe("#confirmDowngrade()", function() {
  384. before(function () {
  385. sinon.stub(App, 'showConfirmationPopup', Em.K);
  386. });
  387. after(function () {
  388. App.showConfirmationPopup.restore();
  389. });
  390. it("show confirmation popup", function() {
  391. controller.set('currentVersion', Em.Object.create({
  392. repository_version: '2.2',
  393. repository_name: 'HDP-2.2'
  394. }));
  395. controller.confirmDowngrade();
  396. expect(App.showConfirmationPopup.calledOnce).to.be.true;
  397. });
  398. });
  399. describe("#downgrade()", function() {
  400. before(function () {
  401. sinon.stub(App.ajax, 'send', Em.K);
  402. sinon.stub(controller, 'setUpgradeItemStatus');
  403. });
  404. after(function () {
  405. App.ajax.send.restore();
  406. controller.setUpgradeItemStatus.restore();
  407. });
  408. it("make ajax call", function() {
  409. controller.downgrade(Em.Object.create({
  410. repository_version: '2.2',
  411. repository_name: 'HDP-2.2'
  412. }), {context: 'context'});
  413. expect(controller.setUpgradeItemStatus.calledWith('context', 'FAILED')).to.be.true;
  414. expect(App.ajax.send.getCall(0).args[0]).to.eql({
  415. name: 'admin.downgrade.start',
  416. sender: controller,
  417. data: {
  418. value: '2.2',
  419. label: 'HDP-2.2'
  420. },
  421. success: 'upgradeSuccessCallback'
  422. });
  423. });
  424. });
  425. describe("#installRepoVersionConfirmation()", function () {
  426. before(function () {
  427. sinon.stub(controller, 'installRepoVersion', Em.K);
  428. });
  429. after(function () {
  430. controller.installRepoVersion.restore();
  431. });
  432. it("show popup", function () {
  433. var repo = Em.Object.create({'displayName': 'HDP-2.2'});
  434. var popup = controller.installRepoVersionConfirmation(repo);
  435. popup.onPrimary();
  436. expect(controller.installRepoVersion.calledWith(repo)).to.be.true;
  437. });
  438. });
  439. describe("#installRepoVersion()", function () {
  440. before(function () {
  441. sinon.stub(App.ajax, 'send', Em.K);
  442. });
  443. after(function () {
  444. App.ajax.send.restore();
  445. });
  446. it("make ajax call", function () {
  447. var repo = Em.Object.create({
  448. stackVersionType: 'HDP',
  449. stackVersionNumber: '2.2',
  450. repositoryVersion: '2.2.1',
  451. repoId: 1
  452. });
  453. controller.installRepoVersion(repo);
  454. expect(App.ajax.send.calledOnce).to.be.true;
  455. });
  456. });
  457. describe("#setUpgradeItemStatus()", function () {
  458. before(function () {
  459. sinon.stub(App.ajax, 'send', function () {
  460. return {
  461. done: function (callback) {
  462. callback();
  463. }
  464. }
  465. });
  466. });
  467. after(function () {
  468. App.ajax.send.restore();
  469. });
  470. it("", function () {
  471. var item = Em.Object.create({
  472. request_id: 1,
  473. stage_id: 1,
  474. group_id: 1
  475. });
  476. controller.setUpgradeItemStatus(item, 'PENDING');
  477. expect(App.ajax.send.getCall(0).args[0]).to.eql({
  478. name: 'admin.upgrade.upgradeItem.setState',
  479. sender: controller,
  480. data: {
  481. upgradeId: 1,
  482. itemId: 1,
  483. groupId: 1,
  484. status: 'PENDING'
  485. }
  486. });
  487. expect(item.get('status')).to.equal('PENDING');
  488. });
  489. });
  490. });