stack_and_upgrade_controller_test.js 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431
  1. /**
  2. * Licensed to the Apache Software Foundation (ASF) under one
  3. * or more contributor license agreements. See the NOTICE file
  4. * distributed with this work for additional information
  5. * regarding copyright ownership. The ASF licenses this file
  6. * to you under the Apache License, Version 2.0 (the
  7. * "License"); you may not use this file except in compliance
  8. * with the License. You may obtain a copy of the License at
  9. *
  10. * http://www.apache.org/licenses/LICENSE-2.0
  11. *
  12. * Unless required by applicable law or agreed to in writing, software
  13. * distributed under the License is distributed on an "AS IS" BASIS,
  14. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  15. * See the License for the specific language governing permissions and
  16. * limitations under the License.
  17. */
  18. var App = require('app');
  19. require('controllers/main/admin/stack_and_upgrade_controller');
  20. describe('App.MainAdminStackAndUpgradeController', function() {
  21. var controller = App.MainAdminStackAndUpgradeController.create({
  22. getDBProperty: Em.K,
  23. setDBProperty: Em.K
  24. });
  25. describe("#loadUpgradeData()", function() {
  26. beforeEach(function () {
  27. sinon.stub(App.ajax, 'send').returns({
  28. then: Em.K
  29. });
  30. });
  31. afterEach(function () {
  32. App.ajax.send.restore();
  33. });
  34. it("get entire data", function() {
  35. controller.set('upgradeId', 1);
  36. controller.loadUpgradeData();
  37. expect(App.ajax.send.getCall(0).args[0]).to.eql({
  38. name: 'admin.upgrade.data',
  39. sender: controller,
  40. data: {
  41. id: 1
  42. },
  43. success: 'loadUpgradeDataSuccessCallback'
  44. })
  45. });
  46. it("get only state", function() {
  47. controller.set('upgradeId', 1);
  48. controller.loadUpgradeData(true);
  49. expect(App.ajax.send.getCall(0).args[0]).to.eql({
  50. name: 'admin.upgrade.state',
  51. sender: controller,
  52. data: {
  53. id: 1
  54. },
  55. success: 'loadUpgradeDataSuccessCallback'
  56. })
  57. });
  58. it("upgrade id is null", function() {
  59. controller.set('upgradeId', null);
  60. controller.loadUpgradeData();
  61. expect(App.ajax.send.called).to.be.false;
  62. });
  63. });
  64. describe("#loadUpgradeDataSuccessCallback()", function() {
  65. beforeEach(function () {
  66. sinon.stub(controller, 'updateUpgradeData', Em.K);
  67. });
  68. afterEach(function () {
  69. controller.updateUpgradeData.restore();
  70. });
  71. it("", function() {
  72. var data = {
  73. "Upgrade": {
  74. "request_status": "COMPLETED"
  75. },
  76. "upgrade_groups": [
  77. {
  78. "UpgradeGroup": {
  79. "id": 1
  80. },
  81. "upgrade_items": []
  82. }
  83. ]};
  84. controller.loadUpgradeDataSuccessCallback(data);
  85. expect(App.get('upgradeState')).to.equal('COMPLETED');
  86. expect(controller.updateUpgradeData.called).to.be.true;
  87. });
  88. });
  89. describe("#openUpgradeDialog()", function () {
  90. before(function () {
  91. sinon.stub(App.router, 'transitionTo', Em.K);
  92. });
  93. after(function () {
  94. App.router.transitionTo.restore();
  95. });
  96. it("should open dialog", function () {
  97. controller.openUpgradeDialog();
  98. expect(App.router.transitionTo.calledWith('admin.stackUpgrade')).to.be.true;
  99. });
  100. });
  101. describe("#runPreUpgradeCheck()", function() {
  102. before(function () {
  103. sinon.stub(App.ajax, 'send', Em.K);
  104. });
  105. after(function () {
  106. App.ajax.send.restore();
  107. });
  108. it("make ajax call", function() {
  109. controller.runPreUpgradeCheck(Em.Object.create({
  110. repositoryVersion: '2.2',
  111. displayName: 'HDP-2.2'
  112. }));
  113. expect(App.ajax.send.getCall(0).args[0]).to.eql({
  114. name: "admin.rolling_upgrade.pre_upgrade_check",
  115. sender: controller,
  116. data: {
  117. value: '2.2',
  118. label: 'HDP-2.2'
  119. },
  120. success: "runPreUpgradeCheckSuccess"
  121. });
  122. });
  123. });
  124. describe("#runPreUpgradeCheckSuccess()", function () {
  125. beforeEach(function () {
  126. sinon.stub(App, 'showClusterCheckPopup', Em.K);
  127. sinon.stub(controller, 'upgrade', Em.K);
  128. });
  129. afterEach(function () {
  130. App.showClusterCheckPopup.restore();
  131. controller.upgrade.restore();
  132. });
  133. it("shows popup", function () {
  134. var check = { items: [{
  135. UpgradeChecks: {
  136. "check": "Work-preserving RM/NM restart is enabled in YARN configs",
  137. "status": "FAIL",
  138. "reason": "FAIL",
  139. "failed_on": [],
  140. "check_type": "SERVICE"
  141. }
  142. }]};
  143. controller.runPreUpgradeCheckSuccess(check,null,{label: "name"});
  144. expect(controller.upgrade.called).to.be.false;
  145. expect(App.showClusterCheckPopup.called).to.be.true;
  146. });
  147. it("runs upgrade popup", function () {
  148. var check = { items: [{
  149. UpgradeChecks: {
  150. "check": "Work-preserving RM/NM restart is enabled in YARN configs",
  151. "status": "PASS",
  152. "reason": "OK",
  153. "failed_on": [],
  154. "check_type": "SERVICE"
  155. }
  156. }]};
  157. controller.runPreUpgradeCheckSuccess(check,null,{label: "name"});
  158. expect(controller.upgrade.called).to.be.true;
  159. expect(App.showClusterCheckPopup.called).to.be.false;
  160. });
  161. });
  162. describe("#initDBProperties()", function() {
  163. before(function () {
  164. sinon.stub(controller, 'getDBProperty', function (prop) {
  165. return prop;
  166. });
  167. });
  168. after(function () {
  169. controller.getDBProperty.restore();
  170. });
  171. it("set properties", function () {
  172. controller.set('wizardStorageProperties', ['prop1']);
  173. controller.initDBProperties();
  174. expect(controller.get('prop1')).to.equal('prop1');
  175. });
  176. });
  177. describe("#init()", function() {
  178. before(function () {
  179. sinon.stub(controller, 'initDBProperties', Em.K);
  180. });
  181. after(function () {
  182. controller.initDBProperties.restore();
  183. });
  184. it("call initDBProperties", function () {
  185. controller.init();
  186. expect(controller.initDBProperties.calledOnce).to.be.true;
  187. });
  188. });
  189. describe("#upgrade()", function() {
  190. before(function () {
  191. sinon.stub(App.ajax, 'send', Em.K);
  192. sinon.stub(controller, 'setDBProperty', Em.K);
  193. });
  194. after(function () {
  195. App.ajax.send.restore();
  196. controller.setDBProperty.restore();
  197. });
  198. it("make ajax call", function() {
  199. controller.set('currentVersion', {
  200. repository_version: '2.2'
  201. });
  202. controller.upgrade({
  203. value: '2.2',
  204. label: 'HDP-2.2'
  205. });
  206. expect(App.ajax.send.getCall(0).args[0]).to.eql({
  207. name: 'admin.upgrade.start',
  208. sender: controller,
  209. data: {
  210. value: '2.2',
  211. label: 'HDP-2.2'
  212. },
  213. success: 'upgradeSuccessCallback'
  214. });
  215. expect(controller.setDBProperty.calledWith('currentVersion', {
  216. repository_version: '2.2'
  217. })).to.be.true;
  218. });
  219. });
  220. describe("#upgradeSuccessCallback()", function() {
  221. before(function () {
  222. sinon.stub(App.clusterStatus, 'setClusterStatus', Em.K);
  223. sinon.stub(controller, 'openUpgradeDialog', Em.K);
  224. sinon.stub(controller, 'setDBProperty', Em.K);
  225. });
  226. after(function () {
  227. App.clusterStatus.setClusterStatus.restore();
  228. controller.openUpgradeDialog.restore();
  229. controller.setDBProperty.restore();
  230. });
  231. it("open upgrade dialog", function() {
  232. var data = {
  233. resources: [
  234. {
  235. Upgrade: {
  236. request_id: 1
  237. }
  238. }
  239. ]
  240. };
  241. controller.upgradeSuccessCallback(data, {}, {label: 'HDP-2.2.1'});
  242. expect(controller.setDBProperty.calledWith('upgradeId', 1)).to.be.true;
  243. expect(controller.setDBProperty.calledWith('upgradeVersion', 'HDP-2.2.1')).to.be.true;
  244. expect(controller.get('upgradeVersion')).to.equal('HDP-2.2.1');
  245. expect(App.clusterStatus.setClusterStatus.calledOnce).to.be.true;
  246. expect(controller.openUpgradeDialog.calledOnce).to.be.true;
  247. });
  248. });
  249. describe("#updateUpgradeData()", function() {
  250. beforeEach(function () {
  251. sinon.stub(controller, 'initUpgradeData', Em.K);
  252. });
  253. afterEach(function () {
  254. controller.initUpgradeData.restore();
  255. });
  256. it("data loaded first time", function() {
  257. controller.set('upgradeData', null);
  258. controller.updateUpgradeData({});
  259. expect(controller.initUpgradeData.calledWith({})).to.be.true;
  260. });
  261. it("update loaded data", function() {
  262. var oldData = Em.Object.create({
  263. upgradeGroups: [
  264. Em.Object.create({
  265. group_id: 1,
  266. upgradeItems: [
  267. Em.Object.create({
  268. stage_id: 1,
  269. tasks: [
  270. Em.Object.create({
  271. id: 1
  272. })
  273. ]
  274. })
  275. ]
  276. })
  277. ]
  278. });
  279. var newData = {
  280. Upgrade: {
  281. request_id: 1
  282. },
  283. upgrade_groups: [
  284. {
  285. UpgradeGroup: {
  286. group_id: 1,
  287. status: 'COMPLETED',
  288. progress_percent: 100
  289. },
  290. upgrade_items: [
  291. {
  292. UpgradeItem: {
  293. stage_id: 1,
  294. status: 'COMPLETED',
  295. progress_percent: 100
  296. },
  297. tasks: [
  298. {
  299. Tasks: {
  300. id: 1,
  301. status: 'COMPLETED'
  302. }
  303. }
  304. ]
  305. }
  306. ]
  307. }
  308. ]
  309. };
  310. controller.set('upgradeData', oldData);
  311. controller.updateUpgradeData(newData);
  312. expect(controller.get('upgradeData.upgradeGroups')[0].get('status')).to.equal('COMPLETED');
  313. expect(controller.get('upgradeData.upgradeGroups')[0].get('progress_percent')).to.equal(100);
  314. expect(controller.get('upgradeData.upgradeGroups')[0].get('upgradeItems')[0].get('status')).to.equal('COMPLETED');
  315. expect(controller.get('upgradeData.upgradeGroups')[0].get('upgradeItems')[0].get('progress_percent')).to.equal(100);
  316. expect(controller.get('upgradeData.upgradeGroups')[0].get('upgradeItems')[0].get('tasks')[0].get('status')).to.equal('COMPLETED');
  317. });
  318. });
  319. describe("#initUpgradeData()", function() {
  320. it("", function() {
  321. var newData = {
  322. Upgrade: {
  323. request_id: 1
  324. },
  325. upgrade_groups: [
  326. {
  327. UpgradeGroup: {
  328. group_id: 1
  329. },
  330. upgrade_items: [
  331. {
  332. UpgradeItem: {
  333. stage_id: 1
  334. },
  335. tasks: [
  336. {
  337. Tasks: {
  338. id: 1
  339. }
  340. }
  341. ]
  342. }
  343. ]
  344. }
  345. ]
  346. };
  347. controller.initUpgradeData(newData);
  348. expect(controller.get('upgradeData.Upgrade.request_id')).to.equal(1);
  349. expect(controller.get('upgradeData.upgradeGroups')[0].get('group_id')).to.equal(1);
  350. expect(controller.get('upgradeData.upgradeGroups')[0].get('upgradeItems')[0].get('stage_id')).to.equal(1);
  351. expect(controller.get('upgradeData.upgradeGroups')[0].get('upgradeItems')[0].get('tasks')[0].get('id')).to.equal(1);
  352. });
  353. });
  354. describe("#finish()", function() {
  355. before(function () {
  356. sinon.stub(App.clusterStatus, 'setClusterStatus', Em.K);
  357. sinon.stub(controller, 'setDBProperty', Em.K);
  358. });
  359. after(function () {
  360. App.clusterStatus.setClusterStatus.restore();
  361. controller.setDBProperty.restore();
  362. });
  363. it("reset upgrade info", function() {
  364. controller.finish();
  365. expect(controller.get('upgradeId')).to.be.null;
  366. expect(controller.setDBProperty.calledWith('upgradeId', undefined)).to.be.true;
  367. expect(App.get('upgradeState')).to.equal('INIT');
  368. expect(controller.get('upgradeVersion')).to.be.null;
  369. expect(controller.setDBProperty.calledWith('upgradeVersion', undefined)).to.be.true;
  370. expect(App.clusterStatus.setClusterStatus.calledOnce).to.be.true;
  371. });
  372. });
  373. describe("#confirmDowngrade()", function() {
  374. before(function () {
  375. sinon.stub(App, 'showConfirmationPopup', Em.K);
  376. });
  377. after(function () {
  378. App.showConfirmationPopup.restore();
  379. });
  380. it("show confirmation popup", function() {
  381. controller.set('currentVersion', Em.Object.create({
  382. repository_version: '2.2',
  383. repository_name: 'HDP-2.2'
  384. }));
  385. controller.confirmDowngrade();
  386. expect(App.showConfirmationPopup.calledOnce).to.be.true;
  387. });
  388. });
  389. describe("#downgrade()", function() {
  390. before(function () {
  391. sinon.stub(App.ajax, 'send', Em.K);
  392. });
  393. after(function () {
  394. App.ajax.send.restore();
  395. });
  396. it("make ajax call", function() {
  397. controller.downgrade(Em.Object.create({
  398. repository_version: '2.2',
  399. repository_name: 'HDP-2.2'
  400. }));
  401. expect(App.ajax.send.getCall(0).args[0]).to.eql({
  402. name: 'admin.downgrade.start',
  403. sender: controller,
  404. data: {
  405. value: '2.2',
  406. label: 'HDP-2.2'
  407. },
  408. success: 'upgradeSuccessCallback'
  409. });
  410. });
  411. });
  412. });