stack_and_upgrade_controller_test.js 42 KB

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