stack_and_upgrade_controller_test.js 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534
  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. version: '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.ModalPopup, 'show', Em.K);
  246. sinon.stub(controller, 'upgrade', Em.K);
  247. });
  248. afterEach(function () {
  249. App.ModalPopup.show.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.calledOnce).to.be.false;
  264. expect(App.ModalPopup.show.calledOnce).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.calledOnce).to.be.true;
  278. expect(App.ModalPopup.show.calledOnce).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.upgrade({
  346. value: '2.2',
  347. label: 'HDP-2.2'
  348. });
  349. expect(App.ajax.send.getCall(0).args[0]).to.eql({
  350. name: 'admin.upgrade.start',
  351. sender: controller,
  352. data: {
  353. version: '2.2'
  354. },
  355. success: 'upgradeSuccessCallback'
  356. });
  357. expect(controller.get('upgradeVersion')).to.equal('HDP-2.2');
  358. expect(controller.setDBProperty.calledWith('upgradeVersion', 'HDP-2.2')).to.be.true;
  359. });
  360. });
  361. describe("#upgradeSuccessCallback()", function() {
  362. before(function () {
  363. sinon.stub(App.clusterStatus, 'setClusterStatus', Em.K);
  364. sinon.stub(controller, 'openUpgradeDialog', Em.K);
  365. sinon.stub(controller, 'setDBProperty', Em.K);
  366. });
  367. after(function () {
  368. App.clusterStatus.setClusterStatus.restore();
  369. controller.openUpgradeDialog.restore();
  370. controller.setDBProperty.restore();
  371. });
  372. it("open upgrade dialog", function() {
  373. var data = {
  374. resources: [
  375. {
  376. Upgrade: {
  377. request_id: 1
  378. }
  379. }
  380. ]
  381. };
  382. controller.upgradeSuccessCallback(data);
  383. expect(controller.setDBProperty.calledWith('upgradeId', 1)).to.be.true;
  384. expect(App.clusterStatus.setClusterStatus.calledOnce).to.be.true;
  385. expect(controller.openUpgradeDialog.calledOnce).to.be.true;
  386. });
  387. });
  388. describe("#updateUpgradeData()", function() {
  389. beforeEach(function () {
  390. sinon.stub(controller, 'initUpgradeData', Em.K);
  391. });
  392. afterEach(function () {
  393. controller.initUpgradeData.restore();
  394. });
  395. it("data loaded first time", function() {
  396. controller.set('upgradeData', null);
  397. controller.updateUpgradeData({});
  398. expect(controller.initUpgradeData.calledWith({})).to.be.true;
  399. });
  400. it("update loaded data", function() {
  401. var oldData = Em.Object.create({
  402. upgradeGroups: [
  403. Em.Object.create({
  404. group_id: 1,
  405. upgradeItems: [
  406. Em.Object.create({
  407. stage_id: 1,
  408. tasks: [
  409. Em.Object.create({
  410. id: 1
  411. })
  412. ]
  413. })
  414. ]
  415. })
  416. ]
  417. });
  418. var newData = {
  419. Upgrade: {
  420. request_id: 1
  421. },
  422. upgrade_groups: [
  423. {
  424. UpgradeGroup: {
  425. group_id: 1,
  426. status: 'COMPLETED',
  427. progress_percent: 100
  428. },
  429. upgrade_items: [
  430. {
  431. UpgradeItem: {
  432. stage_id: 1,
  433. status: 'COMPLETED',
  434. progress_percent: 100
  435. },
  436. tasks: [
  437. {
  438. Tasks: {
  439. id: 1,
  440. status: 'COMPLETED'
  441. }
  442. }
  443. ]
  444. }
  445. ]
  446. }
  447. ]
  448. };
  449. controller.set('upgradeData', oldData);
  450. controller.updateUpgradeData(newData);
  451. expect(controller.get('upgradeData.upgradeGroups')[0].get('status')).to.equal('COMPLETED');
  452. expect(controller.get('upgradeData.upgradeGroups')[0].get('progress_percent')).to.equal(100);
  453. expect(controller.get('upgradeData.upgradeGroups')[0].get('upgradeItems')[0].get('status')).to.equal('COMPLETED');
  454. expect(controller.get('upgradeData.upgradeGroups')[0].get('upgradeItems')[0].get('progress_percent')).to.equal(100);
  455. expect(controller.get('upgradeData.upgradeGroups')[0].get('upgradeItems')[0].get('tasks')[0].get('status')).to.equal('COMPLETED');
  456. });
  457. });
  458. describe("#initUpgradeData()", function() {
  459. it("", function() {
  460. var newData = {
  461. Upgrade: {
  462. request_id: 1
  463. },
  464. upgrade_groups: [
  465. {
  466. UpgradeGroup: {
  467. group_id: 1
  468. },
  469. upgrade_items: [
  470. {
  471. UpgradeItem: {
  472. stage_id: 1
  473. },
  474. tasks: [
  475. {
  476. Tasks: {
  477. id: 1
  478. }
  479. }
  480. ]
  481. }
  482. ]
  483. }
  484. ]
  485. };
  486. controller.initUpgradeData(newData);
  487. expect(controller.get('upgradeData.Upgrade.request_id')).to.equal(1);
  488. expect(controller.get('upgradeData.upgradeGroups')[0].get('group_id')).to.equal(1);
  489. expect(controller.get('upgradeData.upgradeGroups')[0].get('upgradeItems')[0].get('stage_id')).to.equal(1);
  490. expect(controller.get('upgradeData.upgradeGroups')[0].get('upgradeItems')[0].get('tasks')[0].get('id')).to.equal(1);
  491. });
  492. });
  493. describe("#finish()", function() {
  494. before(function () {
  495. sinon.stub(App.clusterStatus, 'setClusterStatus', Em.K);
  496. sinon.stub(controller, 'setDBProperty', Em.K);
  497. });
  498. after(function () {
  499. App.clusterStatus.setClusterStatus.restore();
  500. controller.setDBProperty.restore();
  501. });
  502. it("reset upgrade info", function() {
  503. controller.finish();
  504. expect(controller.get('upgradeId')).to.be.null;
  505. expect(controller.setDBProperty.calledWith('upgradeId', undefined)).to.be.true;
  506. expect(App.get('upgradeState')).to.equal('INIT');
  507. expect(controller.get('upgradeVersion')).to.be.null;
  508. expect(controller.setDBProperty.calledWith('upgradeVersion', undefined)).to.be.true;
  509. expect(App.clusterStatus.setClusterStatus.calledOnce).to.be.true;
  510. });
  511. });
  512. });