stack_and_upgrade_controller_test.js 45 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409
  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.upgradeMethods = [
  527. Em.Object.create({
  528. displayName: Em.I18n.t('admin.stackVersions.version.upgrade.upgradeOptions.RU.title'),
  529. type: 'ROLLING'
  530. }),
  531. Em.Object.create({
  532. displayName: Em.I18n.t('admin.stackVersions.version.upgrade.upgradeOptions.EU.title'),
  533. type: 'NON_ROLLING'
  534. })
  535. ];
  536. controller.upgradeSuccessCallback(data, {}, {label: 'HDP-2.2.1', isDowngrade: true});
  537. expect(controller.load.calledOnce).to.be.true;
  538. expect(controller.get('upgradeVersion')).to.equal('HDP-2.2.1');
  539. expect(controller.get('upgradeData')).to.be.null;
  540. expect(controller.get('isDowngrade')).to.be.true;
  541. expect(App.clusterStatus.setClusterStatus.calledOnce).to.be.true;
  542. expect(controller.openUpgradeDialog.calledOnce).to.be.true;
  543. });
  544. });
  545. describe("#updateUpgradeData()", function() {
  546. beforeEach(function () {
  547. sinon.stub(controller, 'initUpgradeData', Em.K);
  548. });
  549. afterEach(function () {
  550. controller.initUpgradeData.restore();
  551. });
  552. it("data loaded first time", function() {
  553. controller.set('upgradeData', null);
  554. controller.updateUpgradeData({});
  555. expect(controller.initUpgradeData.calledWith({})).to.be.true;
  556. });
  557. it("update loaded data", function() {
  558. var oldData = Em.Object.create({
  559. upgradeGroups: [
  560. Em.Object.create({
  561. group_id: 1,
  562. upgradeItems: [
  563. Em.Object.create({
  564. stage_id: 1
  565. })
  566. ]
  567. }),
  568. Em.Object.create({
  569. group_id: 2,
  570. upgradeItems: [
  571. Em.Object.create({
  572. stage_id: 2
  573. }),
  574. Em.Object.create({
  575. stage_id: 3
  576. })
  577. ]
  578. })
  579. ]
  580. });
  581. var newData = {
  582. Upgrade: {
  583. request_id: 1
  584. },
  585. upgrade_groups: [
  586. {
  587. UpgradeGroup: {
  588. group_id: 1,
  589. status: 'COMPLETED',
  590. progress_percent: 100,
  591. completed_task_count: 3
  592. },
  593. upgrade_items: [
  594. {
  595. UpgradeItem: {
  596. stage_id: 1,
  597. status: 'COMPLETED',
  598. progress_percent: 100
  599. }
  600. }
  601. ]
  602. },
  603. {
  604. UpgradeGroup: {
  605. group_id: 2,
  606. status: 'ABORTED',
  607. progress_percent: 50,
  608. completed_task_count: 1
  609. },
  610. upgrade_items: [
  611. {
  612. UpgradeItem: {
  613. stage_id: 2,
  614. status: 'ABORTED',
  615. progress_percent: 99
  616. }
  617. },
  618. {
  619. UpgradeItem: {
  620. stage_id: 3,
  621. status: 'PENDING',
  622. progress_percent: 0
  623. }
  624. }
  625. ]
  626. }
  627. ]
  628. };
  629. controller.set('upgradeData', oldData);
  630. controller.updateUpgradeData(newData);
  631. expect(controller.get('upgradeData.upgradeGroups')[0].get('status')).to.equal('COMPLETED');
  632. expect(controller.get('upgradeData.upgradeGroups')[0].get('progress_percent')).to.equal(100);
  633. expect(controller.get('upgradeData.upgradeGroups')[0].get('completed_task_count')).to.equal(3);
  634. expect(controller.get('upgradeData.upgradeGroups')[0].get('upgradeItems')[0].get('status')).to.equal('COMPLETED');
  635. expect(controller.get('upgradeData.upgradeGroups')[0].get('upgradeItems')[0].get('progress_percent')).to.equal(100);
  636. expect(controller.get('upgradeData.upgradeGroups')[0].get('hasExpandableItems')).to.be.true;
  637. expect(controller.get('upgradeData.upgradeGroups')[1].get('status')).to.equal('ABORTED');
  638. expect(controller.get('upgradeData.upgradeGroups')[1].get('progress_percent')).to.equal(50);
  639. expect(controller.get('upgradeData.upgradeGroups')[1].get('completed_task_count')).to.equal(1);
  640. expect(controller.get('upgradeData.upgradeGroups')[1].get('upgradeItems')[0].get('status')).to.equal('ABORTED');
  641. expect(controller.get('upgradeData.upgradeGroups')[1].get('upgradeItems')[1].get('status')).to.equal('PENDING');
  642. expect(controller.get('upgradeData.upgradeGroups')[1].get('upgradeItems')[0].get('progress_percent')).to.equal(99);
  643. expect(controller.get('upgradeData.upgradeGroups')[1].get('upgradeItems')[1].get('progress_percent')).to.equal(0);
  644. expect(controller.get('upgradeData.upgradeGroups')[1].get('hasExpandableItems')).to.be.false;
  645. });
  646. });
  647. describe("#initUpgradeData()", function() {
  648. beforeEach(function () {
  649. sinon.stub(controller, 'setDBProperty');
  650. });
  651. afterEach(function () {
  652. controller.setDBProperty.restore();
  653. });
  654. it("", function() {
  655. var newData = {
  656. Upgrade: {
  657. request_id: 1,
  658. downgrade_allowed: false
  659. },
  660. upgrade_groups: [
  661. {
  662. UpgradeGroup: {
  663. group_id: 1
  664. },
  665. upgrade_items: [
  666. {
  667. UpgradeItem: {
  668. stage_id: 1,
  669. status: 'IN_PROGRESS'
  670. }
  671. },
  672. {
  673. UpgradeItem: {
  674. stage_id: 2
  675. }
  676. }
  677. ]
  678. },
  679. {
  680. UpgradeGroup: {
  681. group_id: 2
  682. },
  683. upgrade_items: []
  684. },
  685. {
  686. UpgradeGroup: {
  687. group_id: 3
  688. },
  689. upgrade_items: [
  690. {
  691. UpgradeItem: {
  692. stage_id: 3,
  693. status: 'ABORTED'
  694. }
  695. },
  696. {
  697. UpgradeItem: {
  698. stage_id: 4,
  699. status: 'PENDING'
  700. }
  701. }
  702. ]
  703. }
  704. ]
  705. };
  706. controller.initUpgradeData(newData);
  707. expect(controller.setDBProperty.calledWith('downgradeAllowed', false)).to.be.true;
  708. expect(controller.get('downgradeAllowed')).to.be.false;
  709. expect(controller.get('upgradeData.Upgrade.request_id')).to.equal(1);
  710. expect(controller.get('upgradeData.upgradeGroups')[0].get('group_id')).to.equal(3);
  711. expect(controller.get('upgradeData.upgradeGroups')[1].get('group_id')).to.equal(2);
  712. expect(controller.get('upgradeData.upgradeGroups')[2].get('group_id')).to.equal(1);
  713. expect(controller.get('upgradeData.upgradeGroups')[2].get('upgradeItems')[0].get('stage_id')).to.equal(2);
  714. expect(controller.get('upgradeData.upgradeGroups')[2].get('upgradeItems')[1].get('stage_id')).to.equal(1);
  715. expect(controller.get('upgradeData.upgradeGroups')[0].get('hasExpandableItems')).to.be.false;
  716. expect(controller.get('upgradeData.upgradeGroups')[1].get('hasExpandableItems')).to.be.false;
  717. expect(controller.get('upgradeData.upgradeGroups')[2].get('hasExpandableItems')).to.be.true;
  718. });
  719. });
  720. describe.skip("#finish()", function() {
  721. before(function () {
  722. sinon.stub(App.clusterStatus, 'setClusterStatus', Em.K);
  723. sinon.stub(controller, 'setDBProperty', Em.K);
  724. });
  725. after(function () {
  726. App.clusterStatus.setClusterStatus.restore();
  727. controller.setDBProperty.restore();
  728. });
  729. it("upgradeState is not COMPLETED", function() {
  730. App.set('upgradeState', 'UPGRADING');
  731. controller.finish();
  732. expect(App.clusterStatus.setClusterStatus.called).to.be.false;
  733. });
  734. it("upgradeState is COMPLETED", function() {
  735. App.set('upgradeState', 'COMPLETED');
  736. controller.finish();
  737. expect(controller.setDBProperty.calledWith('upgradeId', undefined)).to.be.true;
  738. expect(controller.setDBProperty.calledWith('upgradeVersion', undefined)).to.be.true;
  739. expect(controller.setDBProperty.calledWith('upgradeState', 'INIT')).to.be.true;
  740. expect(controller.setDBProperty.calledWith('currentVersion', undefined)).to.be.true;
  741. expect(App.get('upgradeState')).to.equal('INIT');
  742. expect(App.clusterStatus.setClusterStatus.calledOnce).to.be.true;
  743. });
  744. });
  745. describe("#confirmDowngrade()", function() {
  746. before(function () {
  747. sinon.spy(App, 'showConfirmationPopup');
  748. sinon.stub(controller, 'downgrade', Em.K);
  749. });
  750. after(function () {
  751. App.showConfirmationPopup.restore();
  752. controller.downgrade.restore();
  753. });
  754. it("show confirmation popup", function() {
  755. controller.set('currentVersion', Em.Object.create({
  756. repository_version: '2.2',
  757. repository_name: 'HDP-2.2'
  758. }));
  759. var popup = controller.confirmDowngrade();
  760. expect(App.showConfirmationPopup.calledOnce).to.be.true;
  761. popup.onPrimary();
  762. expect(controller.downgrade.calledWith(Em.Object.create({
  763. repository_version: '2.2',
  764. repository_name: 'HDP-2.2'
  765. }))).to.be.true;
  766. });
  767. });
  768. describe("#upgradeOptions()", function() {
  769. before(function () {
  770. sinon.spy(App, 'ModalPopup');
  771. sinon.spy(App, 'showConfirmationFeedBackPopup');
  772. this.mock = sinon.stub(controller, 'getSupportedUpgradeTypes');
  773. sinon.stub(controller, 'runPreUpgradeCheck', Em.K);
  774. });
  775. after(function () {
  776. App.ModalPopup.restore();
  777. App.showConfirmationFeedBackPopup.restore();
  778. controller.runPreUpgradeCheck.restore();
  779. this.mock.restore();
  780. });
  781. it("show confirmation popup", function() {
  782. var version = Em.Object.create({displayName: 'HDP-2.2'});
  783. this.mock.returns({
  784. done: function(callback) {callback([1]);}
  785. });
  786. controller.upgradeMethods = [
  787. Em.Object.create({
  788. displayName: Em.I18n.t('admin.stackVersions.version.upgrade.upgradeOptions.RU.title'),
  789. type: 'ROLLING',
  790. icon: "icon-dashboard",
  791. description: Em.I18n.t('admin.stackVersions.version.upgrade.upgradeOptions.RU.description'),
  792. selected: true,
  793. allowed: true
  794. }),
  795. Em.Object.create({
  796. displayName: Em.I18n.t('admin.stackVersions.version.upgrade.upgradeOptions.EU.title'),
  797. type: 'NON_ROLLING',
  798. icon: "icon-bolt",
  799. description: Em.I18n.t('admin.stackVersions.version.upgrade.upgradeOptions.EU.description'),
  800. selected: false,
  801. allowed: true
  802. })
  803. ];
  804. controller.set('isDowngrade', false);
  805. var popup = controller.upgradeOptions(false, version);
  806. expect(App.ModalPopup.calledOnce).to.be.true;
  807. var confirmPopup = popup.onPrimary();
  808. expect(App.showConfirmationFeedBackPopup.calledOnce).to.be.true;
  809. confirmPopup.onPrimary();
  810. expect(controller.runPreUpgradeCheck.calledWith(version)).to.be.true;
  811. });
  812. it("NOT show confirmation popup on Downgrade", function() {
  813. var version = Em.Object.create({displayName: 'HDP-2.2'});
  814. this.mock.returns({
  815. done: function(callback) {callback([1]);}
  816. });
  817. controller.set('isDowngrade', true);
  818. var popup = controller.upgradeOptions(false, version);
  819. expect(App.ModalPopup.calledOnce).to.be.false;
  820. });
  821. });
  822. describe("#confirmUpgrade()", function() {
  823. before(function () {
  824. sinon.stub(controller, 'upgradeOptions', Em.K);
  825. });
  826. after(function () {
  827. controller.upgradeOptions.restore();
  828. });
  829. it("show show upgrade options popup window", function() {
  830. var version = Em.Object.create({displayName: 'HDP-2.2'});
  831. controller.confirmUpgrade(version);
  832. expect(controller.upgradeOptions.calledWith(false, version)).to.be.true;
  833. });
  834. });
  835. describe("#downgrade()", function() {
  836. before(function () {
  837. sinon.stub(App.ajax, 'send', Em.K);
  838. sinon.stub(controller, 'abortUpgrade');
  839. sinon.stub(App.RepositoryVersion, 'find').returns([
  840. Em.Object.create({
  841. displayName: 'HDP-2.3',
  842. repositoryVersion: '2.3'
  843. })
  844. ]);
  845. });
  846. after(function () {
  847. App.ajax.send.restore();
  848. controller.abortUpgrade.restore();
  849. App.RepositoryVersion.find.restore();
  850. });
  851. it("make ajax call", function() {
  852. controller.set('upgradeVersion', 'HDP-2.3');
  853. controller.set('upgradeType', 'NON_ROLLING');
  854. controller.downgrade(Em.Object.create({
  855. repository_version: '2.2',
  856. repository_name: 'HDP-2.2'
  857. }), {context: 'context'});
  858. expect(controller.abortUpgrade.calledOnce).to.be.true;
  859. expect(App.ajax.send.getCall(0).args[0].data).to.eql({
  860. from: '2.3',
  861. value: '2.2',
  862. label: 'HDP-2.2',
  863. isDowngrade: true,
  864. upgradeType: "NON_ROLLING"
  865. });
  866. expect(App.ajax.send.getCall(0).args[0].name).to.eql('admin.downgrade.start');
  867. expect(App.ajax.send.getCall(0).args[0].sender).to.eql(controller);
  868. expect(App.ajax.send.getCall(0).args[0].success).to.eql('upgradeSuccessCallback');
  869. expect(App.ajax.send.getCall(0).args[0].callback).to.be.called;
  870. });
  871. });
  872. describe("#installRepoVersionConfirmation()", function () {
  873. before(function () {
  874. sinon.stub(controller, 'installRepoVersion', Em.K);
  875. });
  876. after(function () {
  877. controller.installRepoVersion.restore();
  878. });
  879. it("show popup", function () {
  880. var repo = Em.Object.create({'displayName': 'HDP-2.2'});
  881. var popup = controller.installRepoVersionConfirmation(repo);
  882. popup.onPrimary();
  883. expect(controller.installRepoVersion.calledWith(repo)).to.be.true;
  884. });
  885. });
  886. describe("#installRepoVersion()", function () {
  887. before(function () {
  888. sinon.stub(App.ajax, 'send', Em.K);
  889. });
  890. after(function () {
  891. App.ajax.send.restore();
  892. });
  893. it("make ajax call", function () {
  894. var repo = Em.Object.create({
  895. stackVersionType: 'HDP',
  896. stackVersionNumber: '2.2',
  897. repositoryVersion: '2.2.1',
  898. repoId: 1
  899. });
  900. controller.installRepoVersion(repo);
  901. expect(App.ajax.send.calledOnce).to.be.true;
  902. });
  903. });
  904. describe("#installRepoVersionSuccess()", function() {
  905. var mock = Em.Object.create({
  906. id: 1,
  907. defaultStatus: 'INIT',
  908. stackVersion: {}
  909. });
  910. before(function () {
  911. sinon.spy(mock, 'set');
  912. sinon.stub(App.db, 'set', Em.K);
  913. sinon.stub(App.clusterStatus, 'setClusterStatus', Em.K);
  914. sinon.stub(App.RepositoryVersion, 'find').returns(mock);
  915. });
  916. after(function () {
  917. App.db.set.restore();
  918. App.clusterStatus.setClusterStatus.restore();
  919. App.RepositoryVersion.find.restore();
  920. });
  921. it("", function() {
  922. controller.installRepoVersionSuccess({Requests: {id: 1}}, {}, {id: 1});
  923. expect(App.db.set.calledWith('repoVersionInstall', 'id', [1])).to.be.true;
  924. expect(App.clusterStatus.setClusterStatus.calledOnce).to.be.true;
  925. expect(App.RepositoryVersion.find.calledWith(1)).to.be.true;
  926. expect(App.RepositoryVersion.find(1).get('defaultStatus')).to.equal('INSTALLING');
  927. expect(App.RepositoryVersion.find(1).get('stackVersion.state')).to.equal('INSTALLING');
  928. });
  929. });
  930. describe("#setUpgradeItemStatus()", function () {
  931. before(function () {
  932. sinon.stub(App.ajax, 'send', function () {
  933. return {
  934. done: function (callback) {
  935. callback();
  936. }
  937. }
  938. });
  939. });
  940. after(function () {
  941. App.ajax.send.restore();
  942. });
  943. it("", function () {
  944. var item = Em.Object.create({
  945. request_id: 1,
  946. stage_id: 1,
  947. group_id: 1
  948. });
  949. controller.setUpgradeItemStatus(item, 'PENDING');
  950. expect(App.ajax.send.getCall(0).args[0].data).to.eql({upgradeId: 1, itemId: 1, groupId: 1, status: 'PENDING'});
  951. expect(App.ajax.send.getCall(0).args[0].name).to.eql('admin.upgrade.upgradeItem.setState');
  952. expect(App.ajax.send.getCall(0).args[0].sender).to.eql(controller);
  953. expect(App.ajax.send.getCall(0).args[0].callback).to.be.called;
  954. expect(item.get('status')).to.equal('PENDING');
  955. });
  956. });
  957. describe("#prepareRepoForSaving()", function () {
  958. it("prepare date for saving", function () {
  959. var repo = Em.Object.create({
  960. operatingSystems: [
  961. Em.Object.create({
  962. osType: "redhat6",
  963. isDisabled: Ember.computed.not('isSelected'),
  964. repositories: [Em.Object.create({
  965. "baseUrl": "111121",
  966. "repoId": "HDP-2.2",
  967. "repoName": "HDP",
  968. hasError: false
  969. }),
  970. Em.Object.create({
  971. "baseUrl": "1",
  972. "repoId": "HDP-UTILS-1.1.0.20",
  973. "repoName": "HDP-UTILS",
  974. hasError: false
  975. })]
  976. })
  977. ]
  978. });
  979. var result = {
  980. "operating_systems": [
  981. {
  982. "OperatingSystems": {
  983. "os_type": "redhat6"
  984. },
  985. "repositories": [
  986. {
  987. "Repositories": {
  988. "base_url": "111121",
  989. "repo_id": "HDP-2.2",
  990. "repo_name": "HDP"
  991. }
  992. },
  993. {
  994. "Repositories": {
  995. "base_url": "1",
  996. "repo_id": "HDP-UTILS-1.1.0.20",
  997. "repo_name": "HDP-UTILS"
  998. }
  999. }
  1000. ]
  1001. }
  1002. ]};
  1003. expect(controller.prepareRepoForSaving(repo)).to.eql(result);
  1004. });
  1005. });
  1006. describe("#getStackVersionNumber()", function(){
  1007. it("get stack version number", function(){
  1008. var repo = Em.Object.create({
  1009. "stackVersionType": 'HDP',
  1010. "stackVersion": '2.3',
  1011. "repositoryVersion": '2.2.1'
  1012. });
  1013. var stackVersion = controller.getStackVersionNumber(repo);
  1014. expect(stackVersion).to.equal('2.3');
  1015. });
  1016. it("get default stack version number", function(){
  1017. App.set('currentStackVersion', '1.2.3');
  1018. var repo = Em.Object.create({
  1019. "stackVersionType": 'HDP',
  1020. "repositoryVersion": '2.2.1'
  1021. });
  1022. var stackVersion = controller.getStackVersionNumber(repo);
  1023. expect(stackVersion).to.equal('1.2.3');
  1024. });
  1025. });
  1026. describe("#saveRepoOS()", function() {
  1027. before(function(){
  1028. this.mock = sinon.stub(controller, 'validateRepoVersions');
  1029. sinon.stub(controller, 'prepareRepoForSaving', Em.K);
  1030. sinon.stub(App.ajax, 'send').returns({success: Em.K});
  1031. });
  1032. after(function(){
  1033. this.mock.restore();
  1034. controller.prepareRepoForSaving.restore();
  1035. App.ajax.send.restore();
  1036. });
  1037. it("validation errors present", function() {
  1038. this.mock.returns({
  1039. done: function(callback) {callback([1]);}
  1040. });
  1041. controller.saveRepoOS(Em.Object.create({repoVersionId: 1}), true);
  1042. expect(controller.validateRepoVersions.calledWith(Em.Object.create({repoVersionId: 1}), true)).to.be.true;
  1043. expect(controller.prepareRepoForSaving.called).to.be.false;
  1044. expect(App.ajax.send.called).to.be.false;
  1045. });
  1046. it("no validation errors", function() {
  1047. this.mock.returns({
  1048. done: function(callback) {callback([]);}
  1049. });
  1050. controller.saveRepoOS(Em.Object.create({repoVersionId: 1}), true);
  1051. expect(controller.validateRepoVersions.calledWith(Em.Object.create({repoVersionId: 1}), true)).to.be.true;
  1052. expect(controller.prepareRepoForSaving.calledWith(Em.Object.create({repoVersionId: 1}))).to.be.true;
  1053. expect(App.ajax.send.calledOnce).to.be.true;
  1054. });
  1055. });
  1056. describe("#validateRepoVersions()", function () {
  1057. before(function () {
  1058. sinon.stub(App.ajax, 'send').returns({success: Em.K, error: Em.K});
  1059. });
  1060. after(function () {
  1061. App.ajax.send.restore();
  1062. });
  1063. it("skip validation", function () {
  1064. controller.validateRepoVersions(Em.Object.create({repoVersionId: 1}), true);
  1065. expect(App.ajax.send.called).to.be.false;
  1066. });
  1067. it("do validation", function () {
  1068. var repo = Em.Object.create({
  1069. repoVersionId: 1,
  1070. operatingSystems: [
  1071. Em.Object.create({
  1072. isSelected: true,
  1073. repositories: [
  1074. Em.Object.create()
  1075. ]
  1076. })
  1077. ]
  1078. });
  1079. controller.validateRepoVersions(repo, false);
  1080. expect(App.ajax.send.calledOnce).to.be.true;
  1081. });
  1082. });
  1083. describe("#showProgressPopup()", function () {
  1084. var mock = {
  1085. initPopup: Em.K
  1086. };
  1087. before(function () {
  1088. sinon.stub(App.router, 'get').withArgs('highAvailabilityProgressPopupController').returns(mock);
  1089. sinon.spy(mock, 'initPopup');
  1090. });
  1091. after(function () {
  1092. App.router.get.restore();
  1093. mock.initPopup.restore();
  1094. });
  1095. it("", function () {
  1096. controller.showProgressPopup(Em.Object.create());
  1097. expect(mock.initPopup.calledOnce).to.be.true;
  1098. });
  1099. });
  1100. describe("#getUrl()", function() {
  1101. beforeEach(function(){
  1102. controller.reopen({
  1103. realStackUrl: 'realStackUrl',
  1104. realRepoUrl: 'realRepoUrl',
  1105. realUpdateUrl: 'realUpdateUrl'
  1106. });
  1107. });
  1108. it("full load is true, stack is null", function() {
  1109. expect(controller.getUrl(null, true)).to.equal('realRepoUrl');
  1110. });
  1111. it("full load is true, stack is valid", function() {
  1112. expect(controller.getUrl({}, true)).to.equal('realStackUrl');
  1113. });
  1114. it("full load is false, stack is valid", function() {
  1115. expect(controller.getUrl({}, false)).to.equal('realUpdateUrl');
  1116. });
  1117. });
  1118. describe("#loadStackVersionsToModel()", function () {
  1119. before(function () {
  1120. sinon.stub(App.HttpClient, 'get');
  1121. });
  1122. after(function () {
  1123. App.HttpClient.get.restore();
  1124. });
  1125. it("", function () {
  1126. controller.loadStackVersionsToModel();
  1127. expect(App.HttpClient.get.calledOnce).to.be.true;
  1128. });
  1129. });
  1130. describe("#loadRepoVersionsToModel()", function () {
  1131. before(function () {
  1132. sinon.stub(App.HttpClient, 'get');
  1133. });
  1134. after(function () {
  1135. App.HttpClient.get.restore();
  1136. });
  1137. it("", function () {
  1138. controller.loadRepoVersionsToModel();
  1139. expect(App.HttpClient.get.calledOnce).to.be.true;
  1140. });
  1141. });
  1142. describe('#currentVersionObserver()', function () {
  1143. var cases = [
  1144. {
  1145. stackVersionType: 'HDP',
  1146. repoVersion: '2.2.1.1.0-1',
  1147. isStormMetricsSupported: false,
  1148. title: 'HDP < 2.2.2'
  1149. },
  1150. {
  1151. stackVersionType: 'HDP',
  1152. repoVersion: '2.2.2.1.0-1',
  1153. isStormMetricsSupported: true,
  1154. title: 'HDP 2.2.2'
  1155. },
  1156. {
  1157. stackVersionType: 'HDP',
  1158. repoVersion: '2.2.3.1.0-1',
  1159. isStormMetricsSupported: true,
  1160. title: 'HDP > 2.2.2'
  1161. },
  1162. {
  1163. stackVersionType: 'BIGTOP',
  1164. repoVersion: '0.8.1.1.0-1',
  1165. isStormMetricsSupported: true,
  1166. title: 'not HDP'
  1167. }
  1168. ];
  1169. afterEach(function () {
  1170. App.RepositoryVersion.find.restore();
  1171. });
  1172. cases.forEach(function (item) {
  1173. it(item.title, function () {
  1174. sinon.stub(App.RepositoryVersion, 'find').returns([
  1175. Em.Object.create({
  1176. status: 'CURRENT',
  1177. stackVersionType: item.stackVersionType
  1178. })
  1179. ]);
  1180. controller.set('currentVersion', {
  1181. repository_version: item.repoVersion
  1182. });
  1183. expect(App.get('isStormMetricsSupported')).to.equal(item.isStormMetricsSupported);
  1184. });
  1185. });
  1186. });
  1187. describe('#updateFinalize', function () {
  1188. beforeEach(function() {
  1189. sinon.stub($, 'ajax', Em.K);
  1190. controller.set('isFinalizeItem', true);
  1191. });
  1192. afterEach(function () {
  1193. $.ajax.restore();
  1194. });
  1195. it('should do ajax-request', function () {
  1196. sinon.stub(App, 'get').withArgs('upgradeState').returns('HOLDING');
  1197. controller.updateFinalize();
  1198. App.get.restore();
  1199. expect($.ajax.calledOnce).to.be.true;
  1200. });
  1201. it('shouldn\'t do ajax-request', function () {
  1202. sinon.stub(App, 'get').withArgs('upgradeState').returns('HOLDING_TIMEDOUT');
  1203. controller.updateFinalize();
  1204. App.get.restore();
  1205. expect(controller.get('isFinalizeItem')).to.be.false;
  1206. expect($.ajax.calledOnce).to.be.false;
  1207. });
  1208. });
  1209. describe('#updateFinalizeSuccessCallback', function () {
  1210. it('data exists and Finalize should be true', function() {
  1211. var data = {
  1212. items: [
  1213. {
  1214. upgrade_groups: [
  1215. {
  1216. upgrade_items: [
  1217. {
  1218. UpgradeItem: {
  1219. context: controller.get('finalizeContext'),
  1220. status: "HOLDING"
  1221. }
  1222. }
  1223. ]
  1224. }
  1225. ]
  1226. }
  1227. ]
  1228. };
  1229. controller.set('isFinalizeItem', false);
  1230. controller.updateFinalizeSuccessCallback(data);
  1231. expect(controller.get('isFinalizeItem')).to.be.true;
  1232. });
  1233. it('data exists and Finalize should be false', function() {
  1234. var data = {
  1235. upgrade_groups: [
  1236. {
  1237. upgrade_items: [
  1238. {
  1239. UpgradeItem: {
  1240. context: '!@#$%^&',
  1241. status: "HOLDING"
  1242. }
  1243. }
  1244. ]
  1245. }
  1246. ]
  1247. };
  1248. controller.set('isFinalizeItem', true);
  1249. controller.updateFinalizeSuccessCallback(data);
  1250. expect(controller.get('isFinalizeItem')).to.be.false;
  1251. });
  1252. it('data doesn\'t exist', function() {
  1253. var data = null;
  1254. controller.set('isFinalizeItem', true);
  1255. controller.updateFinalizeSuccessCallback(data);
  1256. expect(controller.get('isFinalizeItem')).to.be.false;
  1257. });
  1258. });
  1259. describe('#updateFinalizeErrorCallback', function () {
  1260. it('should set isFinalizeItem to false', function () {
  1261. controller.set('isFinalizeItem', true);
  1262. controller.updateFinalizeErrorCallback();
  1263. expect(controller.get('isFinalizeItem')).to.be.false;
  1264. });
  1265. });
  1266. describe("#suspendUpgrade()", function() {
  1267. beforeEach(function () {
  1268. sinon.stub(controller, 'abortUpgrade').returns({
  1269. done: function (callback) {
  1270. callback();
  1271. }
  1272. });
  1273. sinon.stub(controller, 'setDBProperty', Em.K);
  1274. sinon.stub(App.clusterStatus, 'setClusterStatus', Em.K);
  1275. });
  1276. afterEach(function () {
  1277. controller.abortUpgrade.restore();
  1278. controller.setDBProperty.restore();
  1279. App.clusterStatus.setClusterStatus.restore();
  1280. });
  1281. it("", function() {
  1282. controller.suspendUpgrade();
  1283. expect(controller.abortUpgrade.calledOnce).to.be.true;
  1284. expect(App.get('upgradeState')).to.equal('ABORTED');
  1285. expect(controller.get('isSuspended')).to.be.true;
  1286. expect(controller.setDBProperty.calledWith('upgradeState', 'ABORTED')).to.be.true;
  1287. expect(controller.setDBProperty.calledWith('isSuspended', true)).to.be.true;
  1288. expect(App.clusterStatus.setClusterStatus.calledOnce).to.be.true;
  1289. });
  1290. });
  1291. describe("#resumeUpgrade()", function() {
  1292. beforeEach(function () {
  1293. sinon.stub(controller, 'retryUpgrade').returns({
  1294. done: function (callback) {
  1295. callback();
  1296. }
  1297. });
  1298. sinon.stub(controller, 'setDBProperty', Em.K);
  1299. sinon.stub(App.clusterStatus, 'setClusterStatus', Em.K);
  1300. });
  1301. afterEach(function () {
  1302. controller.retryUpgrade.restore();
  1303. controller.setDBProperty.restore();
  1304. App.clusterStatus.setClusterStatus.restore();
  1305. });
  1306. it("", function() {
  1307. controller.resumeUpgrade();
  1308. expect(controller.retryUpgrade.calledOnce).to.be.true;
  1309. expect(App.get('upgradeState')).to.equal('PENDING');
  1310. expect(controller.get('isSuspended')).to.be.false;
  1311. expect(controller.setDBProperty.calledWith('upgradeState', 'PENDING')).to.be.true;
  1312. expect(controller.setDBProperty.calledWith('isSuspended', false)).to.be.true;
  1313. expect(App.clusterStatus.setClusterStatus.calledOnce).to.be.true;
  1314. });
  1315. });
  1316. describe("#runUpgradeMethodChecks()", function() {
  1317. beforeEach(function () {
  1318. sinon.stub(controller, 'runPreUpgradeCheckOnly');
  1319. });
  1320. afterEach(function () {
  1321. controller.runPreUpgradeCheckOnly.restore();
  1322. });
  1323. it("no allowed upgrade methods", function () {
  1324. controller.set('upgradeMethods', [Em.Object.create({
  1325. allowed: false
  1326. })]);
  1327. controller.runUpgradeMethodChecks();
  1328. expect(controller.runPreUpgradeCheckOnly.called).to.be.false;
  1329. });
  1330. it("Rolling method allowed", function () {
  1331. controller.set('upgradeMethods', [Em.Object.create({
  1332. allowed: true,
  1333. type: 'ROLLING'
  1334. })]);
  1335. controller.runUpgradeMethodChecks(Em.Object.create({
  1336. repositoryVersion: 'v1',
  1337. displayName: 'V1'
  1338. }));
  1339. expect(controller.runPreUpgradeCheckOnly.calledWith({
  1340. value: 'v1',
  1341. label: 'V1',
  1342. type: 'ROLLING'
  1343. })).to.be.true;
  1344. });
  1345. });
  1346. });