stack_and_upgrade_controller_test.js 46 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438
  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. require('utils/string_utils');
  21. describe('App.MainAdminStackAndUpgradeController', function() {
  22. var controller = App.MainAdminStackAndUpgradeController.create({
  23. getDBProperty: Em.K,
  24. setDBProperty: Em.K
  25. });
  26. describe("#realRepoUrl", function() {
  27. before(function () {
  28. this.mock = sinon.stub(App, 'get');
  29. });
  30. after(function () {
  31. this.mock.restore();
  32. });
  33. it("", function() {
  34. this.mock.withArgs('apiPrefix').returns('apiPrefix');
  35. this.mock.withArgs('stackVersionURL').returns('stackVersionURL');
  36. controller.propertyDidChange('realRepoUrl');
  37. expect(controller.get('realRepoUrl')).to.equal('apiPrefixstackVersionURL/compatible_repository_versions?fields=*,operating_systems/*,operating_systems/repositories/*');
  38. });
  39. });
  40. describe("#realStackUrl", function() {
  41. before(function () {
  42. this.mock = sinon.stub(App, 'get');
  43. });
  44. after(function () {
  45. this.mock.restore();
  46. });
  47. it("", function() {
  48. this.mock.withArgs('apiPrefix').returns('apiPrefix');
  49. this.mock.withArgs('clusterName').returns('clusterName');
  50. controller.propertyDidChange('realStackUrl');
  51. expect(controller.get('realStackUrl')).to.equal('apiPrefix/clusters/clusterName/stack_versions?fields=*,repository_versions/*,repository_versions/operating_systems/repositories/*');
  52. });
  53. });
  54. describe("#realUpdateUrl", function() {
  55. before(function () {
  56. this.mock = sinon.stub(App, 'get');
  57. });
  58. after(function () {
  59. this.mock.restore();
  60. });
  61. it("", function() {
  62. this.mock.withArgs('apiPrefix').returns('apiPrefix');
  63. this.mock.withArgs('clusterName').returns('clusterName');
  64. controller.propertyDidChange('realUpdateUrl');
  65. expect(controller.get('realUpdateUrl')).to.equal('apiPrefix/clusters/clusterName/stack_versions?fields=ClusterStackVersions/*');
  66. });
  67. });
  68. describe("#requestStatus", function() {
  69. it("isSuspended false", function() {
  70. controller.set('isSuspended', false);
  71. controller.set('upgradeData', { Upgrade: {request_status: 'ABORTED'}});
  72. controller.propertyDidChange('requestStatus');
  73. expect(controller.get('requestStatus')).to.equal('ABORTED');
  74. });
  75. it("isSuspended true", function() {
  76. controller.set('isSuspended', true);
  77. controller.set('upgradeData', { Upgrade: {request_status: 'ABORTED'}});
  78. controller.propertyDidChange('requestStatus');
  79. expect(controller.get('requestStatus')).to.equal('SUSPENDED');
  80. });
  81. });
  82. describe("#load()", function() {
  83. before(function(){
  84. sinon.stub(controller, 'loadUpgradeData').returns({
  85. done: function(callback) {callback();}
  86. });
  87. sinon.stub(controller, 'loadStackVersionsToModel').returns({
  88. done: function(callback) {callback();}
  89. });
  90. sinon.stub(controller, 'loadRepoVersionsToModel').returns({
  91. done: function(callback) {callback();}
  92. });
  93. sinon.stub(App.StackVersion, 'find').returns([Em.Object.create({
  94. state: 'CURRENT',
  95. repositoryVersion: {
  96. repositoryVersion: '2.2',
  97. displayName: 'HDP-2.2'
  98. }
  99. })]);
  100. });
  101. after(function(){
  102. controller.loadUpgradeData.restore();
  103. controller.loadStackVersionsToModel.restore();
  104. controller.loadRepoVersionsToModel.restore();
  105. App.StackVersion.find.restore();
  106. });
  107. it("", function() {
  108. controller.load();
  109. expect(controller.loadUpgradeData.calledWith(true)).to.be.true;
  110. expect(controller.loadStackVersionsToModel.calledWith(true)).to.be.true;
  111. expect(controller.loadRepoVersionsToModel.calledOnce).to.be.true;
  112. expect(controller.get('currentVersion')).to.eql({
  113. "repository_version": "2.2",
  114. "repository_name": "HDP-2.2"
  115. });
  116. });
  117. });
  118. describe("#loadUpgradeData()", function() {
  119. beforeEach(function () {
  120. sinon.stub(App.ajax, 'send').returns({
  121. then: Em.K,
  122. complete: Em.K
  123. });
  124. });
  125. afterEach(function () {
  126. App.ajax.send.restore();
  127. });
  128. it("get entire data", function() {
  129. controller.set('upgradeId', 1);
  130. controller.loadUpgradeData();
  131. expect(App.ajax.send.getCall(0).args[0]).to.eql({
  132. name: 'admin.upgrade.data',
  133. sender: controller,
  134. data: {
  135. id: 1
  136. },
  137. success: 'loadUpgradeDataSuccessCallback'
  138. })
  139. });
  140. it("get only state", function() {
  141. controller.set('upgradeId', 1);
  142. controller.loadUpgradeData(true);
  143. expect(App.ajax.send.getCall(0).args[0]).to.eql({
  144. name: 'admin.upgrade.state',
  145. sender: controller,
  146. data: {
  147. id: 1
  148. },
  149. success: 'loadUpgradeDataSuccessCallback'
  150. })
  151. });
  152. it("upgrade id is null", function() {
  153. controller.set('upgradeId', null);
  154. controller.loadUpgradeData();
  155. expect(App.ajax.send.called).to.be.false;
  156. });
  157. });
  158. describe("#loadUpgradeDataSuccessCallback()", function() {
  159. var retryCases = [
  160. {
  161. isRetryPendingInitial: true,
  162. status: 'ABORTED',
  163. isRetryPending: true,
  164. requestInProgress: true,
  165. title: 'retry request not yet applied'
  166. },
  167. {
  168. isRetryPendingInitial: true,
  169. status: 'UPGRADING',
  170. isRetryPending: false,
  171. requestInProgress: false,
  172. title: 'retry request applied'
  173. },
  174. {
  175. isRetryPendingInitial: false,
  176. status: 'ABORTED',
  177. isRetryPending: false,
  178. requestInProgress: true,
  179. title: 'no retry request sent'
  180. },
  181. {
  182. isRetryPendingInitial: false,
  183. status: 'UPGRADING',
  184. isRetryPending: false,
  185. requestInProgress: true,
  186. title: 'upgrade wasn\'t aborted'
  187. }
  188. ];
  189. beforeEach(function () {
  190. sinon.stub(controller, 'updateUpgradeData', Em.K);
  191. sinon.stub(controller, 'setDBProperty', Em.K);
  192. });
  193. afterEach(function () {
  194. controller.updateUpgradeData.restore();
  195. controller.setDBProperty.restore();
  196. });
  197. it("correct data", function() {
  198. var data = {
  199. "Upgrade": {
  200. "request_status": "UPGRADED"
  201. },
  202. "upgrade_groups": [
  203. {
  204. "UpgradeGroup": {
  205. "id": 1
  206. },
  207. "upgrade_items": []
  208. }
  209. ]};
  210. controller.loadUpgradeDataSuccessCallback(data);
  211. expect(App.get('upgradeState')).to.equal('UPGRADED');
  212. expect(controller.updateUpgradeData.calledOnce).to.be.true;
  213. expect(controller.setDBProperty.calledWith('upgradeState', 'UPGRADED')).to.be.true;
  214. });
  215. it("data is null", function() {
  216. var data = null;
  217. controller.loadUpgradeDataSuccessCallback(data);
  218. expect(controller.updateUpgradeData.called).to.be.false;
  219. expect(controller.setDBProperty.called).to.be.false;
  220. });
  221. retryCases.forEach(function (item) {
  222. it(item.title, function () {
  223. var data = {
  224. "Upgrade": {
  225. "request_status": item.status
  226. }
  227. };
  228. controller.setProperties({
  229. isRetryPending: item.isRetryPendingInitial,
  230. requestInProgress: true
  231. });
  232. controller.loadUpgradeDataSuccessCallback(data);
  233. expect(controller.getProperties(['isRetryPending', 'requestInProgress'])).to.eql({
  234. isRetryPending: item.isRetryPending,
  235. requestInProgress: item.requestInProgress
  236. });
  237. });
  238. });
  239. });
  240. describe("#getUpgradeItem()", function() {
  241. beforeEach(function () {
  242. sinon.stub(App.ajax, 'send', Em.K);
  243. });
  244. afterEach(function () {
  245. App.ajax.send.restore();
  246. });
  247. it("", function() {
  248. var item = Em.Object.create({
  249. request_id: 1,
  250. group_id: 2,
  251. stage_id: 3
  252. });
  253. controller.getUpgradeItem(item);
  254. expect(App.ajax.send.getCall(0).args[0]).to.eql({
  255. name: 'admin.upgrade.upgrade_item',
  256. sender: controller,
  257. data: {
  258. upgradeId: 1,
  259. groupId: 2,
  260. stageId: 3
  261. },
  262. success: 'getUpgradeItemSuccessCallback'
  263. });
  264. });
  265. });
  266. describe("#openUpgradeDialog()", function () {
  267. before(function () {
  268. sinon.stub(App.router, 'transitionTo', Em.K);
  269. });
  270. after(function () {
  271. App.router.transitionTo.restore();
  272. });
  273. it("should open dialog", function () {
  274. controller.openUpgradeDialog();
  275. expect(App.router.transitionTo.calledWith('admin.stackUpgrade')).to.be.true;
  276. });
  277. });
  278. describe("#runPreUpgradeCheck()", function() {
  279. before(function () {
  280. sinon.stub(App.ajax, 'send', Em.K);
  281. });
  282. after(function () {
  283. App.ajax.send.restore();
  284. });
  285. it("make ajax call", function() {
  286. controller.runPreUpgradeCheck(Em.Object.create({
  287. repositoryVersion: '2.2',
  288. displayName: 'HDP-2.2',
  289. upgradeType: 'ROLLING',
  290. skipComponentFailures: false,
  291. skipSCFailures: false
  292. }));
  293. expect(App.ajax.send.getCall(0).args[0]).to.eql({
  294. name: "admin.upgrade.pre_upgrade_check",
  295. sender: controller,
  296. data: {
  297. value: '2.2',
  298. label: 'HDP-2.2',
  299. type: 'ROLLING',
  300. skipComponentFailures: 'false',
  301. skipSCFailures: 'false'
  302. },
  303. success: "runPreUpgradeCheckSuccess",
  304. error: "runPreUpgradeCheckError"
  305. });
  306. });
  307. });
  308. describe("#runPreUpgradeCheckSuccess()", function () {
  309. var cases = [
  310. {
  311. check: {
  312. "check": "Work-preserving RM/NM restart is enabled in YARN configs",
  313. "status": "FAIL",
  314. "reason": "FAIL",
  315. "failed_on": [],
  316. "check_type": "SERVICE"
  317. },
  318. showClusterCheckPopupCalledCount: 1,
  319. upgradeCalledCount: 0,
  320. title: 'popup is displayed if fails are present'
  321. },
  322. {
  323. check: {
  324. "check": "Configuration Merge Check",
  325. "status": "WARNING",
  326. "reason": "Conflict",
  327. "failed_on": [],
  328. "failed_detail": [
  329. {
  330. type: 't0',
  331. property: 'p0',
  332. current: 'c0',
  333. new_stack_value: 'n0',
  334. result_value: 'n0'
  335. },
  336. {
  337. type: 't1',
  338. property: 'p1',
  339. current: 'c1',
  340. new_stack_value: null,
  341. result_value: 'c1'
  342. },
  343. {
  344. type: 't2',
  345. property: 'p2',
  346. current: 'c2',
  347. new_stack_value: null,
  348. result_value: null
  349. }
  350. ],
  351. "check_type": "CLUSTER",
  352. "id": "CONFIG_MERGE"
  353. },
  354. showClusterCheckPopupCalledCount: 1,
  355. upgradeCalledCount: 0,
  356. configs: [
  357. {
  358. type: 't0',
  359. name: 'p0',
  360. currentValue: 'c0',
  361. recommendedValue: 'n0',
  362. resultingValue: 'n0',
  363. isDeprecated: false,
  364. willBeRemoved: false
  365. },
  366. {
  367. type: 't1',
  368. name: 'p1',
  369. currentValue: 'c1',
  370. recommendedValue: Em.I18n.t('popup.clusterCheck.Upgrade.configsMerge.deprecated'),
  371. resultingValue: 'c1',
  372. isDeprecated: true,
  373. willBeRemoved: false
  374. },
  375. {
  376. type: 't2',
  377. name: 'p2',
  378. currentValue: 'c2',
  379. recommendedValue: Em.I18n.t('popup.clusterCheck.Upgrade.configsMerge.deprecated'),
  380. resultingValue: Em.I18n.t('popup.clusterCheck.Upgrade.configsMerge.willBeRemoved'),
  381. isDeprecated: true,
  382. willBeRemoved: true
  383. }
  384. ],
  385. title: 'popup is displayed if warnings are present; configs merge conflicts'
  386. },
  387. {
  388. check: {
  389. "check": "Work-preserving RM/NM restart is enabled in YARN configs",
  390. "status": "PASS",
  391. "reason": "OK",
  392. "failed_on": [],
  393. "check_type": "SERVICE"
  394. },
  395. showClusterCheckPopupCalledCount: 0,
  396. upgradeCalledCount: 1,
  397. title: 'upgrade is started if fails and warnings are absent'
  398. }
  399. ];
  400. beforeEach(function () {
  401. sinon.stub(App, 'showClusterCheckPopup', Em.K);
  402. sinon.stub(controller, 'upgrade', Em.K);
  403. });
  404. afterEach(function () {
  405. App.showClusterCheckPopup.restore();
  406. controller.upgrade.restore();
  407. });
  408. cases.forEach(function (item) {
  409. it(item.title, function () {
  410. controller.runPreUpgradeCheckSuccess(
  411. {
  412. items: [
  413. {
  414. UpgradeChecks: item.check
  415. }
  416. ]
  417. }, null, {
  418. label: 'name'
  419. }
  420. );
  421. expect(controller.upgrade.callCount).to.equal(item.upgradeCalledCount);
  422. expect(App.showClusterCheckPopup.callCount).to.equal(item.showClusterCheckPopupCalledCount);
  423. if (item.check.id == 'CONFIG_MERGE') {
  424. expect(App.showClusterCheckPopup.firstCall.args[7]).to.eql(item.configs);
  425. }
  426. });
  427. });
  428. });
  429. describe("#initDBProperties()", function() {
  430. before(function () {
  431. this.mock = sinon.stub(controller, 'getDBProperties');
  432. });
  433. after(function () {
  434. this.mock.restore();
  435. });
  436. it("set string properties", function () {
  437. this.mock.returns({prop: 'string'});
  438. controller.initDBProperties();
  439. expect(controller.get('prop')).to.equal('string');
  440. });
  441. it("set number properties", function () {
  442. this.mock.returns({prop: 0});
  443. controller.initDBProperties();
  444. expect(controller.get('prop')).to.equal(0);
  445. });
  446. it("set boolean properties", function () {
  447. this.mock.returns({prop: false});
  448. controller.initDBProperties();
  449. expect(controller.get('prop')).to.be.false;
  450. });
  451. it("set undefined properties", function () {
  452. this.mock.returns({prop: undefined});
  453. controller.set('prop', 'value');
  454. controller.initDBProperties();
  455. expect(controller.get('prop')).to.equal('value');
  456. });
  457. it("set null properties", function () {
  458. this.mock.returns({prop: null});
  459. controller.set('prop', 'value');
  460. controller.initDBProperties();
  461. expect(controller.get('prop')).to.equal('value');
  462. });
  463. });
  464. describe("#init()", function() {
  465. before(function () {
  466. sinon.stub(controller, 'initDBProperties', Em.K);
  467. });
  468. after(function () {
  469. controller.initDBProperties.restore();
  470. });
  471. it("call initDBProperties", function () {
  472. controller.init();
  473. expect(controller.initDBProperties.calledOnce).to.be.true;
  474. });
  475. });
  476. describe("#upgrade()", function() {
  477. before(function () {
  478. sinon.stub(App.ajax, 'send', Em.K);
  479. sinon.stub(controller, 'setDBProperty', Em.K);
  480. });
  481. after(function () {
  482. App.ajax.send.restore();
  483. controller.setDBProperty.restore();
  484. });
  485. it("make ajax call", function() {
  486. controller.set('currentVersion', {
  487. repository_version: '2.2'
  488. });
  489. controller.upgrade({
  490. value: '2.2',
  491. label: 'HDP-2.2'
  492. });
  493. expect(App.ajax.send.getCall(0).args[0].data).to.eql({"value": '2.2', "label": 'HDP-2.2'});
  494. expect(App.ajax.send.getCall(0).args[0].name).to.eql('admin.upgrade.start');
  495. expect(App.ajax.send.getCall(0).args[0].sender).to.eql(controller);
  496. expect(App.ajax.send.getCall(0).args[0].success).to.eql('upgradeSuccessCallback');
  497. expect(App.ajax.send.getCall(0).args[0].callback).to.be.called;
  498. expect(controller.setDBProperty.calledWith('currentVersion', {
  499. repository_version: '2.2'
  500. })).to.be.true;
  501. });
  502. });
  503. describe("#upgradeSuccessCallback()", function() {
  504. before(function () {
  505. sinon.stub(App.clusterStatus, 'setClusterStatus', Em.K);
  506. sinon.stub(controller, 'openUpgradeDialog', Em.K);
  507. sinon.stub(controller, 'setDBProperties', Em.K);
  508. sinon.stub(controller, 'load', Em.K);
  509. });
  510. after(function () {
  511. App.clusterStatus.setClusterStatus.restore();
  512. controller.openUpgradeDialog.restore();
  513. controller.setDBProperties.restore();
  514. controller.load.restore();
  515. });
  516. it("open upgrade dialog", function() {
  517. var data = {
  518. resources: [
  519. {
  520. Upgrade: {
  521. request_id: 1
  522. }
  523. }
  524. ]
  525. };
  526. controller.upgradeSuccessCallback(data, {}, {label: 'HDP-2.2.1', isDowngrade: true});
  527. expect(controller.load.calledOnce).to.be.true;
  528. expect(controller.get('upgradeVersion')).to.equal('HDP-2.2.1');
  529. expect(controller.get('upgradeData')).to.be.null;
  530. expect(controller.get('isDowngrade')).to.be.true;
  531. expect(App.clusterStatus.setClusterStatus.calledOnce).to.be.true;
  532. expect(controller.openUpgradeDialog.calledOnce).to.be.true;
  533. });
  534. });
  535. describe("#updateUpgradeData()", function() {
  536. beforeEach(function () {
  537. sinon.stub(controller, 'initUpgradeData', Em.K);
  538. });
  539. afterEach(function () {
  540. controller.initUpgradeData.restore();
  541. });
  542. it("data loaded first time", function() {
  543. controller.set('upgradeData', null);
  544. controller.updateUpgradeData({});
  545. expect(controller.initUpgradeData.calledWith({})).to.be.true;
  546. });
  547. it("update loaded data", function() {
  548. var oldData = Em.Object.create({
  549. upgradeGroups: [
  550. Em.Object.create({
  551. group_id: 1,
  552. upgradeItems: [
  553. Em.Object.create({
  554. stage_id: 1
  555. })
  556. ]
  557. }),
  558. Em.Object.create({
  559. group_id: 2,
  560. upgradeItems: [
  561. Em.Object.create({
  562. stage_id: 2
  563. }),
  564. Em.Object.create({
  565. stage_id: 3
  566. })
  567. ]
  568. })
  569. ]
  570. });
  571. var newData = {
  572. Upgrade: {
  573. request_id: 1
  574. },
  575. upgrade_groups: [
  576. {
  577. UpgradeGroup: {
  578. group_id: 1,
  579. status: 'COMPLETED',
  580. progress_percent: 100,
  581. completed_task_count: 3
  582. },
  583. upgrade_items: [
  584. {
  585. UpgradeItem: {
  586. stage_id: 1,
  587. status: 'COMPLETED',
  588. progress_percent: 100
  589. }
  590. }
  591. ]
  592. },
  593. {
  594. UpgradeGroup: {
  595. group_id: 2,
  596. status: 'ABORTED',
  597. progress_percent: 50,
  598. completed_task_count: 1
  599. },
  600. upgrade_items: [
  601. {
  602. UpgradeItem: {
  603. stage_id: 2,
  604. status: 'ABORTED',
  605. progress_percent: 99
  606. }
  607. },
  608. {
  609. UpgradeItem: {
  610. stage_id: 3,
  611. status: 'PENDING',
  612. progress_percent: 0
  613. }
  614. }
  615. ]
  616. }
  617. ]
  618. };
  619. controller.set('upgradeData', oldData);
  620. controller.updateUpgradeData(newData);
  621. expect(controller.get('upgradeData.upgradeGroups')[0].get('status')).to.equal('COMPLETED');
  622. expect(controller.get('upgradeData.upgradeGroups')[0].get('progress_percent')).to.equal(100);
  623. expect(controller.get('upgradeData.upgradeGroups')[0].get('completed_task_count')).to.equal(3);
  624. expect(controller.get('upgradeData.upgradeGroups')[0].get('upgradeItems')[0].get('status')).to.equal('COMPLETED');
  625. expect(controller.get('upgradeData.upgradeGroups')[0].get('upgradeItems')[0].get('progress_percent')).to.equal(100);
  626. expect(controller.get('upgradeData.upgradeGroups')[0].get('hasExpandableItems')).to.be.true;
  627. expect(controller.get('upgradeData.upgradeGroups')[1].get('status')).to.equal('ABORTED');
  628. expect(controller.get('upgradeData.upgradeGroups')[1].get('progress_percent')).to.equal(50);
  629. expect(controller.get('upgradeData.upgradeGroups')[1].get('completed_task_count')).to.equal(1);
  630. expect(controller.get('upgradeData.upgradeGroups')[1].get('upgradeItems')[0].get('status')).to.equal('ABORTED');
  631. expect(controller.get('upgradeData.upgradeGroups')[1].get('upgradeItems')[1].get('status')).to.equal('PENDING');
  632. expect(controller.get('upgradeData.upgradeGroups')[1].get('upgradeItems')[0].get('progress_percent')).to.equal(99);
  633. expect(controller.get('upgradeData.upgradeGroups')[1].get('upgradeItems')[1].get('progress_percent')).to.equal(0);
  634. expect(controller.get('upgradeData.upgradeGroups')[1].get('hasExpandableItems')).to.be.false;
  635. });
  636. });
  637. describe("#initUpgradeData()", function() {
  638. beforeEach(function () {
  639. sinon.stub(controller, 'setDBProperty');
  640. });
  641. afterEach(function () {
  642. controller.setDBProperty.restore();
  643. });
  644. it("", function() {
  645. var newData = {
  646. Upgrade: {
  647. request_id: 1,
  648. downgrade_allowed: false
  649. },
  650. upgrade_groups: [
  651. {
  652. UpgradeGroup: {
  653. group_id: 1
  654. },
  655. upgrade_items: [
  656. {
  657. UpgradeItem: {
  658. stage_id: 1,
  659. status: 'IN_PROGRESS'
  660. }
  661. },
  662. {
  663. UpgradeItem: {
  664. stage_id: 2
  665. }
  666. }
  667. ]
  668. },
  669. {
  670. UpgradeGroup: {
  671. group_id: 2
  672. },
  673. upgrade_items: []
  674. },
  675. {
  676. UpgradeGroup: {
  677. group_id: 3
  678. },
  679. upgrade_items: [
  680. {
  681. UpgradeItem: {
  682. stage_id: 3,
  683. status: 'ABORTED'
  684. }
  685. },
  686. {
  687. UpgradeItem: {
  688. stage_id: 4,
  689. status: 'PENDING'
  690. }
  691. }
  692. ]
  693. }
  694. ]
  695. };
  696. controller.initUpgradeData(newData);
  697. expect(controller.setDBProperty.calledWith('downgradeAllowed', false)).to.be.true;
  698. expect(controller.get('downgradeAllowed')).to.be.false;
  699. expect(controller.get('upgradeData.Upgrade.request_id')).to.equal(1);
  700. expect(controller.get('upgradeData.upgradeGroups')[0].get('group_id')).to.equal(3);
  701. expect(controller.get('upgradeData.upgradeGroups')[1].get('group_id')).to.equal(2);
  702. expect(controller.get('upgradeData.upgradeGroups')[2].get('group_id')).to.equal(1);
  703. expect(controller.get('upgradeData.upgradeGroups')[2].get('upgradeItems')[0].get('stage_id')).to.equal(2);
  704. expect(controller.get('upgradeData.upgradeGroups')[2].get('upgradeItems')[1].get('stage_id')).to.equal(1);
  705. expect(controller.get('upgradeData.upgradeGroups')[0].get('hasExpandableItems')).to.be.false;
  706. expect(controller.get('upgradeData.upgradeGroups')[1].get('hasExpandableItems')).to.be.false;
  707. expect(controller.get('upgradeData.upgradeGroups')[2].get('hasExpandableItems')).to.be.true;
  708. });
  709. });
  710. describe.skip("#finish()", function() {
  711. before(function () {
  712. sinon.stub(App.clusterStatus, 'setClusterStatus', Em.K);
  713. sinon.stub(controller, 'setDBProperty', Em.K);
  714. });
  715. after(function () {
  716. App.clusterStatus.setClusterStatus.restore();
  717. controller.setDBProperty.restore();
  718. });
  719. it("upgradeState is not COMPLETED", function() {
  720. App.set('upgradeState', 'UPGRADING');
  721. controller.finish();
  722. expect(App.clusterStatus.setClusterStatus.called).to.be.false;
  723. });
  724. it("upgradeState is COMPLETED", function() {
  725. App.set('upgradeState', 'COMPLETED');
  726. controller.finish();
  727. expect(controller.setDBProperty.calledWith('upgradeId', undefined)).to.be.true;
  728. expect(controller.setDBProperty.calledWith('upgradeVersion', undefined)).to.be.true;
  729. expect(controller.setDBProperty.calledWith('upgradeState', 'INIT')).to.be.true;
  730. expect(controller.setDBProperty.calledWith('currentVersion', undefined)).to.be.true;
  731. expect(App.get('upgradeState')).to.equal('INIT');
  732. expect(App.clusterStatus.setClusterStatus.calledOnce).to.be.true;
  733. });
  734. });
  735. describe("#confirmDowngrade()", function() {
  736. before(function () {
  737. sinon.spy(App, 'showConfirmationPopup');
  738. sinon.stub(controller, 'downgrade', Em.K);
  739. });
  740. after(function () {
  741. App.showConfirmationPopup.restore();
  742. controller.downgrade.restore();
  743. });
  744. it("show confirmation popup", function() {
  745. controller.set('currentVersion', Em.Object.create({
  746. repository_version: '2.2',
  747. repository_name: 'HDP-2.2'
  748. }));
  749. var popup = controller.confirmDowngrade();
  750. expect(App.showConfirmationPopup.calledOnce).to.be.true;
  751. popup.onPrimary();
  752. expect(controller.downgrade.calledWith(Em.Object.create({
  753. repository_version: '2.2',
  754. repository_name: 'HDP-2.2'
  755. }))).to.be.true;
  756. });
  757. });
  758. describe("#upgradeOptions()", function() {
  759. before(function () {
  760. sinon.spy(App, 'ModalPopup');
  761. sinon.spy(App, 'showConfirmationFeedBackPopup');
  762. this.mock = sinon.stub(controller, 'getSupportedUpgradeTypes');
  763. sinon.stub(controller, 'runPreUpgradeCheck', Em.K);
  764. });
  765. after(function () {
  766. App.ModalPopup.restore();
  767. App.showConfirmationFeedBackPopup.restore();
  768. controller.runPreUpgradeCheck.restore();
  769. this.mock.restore();
  770. controller.get('upgradeMethods').setEach('selected', false);
  771. });
  772. it("show confirmation popup", function() {
  773. var version = Em.Object.create({displayName: 'HDP-2.2'});
  774. this.mock.returns({
  775. done: function(callback) {callback([1]);}
  776. });
  777. controller.get('upgradeMethods')[0].set('selected', true);
  778. controller.set('isDowngrade', false);
  779. var popup = controller.upgradeOptions(false, version);
  780. expect(App.ModalPopup.calledOnce).to.be.true;
  781. var confirmPopup = popup.onPrimary();
  782. expect(App.showConfirmationFeedBackPopup.calledOnce).to.be.true;
  783. confirmPopup.onPrimary();
  784. expect(controller.runPreUpgradeCheck.calledWith(version)).to.be.true;
  785. });
  786. it("NOT show confirmation popup on Downgrade", function() {
  787. var version = Em.Object.create({displayName: 'HDP-2.2'});
  788. this.mock.returns({
  789. done: function(callback) {callback([1]);}
  790. });
  791. controller.set('isDowngrade', true);
  792. var popup = controller.upgradeOptions(false, version);
  793. expect(App.ModalPopup.calledOnce).to.be.false;
  794. });
  795. });
  796. describe("#confirmUpgrade()", function() {
  797. before(function () {
  798. sinon.stub(controller, 'upgradeOptions', Em.K);
  799. });
  800. after(function () {
  801. controller.upgradeOptions.restore();
  802. });
  803. it("show show upgrade options popup window", function() {
  804. var version = Em.Object.create({displayName: 'HDP-2.2'});
  805. controller.confirmUpgrade(version);
  806. expect(controller.upgradeOptions.calledWith(false, version)).to.be.true;
  807. });
  808. });
  809. describe("#downgrade()", function() {
  810. before(function () {
  811. sinon.stub(App.ajax, 'send', Em.K);
  812. sinon.stub(controller, 'abortUpgrade');
  813. sinon.stub(App.RepositoryVersion, 'find').returns([
  814. Em.Object.create({
  815. displayName: 'HDP-2.3',
  816. repositoryVersion: '2.3'
  817. })
  818. ]);
  819. });
  820. after(function () {
  821. App.ajax.send.restore();
  822. controller.abortUpgrade.restore();
  823. App.RepositoryVersion.find.restore();
  824. });
  825. it("make ajax call", function() {
  826. controller.set('upgradeVersion', 'HDP-2.3');
  827. controller.set('upgradeType', 'NON_ROLLING');
  828. controller.downgrade(Em.Object.create({
  829. repository_version: '2.2',
  830. repository_name: 'HDP-2.2'
  831. }), {context: 'context'});
  832. expect(controller.abortUpgrade.calledOnce).to.be.true;
  833. expect(App.ajax.send.getCall(0).args[0].data).to.eql({
  834. from: '2.3',
  835. value: '2.2',
  836. label: 'HDP-2.2',
  837. isDowngrade: true,
  838. upgradeType: "NON_ROLLING"
  839. });
  840. expect(App.ajax.send.getCall(0).args[0].name).to.eql('admin.downgrade.start');
  841. expect(App.ajax.send.getCall(0).args[0].sender).to.eql(controller);
  842. expect(App.ajax.send.getCall(0).args[0].success).to.eql('upgradeSuccessCallback');
  843. expect(App.ajax.send.getCall(0).args[0].callback).to.be.called;
  844. });
  845. });
  846. describe("#installRepoVersionConfirmation()", function () {
  847. before(function () {
  848. sinon.stub(controller, 'installRepoVersion', Em.K);
  849. });
  850. after(function () {
  851. controller.installRepoVersion.restore();
  852. });
  853. it("show popup", function () {
  854. var repo = Em.Object.create({'displayName': 'HDP-2.2'});
  855. var popup = controller.installRepoVersionConfirmation(repo);
  856. popup.onPrimary();
  857. expect(controller.installRepoVersion.calledWith(repo)).to.be.true;
  858. });
  859. });
  860. describe("#installRepoVersion()", function () {
  861. before(function () {
  862. sinon.stub(App.ajax, 'send', Em.K);
  863. });
  864. after(function () {
  865. App.ajax.send.restore();
  866. });
  867. it("make ajax call", function () {
  868. var repo = Em.Object.create({
  869. stackVersionType: 'HDP',
  870. stackVersionNumber: '2.2',
  871. repositoryVersion: '2.2.1',
  872. repoId: 1
  873. });
  874. controller.installRepoVersion(repo);
  875. expect(App.ajax.send.calledOnce).to.be.true;
  876. });
  877. });
  878. describe("#installRepoVersionSuccess()", function() {
  879. var mock = Em.Object.create({
  880. id: 1,
  881. defaultStatus: 'INIT',
  882. stackVersion: {}
  883. });
  884. before(function () {
  885. sinon.spy(mock, 'set');
  886. sinon.stub(App.db, 'set', Em.K);
  887. sinon.stub(App.clusterStatus, 'setClusterStatus', Em.K);
  888. sinon.stub(App.RepositoryVersion, 'find').returns(mock);
  889. });
  890. after(function () {
  891. App.db.set.restore();
  892. App.clusterStatus.setClusterStatus.restore();
  893. App.RepositoryVersion.find.restore();
  894. });
  895. it("", function() {
  896. controller.installRepoVersionSuccess({Requests: {id: 1}}, {}, {id: 1});
  897. expect(App.db.set.calledWith('repoVersionInstall', 'id', [1])).to.be.true;
  898. expect(App.clusterStatus.setClusterStatus.calledOnce).to.be.true;
  899. expect(App.RepositoryVersion.find.calledWith(1)).to.be.true;
  900. expect(App.RepositoryVersion.find(1).get('defaultStatus')).to.equal('INSTALLING');
  901. expect(App.RepositoryVersion.find(1).get('stackVersion.state')).to.equal('INSTALLING');
  902. });
  903. });
  904. describe("#setUpgradeItemStatus()", function () {
  905. before(function () {
  906. sinon.stub(App.ajax, 'send', function () {
  907. return {
  908. done: function (callback) {
  909. callback();
  910. }
  911. }
  912. });
  913. });
  914. after(function () {
  915. App.ajax.send.restore();
  916. });
  917. it("", function () {
  918. var item = Em.Object.create({
  919. request_id: 1,
  920. stage_id: 1,
  921. group_id: 1
  922. });
  923. controller.setUpgradeItemStatus(item, 'PENDING');
  924. expect(App.ajax.send.getCall(0).args[0].data).to.eql({upgradeId: 1, itemId: 1, groupId: 1, status: 'PENDING'});
  925. expect(App.ajax.send.getCall(0).args[0].name).to.eql('admin.upgrade.upgradeItem.setState');
  926. expect(App.ajax.send.getCall(0).args[0].sender).to.eql(controller);
  927. expect(App.ajax.send.getCall(0).args[0].callback).to.be.called;
  928. expect(item.get('status')).to.equal('PENDING');
  929. });
  930. });
  931. describe("#prepareRepoForSaving()", function () {
  932. it("prepare date for saving", function () {
  933. var repo = Em.Object.create({
  934. operatingSystems: [
  935. Em.Object.create({
  936. osType: "redhat6",
  937. isDisabled: Ember.computed.not('isSelected'),
  938. repositories: [Em.Object.create({
  939. "baseUrl": "111121",
  940. "repoId": "HDP-2.2",
  941. "repoName": "HDP",
  942. hasError: false
  943. }),
  944. Em.Object.create({
  945. "baseUrl": "1",
  946. "repoId": "HDP-UTILS-1.1.0.20",
  947. "repoName": "HDP-UTILS",
  948. hasError: false
  949. })]
  950. })
  951. ]
  952. });
  953. var result = {
  954. "operating_systems": [
  955. {
  956. "OperatingSystems": {
  957. "os_type": "redhat6"
  958. },
  959. "repositories": [
  960. {
  961. "Repositories": {
  962. "base_url": "111121",
  963. "repo_id": "HDP-2.2",
  964. "repo_name": "HDP"
  965. }
  966. },
  967. {
  968. "Repositories": {
  969. "base_url": "1",
  970. "repo_id": "HDP-UTILS-1.1.0.20",
  971. "repo_name": "HDP-UTILS"
  972. }
  973. }
  974. ]
  975. }
  976. ]};
  977. expect(controller.prepareRepoForSaving(repo)).to.eql(result);
  978. });
  979. });
  980. describe("#getStackVersionNumber()", function(){
  981. it("get stack version number", function(){
  982. var repo = Em.Object.create({
  983. "stackVersionType": 'HDP',
  984. "stackVersion": '2.3',
  985. "repositoryVersion": '2.2.1'
  986. });
  987. var stackVersion = controller.getStackVersionNumber(repo);
  988. expect(stackVersion).to.equal('2.3');
  989. });
  990. it("get default stack version number", function(){
  991. App.set('currentStackVersion', '1.2.3');
  992. var repo = Em.Object.create({
  993. "stackVersionType": 'HDP',
  994. "repositoryVersion": '2.2.1'
  995. });
  996. var stackVersion = controller.getStackVersionNumber(repo);
  997. expect(stackVersion).to.equal('1.2.3');
  998. });
  999. });
  1000. describe("#saveRepoOS()", function() {
  1001. before(function(){
  1002. this.mock = sinon.stub(controller, 'validateRepoVersions');
  1003. sinon.stub(controller, 'prepareRepoForSaving', Em.K);
  1004. sinon.stub(App.ajax, 'send').returns({success: Em.K});
  1005. });
  1006. after(function(){
  1007. this.mock.restore();
  1008. controller.prepareRepoForSaving.restore();
  1009. App.ajax.send.restore();
  1010. });
  1011. it("validation errors present", function() {
  1012. this.mock.returns({
  1013. done: function(callback) {callback([1]);}
  1014. });
  1015. controller.saveRepoOS(Em.Object.create({repoVersionId: 1}), true);
  1016. expect(controller.validateRepoVersions.calledWith(Em.Object.create({repoVersionId: 1}), true)).to.be.true;
  1017. expect(controller.prepareRepoForSaving.called).to.be.false;
  1018. expect(App.ajax.send.called).to.be.false;
  1019. });
  1020. it("no validation errors", function() {
  1021. this.mock.returns({
  1022. done: function(callback) {callback([]);}
  1023. });
  1024. controller.saveRepoOS(Em.Object.create({repoVersionId: 1}), true);
  1025. expect(controller.validateRepoVersions.calledWith(Em.Object.create({repoVersionId: 1}), true)).to.be.true;
  1026. expect(controller.prepareRepoForSaving.calledWith(Em.Object.create({repoVersionId: 1}))).to.be.true;
  1027. expect(App.ajax.send.calledOnce).to.be.true;
  1028. });
  1029. });
  1030. describe("#validateRepoVersions()", function () {
  1031. before(function () {
  1032. sinon.stub(App.ajax, 'send').returns({success: Em.K, error: Em.K});
  1033. });
  1034. after(function () {
  1035. App.ajax.send.restore();
  1036. });
  1037. it("skip validation", function () {
  1038. controller.validateRepoVersions(Em.Object.create({repoVersionId: 1}), true);
  1039. expect(App.ajax.send.called).to.be.false;
  1040. });
  1041. it("do validation", function () {
  1042. var repo = Em.Object.create({
  1043. repoVersionId: 1,
  1044. operatingSystems: [
  1045. Em.Object.create({
  1046. isSelected: true,
  1047. repositories: [
  1048. Em.Object.create()
  1049. ]
  1050. })
  1051. ]
  1052. });
  1053. controller.validateRepoVersions(repo, false);
  1054. expect(App.ajax.send.calledOnce).to.be.true;
  1055. });
  1056. });
  1057. describe("#showProgressPopup()", function () {
  1058. var mock = {
  1059. initPopup: Em.K
  1060. };
  1061. before(function () {
  1062. sinon.stub(App.router, 'get').withArgs('highAvailabilityProgressPopupController').returns(mock);
  1063. sinon.spy(mock, 'initPopup');
  1064. });
  1065. after(function () {
  1066. App.router.get.restore();
  1067. mock.initPopup.restore();
  1068. });
  1069. it("", function () {
  1070. controller.showProgressPopup(Em.Object.create());
  1071. expect(mock.initPopup.calledOnce).to.be.true;
  1072. });
  1073. });
  1074. describe("#getUrl()", function() {
  1075. beforeEach(function(){
  1076. controller.reopen({
  1077. realStackUrl: 'realStackUrl',
  1078. realRepoUrl: 'realRepoUrl',
  1079. realUpdateUrl: 'realUpdateUrl'
  1080. });
  1081. });
  1082. it("full load is true, stack is null", function() {
  1083. expect(controller.getUrl(null, true)).to.equal('realRepoUrl');
  1084. });
  1085. it("full load is true, stack is valid", function() {
  1086. expect(controller.getUrl({}, true)).to.equal('realStackUrl');
  1087. });
  1088. it("full load is false, stack is valid", function() {
  1089. expect(controller.getUrl({}, false)).to.equal('realUpdateUrl');
  1090. });
  1091. });
  1092. describe("#loadStackVersionsToModel()", function () {
  1093. before(function () {
  1094. sinon.stub(App.HttpClient, 'get');
  1095. });
  1096. after(function () {
  1097. App.HttpClient.get.restore();
  1098. });
  1099. it("", function () {
  1100. controller.loadStackVersionsToModel();
  1101. expect(App.HttpClient.get.calledOnce).to.be.true;
  1102. });
  1103. });
  1104. describe("#loadRepoVersionsToModel()", function () {
  1105. before(function () {
  1106. sinon.stub(App.HttpClient, 'get');
  1107. });
  1108. after(function () {
  1109. App.HttpClient.get.restore();
  1110. });
  1111. it("", function () {
  1112. controller.loadRepoVersionsToModel();
  1113. expect(App.HttpClient.get.calledOnce).to.be.true;
  1114. });
  1115. });
  1116. describe('#currentVersionObserver()', function () {
  1117. var cases = [
  1118. {
  1119. stackVersionType: 'HDP',
  1120. repoVersion: '2.2.1.1.0-1',
  1121. isStormMetricsSupported: false,
  1122. title: 'HDP < 2.2.2'
  1123. },
  1124. {
  1125. stackVersionType: 'HDP',
  1126. repoVersion: '2.2.2.1.0-1',
  1127. isStormMetricsSupported: true,
  1128. title: 'HDP 2.2.2'
  1129. },
  1130. {
  1131. stackVersionType: 'HDP',
  1132. repoVersion: '2.2.3.1.0-1',
  1133. isStormMetricsSupported: true,
  1134. title: 'HDP > 2.2.2'
  1135. },
  1136. {
  1137. stackVersionType: 'BIGTOP',
  1138. repoVersion: '0.8.1.1.0-1',
  1139. isStormMetricsSupported: true,
  1140. title: 'not HDP'
  1141. }
  1142. ];
  1143. afterEach(function () {
  1144. App.RepositoryVersion.find.restore();
  1145. });
  1146. cases.forEach(function (item) {
  1147. it(item.title, function () {
  1148. sinon.stub(App.RepositoryVersion, 'find').returns([
  1149. Em.Object.create({
  1150. status: 'CURRENT',
  1151. stackVersionType: item.stackVersionType
  1152. })
  1153. ]);
  1154. controller.set('currentVersion', {
  1155. repository_version: item.repoVersion
  1156. });
  1157. expect(App.get('isStormMetricsSupported')).to.equal(item.isStormMetricsSupported);
  1158. });
  1159. });
  1160. });
  1161. describe('#updateFinalize', function () {
  1162. beforeEach(function() {
  1163. sinon.stub($, 'ajax', Em.K);
  1164. controller.set('isFinalizeItem', true);
  1165. });
  1166. afterEach(function () {
  1167. $.ajax.restore();
  1168. });
  1169. it('should do ajax-request', function () {
  1170. sinon.stub(App, 'get').withArgs('upgradeState').returns('HOLDING');
  1171. controller.updateFinalize();
  1172. App.get.restore();
  1173. expect($.ajax.calledOnce).to.be.true;
  1174. });
  1175. it('shouldn\'t do ajax-request', function () {
  1176. sinon.stub(App, 'get').withArgs('upgradeState').returns('HOLDING_TIMEDOUT');
  1177. controller.updateFinalize();
  1178. App.get.restore();
  1179. expect(controller.get('isFinalizeItem')).to.be.false;
  1180. expect($.ajax.calledOnce).to.be.false;
  1181. });
  1182. });
  1183. describe('#updateFinalizeSuccessCallback', function () {
  1184. it('data exists and Finalize should be true', function() {
  1185. var data = {
  1186. items: [
  1187. {
  1188. upgrade_groups: [
  1189. {
  1190. upgrade_items: [
  1191. {
  1192. UpgradeItem: {
  1193. context: controller.get('finalizeContext'),
  1194. status: "HOLDING"
  1195. }
  1196. }
  1197. ]
  1198. }
  1199. ]
  1200. }
  1201. ]
  1202. };
  1203. controller.set('isFinalizeItem', false);
  1204. controller.updateFinalizeSuccessCallback(data);
  1205. expect(controller.get('isFinalizeItem')).to.be.true;
  1206. });
  1207. it('data exists and Finalize should be false', function() {
  1208. var data = {
  1209. upgrade_groups: [
  1210. {
  1211. upgrade_items: [
  1212. {
  1213. UpgradeItem: {
  1214. context: '!@#$%^&',
  1215. status: "HOLDING"
  1216. }
  1217. }
  1218. ]
  1219. }
  1220. ]
  1221. };
  1222. controller.set('isFinalizeItem', true);
  1223. controller.updateFinalizeSuccessCallback(data);
  1224. expect(controller.get('isFinalizeItem')).to.be.false;
  1225. });
  1226. it('data doesn\'t exist', function() {
  1227. var data = null;
  1228. controller.set('isFinalizeItem', true);
  1229. controller.updateFinalizeSuccessCallback(data);
  1230. expect(controller.get('isFinalizeItem')).to.be.false;
  1231. });
  1232. });
  1233. describe('#updateFinalizeErrorCallback', function () {
  1234. it('should set isFinalizeItem to false', function () {
  1235. controller.set('isFinalizeItem', true);
  1236. controller.updateFinalizeErrorCallback();
  1237. expect(controller.get('isFinalizeItem')).to.be.false;
  1238. });
  1239. });
  1240. describe("#suspendUpgrade()", function() {
  1241. beforeEach(function () {
  1242. sinon.stub(controller, 'abortUpgrade').returns({
  1243. done: function (callback) {
  1244. callback();
  1245. }
  1246. });
  1247. sinon.stub(controller, 'setDBProperty', Em.K);
  1248. sinon.stub(App.clusterStatus, 'setClusterStatus', Em.K);
  1249. });
  1250. afterEach(function () {
  1251. controller.abortUpgrade.restore();
  1252. controller.setDBProperty.restore();
  1253. App.clusterStatus.setClusterStatus.restore();
  1254. });
  1255. it("", function() {
  1256. controller.suspendUpgrade();
  1257. expect(controller.abortUpgrade.calledOnce).to.be.true;
  1258. expect(App.get('upgradeState')).to.equal('ABORTED');
  1259. expect(controller.get('isSuspended')).to.be.true;
  1260. expect(controller.setDBProperty.calledWith('upgradeState', 'ABORTED')).to.be.true;
  1261. expect(controller.setDBProperty.calledWith('isSuspended', true)).to.be.true;
  1262. expect(App.clusterStatus.setClusterStatus.calledOnce).to.be.true;
  1263. });
  1264. });
  1265. describe("#resumeUpgrade()", function() {
  1266. beforeEach(function () {
  1267. sinon.stub(controller, 'retryUpgrade').returns({
  1268. done: function (callback) {
  1269. callback();
  1270. }
  1271. });
  1272. sinon.stub(controller, 'setDBProperty', Em.K);
  1273. sinon.stub(App.clusterStatus, 'setClusterStatus', Em.K);
  1274. });
  1275. afterEach(function () {
  1276. controller.retryUpgrade.restore();
  1277. controller.setDBProperty.restore();
  1278. App.clusterStatus.setClusterStatus.restore();
  1279. });
  1280. it("", function() {
  1281. controller.resumeUpgrade();
  1282. expect(controller.retryUpgrade.calledOnce).to.be.true;
  1283. expect(App.get('upgradeState')).to.equal('PENDING');
  1284. expect(controller.get('isSuspended')).to.be.false;
  1285. expect(controller.setDBProperty.calledWith('upgradeState', 'PENDING')).to.be.true;
  1286. expect(controller.setDBProperty.calledWith('isSuspended', false)).to.be.true;
  1287. expect(App.clusterStatus.setClusterStatus.calledOnce).to.be.true;
  1288. });
  1289. });
  1290. describe("#runUpgradeMethodChecks()", function() {
  1291. beforeEach(function () {
  1292. sinon.stub(controller, 'runPreUpgradeCheckOnly');
  1293. });
  1294. afterEach(function () {
  1295. controller.runPreUpgradeCheckOnly.restore();
  1296. controller.get('upgradeMethods').setEach('allowed', true);
  1297. });
  1298. it("no allowed upgrade methods", function () {
  1299. controller.get('upgradeMethods').setEach('allowed', false);
  1300. controller.runUpgradeMethodChecks();
  1301. expect(controller.runPreUpgradeCheckOnly.called).to.be.false;
  1302. });
  1303. it("Rolling method allowed", function () {
  1304. controller.get('upgradeMethods').setEach('allowed', true);
  1305. controller.runUpgradeMethodChecks(Em.Object.create({
  1306. repositoryVersion: 'v1',
  1307. displayName: 'V1'
  1308. }));
  1309. expect(controller.runPreUpgradeCheckOnly.calledWith({
  1310. value: 'v1',
  1311. label: 'V1',
  1312. type: 'ROLLING'
  1313. })).to.be.true;
  1314. });
  1315. });
  1316. describe("#restoreLastUpgrade()", function () {
  1317. beforeEach(function () {
  1318. sinon.stub(App.RepositoryVersion, 'find').returns([Em.Object.create({
  1319. repositoryVersion: '1',
  1320. displayName: 'HDP-1'
  1321. })]);
  1322. sinon.stub(controller, 'setDBProperties');
  1323. sinon.stub(controller, 'loadRepoVersionsToModel', function () {
  1324. return {
  1325. done: function (callback) {
  1326. callback();
  1327. }
  1328. }
  1329. });
  1330. sinon.stub(controller, 'setDBProperty');
  1331. sinon.stub(controller, 'initDBProperties');
  1332. sinon.stub(controller, 'loadUpgradeData');
  1333. });
  1334. afterEach(function () {
  1335. App.RepositoryVersion.find.restore();
  1336. controller.setDBProperties.restore();
  1337. controller.loadRepoVersionsToModel.restore();
  1338. controller.setDBProperty.restore();
  1339. controller.initDBProperties.restore();
  1340. controller.loadUpgradeData.restore();
  1341. });
  1342. it("", function () {
  1343. var data = {
  1344. Upgrade: {
  1345. request_id: 1,
  1346. direction: 'UPGRADE',
  1347. request_status: 'PENDING',
  1348. upgrade_type: 'ROLLING',
  1349. downgrade_allowed: true,
  1350. skip_failures: true,
  1351. skip_service_check_failures: true,
  1352. to_version: '1'
  1353. }
  1354. };
  1355. controller.restoreLastUpgrade(data);
  1356. expect(controller.setDBProperties.getCall(0).args[0]).to.eql({
  1357. upgradeId: 1,
  1358. isDowngrade: false,
  1359. upgradeState: 'PENDING',
  1360. upgradeType: "ROLLING",
  1361. downgradeAllowed: true,
  1362. upgradeTypeDisplayName: Em.I18n.t('admin.stackVersions.version.upgrade.upgradeOptions.RU.title'),
  1363. failuresTolerance: Em.Object.create({
  1364. skipComponentFailures: true,
  1365. skipSCFailures: true
  1366. })
  1367. });
  1368. expect(controller.loadRepoVersionsToModel.calledOnce).to.be.true;
  1369. expect(controller.setDBProperty.calledWith('upgradeVersion', 'HDP-1')).to.be.true;
  1370. expect(controller.initDBProperties.calledOnce).to.be.true;
  1371. expect(controller.loadUpgradeData.calledWith(true)).to.be.true;
  1372. });
  1373. });
  1374. });