stack_and_upgrade_controller_test.js 15 KB

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