12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343 |
- /**
- * Licensed to the Apache Software Foundation (ASF) under one
- * or more contributor license agreements. See the NOTICE file
- * distributed with this work for additional information
- * regarding copyright ownership. The ASF licenses this file
- * to you under the Apache License, Version 2.0 (the
- * "License"); you may not use this file except in compliance
- * with the License. You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
- var App = require('app');
- require('controllers/main/admin/stack_and_upgrade_controller');
- require('utils/string_utils');
- describe('App.MainAdminStackAndUpgradeController', function() {
- var controller = App.MainAdminStackAndUpgradeController.create({
- getDBProperty: Em.K,
- setDBProperty: Em.K
- });
- describe("#realRepoUrl", function() {
- before(function () {
- this.mock = sinon.stub(App, 'get');
- });
- after(function () {
- this.mock.restore();
- });
- it("", function() {
- this.mock.withArgs('apiPrefix').returns('apiPrefix');
- this.mock.withArgs('stackVersionURL').returns('stackVersionURL');
- controller.propertyDidChange('realRepoUrl');
- expect(controller.get('realRepoUrl')).to.equal('apiPrefixstackVersionURL/compatible_repository_versions?fields=*,operating_systems/*,operating_systems/repositories/*');
- });
- });
- describe("#realStackUrl", function() {
- before(function () {
- this.mock = sinon.stub(App, 'get');
- });
- after(function () {
- this.mock.restore();
- });
- it("", function() {
- this.mock.withArgs('apiPrefix').returns('apiPrefix');
- this.mock.withArgs('clusterName').returns('clusterName');
- controller.propertyDidChange('realStackUrl');
- expect(controller.get('realStackUrl')).to.equal('apiPrefix/clusters/clusterName/stack_versions?fields=*,repository_versions/*,repository_versions/operating_systems/repositories/*');
- });
- });
- describe("#realUpdateUrl", function() {
- before(function () {
- this.mock = sinon.stub(App, 'get');
- });
- after(function () {
- this.mock.restore();
- });
- it("", function() {
- this.mock.withArgs('apiPrefix').returns('apiPrefix');
- this.mock.withArgs('clusterName').returns('clusterName');
- controller.propertyDidChange('realUpdateUrl');
- expect(controller.get('realUpdateUrl')).to.equal('apiPrefix/clusters/clusterName/stack_versions?fields=ClusterStackVersions/*');
- });
- });
- describe("#requestStatus", function() {
- it("isSuspended false", function() {
- controller.set('isSuspended', false);
- controller.set('upgradeData', { Upgrade: {request_status: 'ABORTED'}});
- controller.propertyDidChange('requestStatus');
- expect(controller.get('requestStatus')).to.equal('ABORTED');
- });
- it("isSuspended true", function() {
- controller.set('isSuspended', true);
- controller.set('upgradeData', { Upgrade: {request_status: 'ABORTED'}});
- controller.propertyDidChange('requestStatus');
- expect(controller.get('requestStatus')).to.equal('SUSPENDED');
- });
- });
- describe("#load()", function() {
- before(function(){
- sinon.stub(controller, 'loadUpgradeData').returns({
- done: function(callback) {callback();}
- });
- sinon.stub(controller, 'loadStackVersionsToModel').returns({
- done: function(callback) {callback();}
- });
- sinon.stub(controller, 'loadRepoVersionsToModel').returns({
- done: function(callback) {callback();}
- });
- sinon.stub(App.StackVersion, 'find').returns([Em.Object.create({
- state: 'CURRENT',
- repositoryVersion: {
- repositoryVersion: '2.2',
- displayName: 'HDP-2.2'
- }
- })]);
- });
- after(function(){
- controller.loadUpgradeData.restore();
- controller.loadStackVersionsToModel.restore();
- controller.loadRepoVersionsToModel.restore();
- App.StackVersion.find.restore();
- });
- it("", function() {
- controller.load();
- expect(controller.loadUpgradeData.calledWith(true)).to.be.true;
- expect(controller.loadStackVersionsToModel.calledWith(true)).to.be.true;
- expect(controller.loadRepoVersionsToModel.calledOnce).to.be.true;
- expect(controller.get('currentVersion')).to.eql({
- "repository_version": "2.2",
- "repository_name": "HDP-2.2"
- });
- });
- });
- describe("#loadUpgradeData()", function() {
- beforeEach(function () {
- sinon.stub(App.ajax, 'send').returns({
- then: Em.K,
- complete: Em.K
- });
- });
- afterEach(function () {
- App.ajax.send.restore();
- });
- it("get entire data", function() {
- controller.set('upgradeId', 1);
- controller.loadUpgradeData();
- expect(App.ajax.send.getCall(0).args[0]).to.eql({
- name: 'admin.upgrade.data',
- sender: controller,
- data: {
- id: 1
- },
- success: 'loadUpgradeDataSuccessCallback'
- })
- });
- it("get only state", function() {
- controller.set('upgradeId', 1);
- controller.loadUpgradeData(true);
- expect(App.ajax.send.getCall(0).args[0]).to.eql({
- name: 'admin.upgrade.state',
- sender: controller,
- data: {
- id: 1
- },
- success: 'loadUpgradeDataSuccessCallback'
- })
- });
- it("upgrade id is null", function() {
- controller.set('upgradeId', null);
- controller.loadUpgradeData();
- expect(App.ajax.send.called).to.be.false;
- });
- });
- describe("#loadUpgradeDataSuccessCallback()", function() {
- var retryCases = [
- {
- isRetryPendingInitial: true,
- status: 'ABORTED',
- isRetryPending: true,
- requestInProgress: true,
- title: 'retry request not yet applied'
- },
- {
- isRetryPendingInitial: true,
- status: 'UPGRADING',
- isRetryPending: false,
- requestInProgress: false,
- title: 'retry request applied'
- },
- {
- isRetryPendingInitial: false,
- status: 'ABORTED',
- isRetryPending: false,
- requestInProgress: true,
- title: 'no retry request sent'
- },
- {
- isRetryPendingInitial: false,
- status: 'UPGRADING',
- isRetryPending: false,
- requestInProgress: true,
- title: 'upgrade wasn\'t aborted'
- }
- ];
- beforeEach(function () {
- sinon.stub(controller, 'updateUpgradeData', Em.K);
- sinon.stub(controller, 'setDBProperty', Em.K);
- });
- afterEach(function () {
- controller.updateUpgradeData.restore();
- controller.setDBProperty.restore();
- });
- it("correct data", function() {
- var data = {
- "Upgrade": {
- "request_status": "UPGRADED"
- },
- "upgrade_groups": [
- {
- "UpgradeGroup": {
- "id": 1
- },
- "upgrade_items": []
- }
- ]};
- controller.loadUpgradeDataSuccessCallback(data);
- expect(App.get('upgradeState')).to.equal('UPGRADED');
- expect(controller.updateUpgradeData.calledOnce).to.be.true;
- expect(controller.setDBProperty.calledWith('upgradeState', 'UPGRADED')).to.be.true;
- });
- it("data is null", function() {
- var data = null;
- controller.loadUpgradeDataSuccessCallback(data);
- expect(controller.updateUpgradeData.called).to.be.false;
- expect(controller.setDBProperty.called).to.be.false;
- });
- retryCases.forEach(function (item) {
- it(item.title, function () {
- var data = {
- "Upgrade": {
- "request_status": item.status
- }
- };
- controller.setProperties({
- isRetryPending: item.isRetryPendingInitial,
- requestInProgress: true
- });
- controller.loadUpgradeDataSuccessCallback(data);
- expect(controller.getProperties(['isRetryPending', 'requestInProgress'])).to.eql({
- isRetryPending: item.isRetryPending,
- requestInProgress: item.requestInProgress
- });
- });
- });
- });
- describe("#getUpgradeItem()", function() {
- beforeEach(function () {
- sinon.stub(App.ajax, 'send', Em.K);
- });
- afterEach(function () {
- App.ajax.send.restore();
- });
- it("", function() {
- var item = Em.Object.create({
- request_id: 1,
- group_id: 2,
- stage_id: 3
- });
- controller.getUpgradeItem(item);
- expect(App.ajax.send.getCall(0).args[0]).to.eql({
- name: 'admin.upgrade.upgrade_item',
- sender: controller,
- data: {
- upgradeId: 1,
- groupId: 2,
- stageId: 3
- },
- success: 'getUpgradeItemSuccessCallback'
- });
- });
- });
- describe("#openUpgradeDialog()", function () {
- before(function () {
- sinon.stub(App.router, 'transitionTo', Em.K);
- });
- after(function () {
- App.router.transitionTo.restore();
- });
- it("should open dialog", function () {
- controller.openUpgradeDialog();
- expect(App.router.transitionTo.calledWith('admin.stackUpgrade')).to.be.true;
- });
- });
- describe("#runPreUpgradeCheck()", function() {
- before(function () {
- sinon.stub(App.ajax, 'send', Em.K);
- });
- after(function () {
- App.ajax.send.restore();
- });
- it("make ajax call", function() {
- controller.runPreUpgradeCheck(Em.Object.create({
- repositoryVersion: '2.2',
- displayName: 'HDP-2.2',
- upgradeType: 'ROLLING',
- skipComponentFailures: false,
- skipSCFailures: false
- }));
- expect(App.ajax.send.getCall(0).args[0]).to.eql({
- name: "admin.upgrade.pre_upgrade_check",
- sender: controller,
- data: {
- value: '2.2',
- label: 'HDP-2.2',
- type: 'ROLLING',
- skipComponentFailures: 'false',
- skipSCFailures: 'false'
- },
- success: "runPreUpgradeCheckSuccess",
- error: "runPreUpgradeCheckError"
- });
- });
- });
- describe("#runPreUpgradeCheckSuccess()", function () {
- var cases = [
- {
- check: {
- "check": "Work-preserving RM/NM restart is enabled in YARN configs",
- "status": "FAIL",
- "reason": "FAIL",
- "failed_on": [],
- "check_type": "SERVICE"
- },
- showClusterCheckPopupCalledCount: 1,
- upgradeCalledCount: 0,
- title: 'popup is displayed if fails are present'
- },
- {
- check: {
- "check": "Configuration Merge Check",
- "status": "WARNING",
- "reason": "Conflict",
- "failed_on": [],
- "failed_detail": [
- {
- type: 't0',
- property: 'p0',
- current: 'c0',
- new_stack_value: 'n0',
- result_value: 'n0'
- },
- {
- type: 't1',
- property: 'p1',
- current: 'c1',
- new_stack_value: null,
- result_value: 'c1'
- },
- {
- type: 't2',
- property: 'p2',
- current: 'c2',
- new_stack_value: null,
- result_value: null
- }
- ],
- "check_type": "CLUSTER",
- "id": "CONFIG_MERGE"
- },
- showClusterCheckPopupCalledCount: 1,
- upgradeCalledCount: 0,
- configs: [
- {
- type: 't0',
- name: 'p0',
- currentValue: 'c0',
- recommendedValue: 'n0',
- resultingValue: 'n0',
- isDeprecated: false,
- willBeRemoved: false
- },
- {
- type: 't1',
- name: 'p1',
- currentValue: 'c1',
- recommendedValue: Em.I18n.t('popup.clusterCheck.Upgrade.configsMerge.deprecated'),
- resultingValue: 'c1',
- isDeprecated: true,
- willBeRemoved: false
- },
- {
- type: 't2',
- name: 'p2',
- currentValue: 'c2',
- recommendedValue: Em.I18n.t('popup.clusterCheck.Upgrade.configsMerge.deprecated'),
- resultingValue: Em.I18n.t('popup.clusterCheck.Upgrade.configsMerge.willBeRemoved'),
- isDeprecated: true,
- willBeRemoved: true
- }
- ],
- title: 'popup is displayed if warnings are present; configs merge conflicts'
- },
- {
- check: {
- "check": "Work-preserving RM/NM restart is enabled in YARN configs",
- "status": "PASS",
- "reason": "OK",
- "failed_on": [],
- "check_type": "SERVICE"
- },
- showClusterCheckPopupCalledCount: 0,
- upgradeCalledCount: 1,
- title: 'upgrade is started if fails and warnings are absent'
- }
- ];
- beforeEach(function () {
- sinon.stub(App, 'showClusterCheckPopup', Em.K);
- sinon.stub(controller, 'upgrade', Em.K);
- });
- afterEach(function () {
- App.showClusterCheckPopup.restore();
- controller.upgrade.restore();
- });
- cases.forEach(function (item) {
- it(item.title, function () {
- controller.runPreUpgradeCheckSuccess(
- {
- items: [
- {
- UpgradeChecks: item.check
- }
- ]
- }, null, {
- label: 'name'
- }
- );
- expect(controller.upgrade.callCount).to.equal(item.upgradeCalledCount);
- expect(App.showClusterCheckPopup.callCount).to.equal(item.showClusterCheckPopupCalledCount);
- if (item.check.id == 'CONFIG_MERGE') {
- expect(App.showClusterCheckPopup.firstCall.args[7]).to.eql(item.configs);
- }
- });
- });
- });
- describe("#initDBProperties()", function() {
- before(function () {
- sinon.stub(controller, 'getDBProperties', function (prop) {
- var ret = {};
- prop.forEach(function (k) {
- ret[k] = k;
- });
- return ret;
- });
- });
- after(function () {
- controller.getDBProperties.restore();
- });
- it("set properties", function () {
- controller.set('wizardStorageProperties', ['prop1']);
- controller.initDBProperties();
- expect(controller.get('prop1')).to.equal('prop1');
- });
- });
- describe("#init()", function() {
- before(function () {
- sinon.stub(controller, 'initDBProperties', Em.K);
- });
- after(function () {
- controller.initDBProperties.restore();
- });
- it("call initDBProperties", function () {
- controller.init();
- expect(controller.initDBProperties.calledOnce).to.be.true;
- });
- });
- describe("#upgrade()", function() {
- before(function () {
- sinon.stub(App.ajax, 'send', Em.K);
- sinon.stub(controller, 'setDBProperty', Em.K);
- });
- after(function () {
- App.ajax.send.restore();
- controller.setDBProperty.restore();
- });
- it("make ajax call", function() {
- controller.set('currentVersion', {
- repository_version: '2.2'
- });
- controller.upgrade({
- value: '2.2',
- label: 'HDP-2.2'
- });
- expect(App.ajax.send.getCall(0).args[0].data).to.eql({"value": '2.2', "label": 'HDP-2.2'});
- expect(App.ajax.send.getCall(0).args[0].name).to.eql('admin.upgrade.start');
- expect(App.ajax.send.getCall(0).args[0].sender).to.eql(controller);
- expect(App.ajax.send.getCall(0).args[0].success).to.eql('upgradeSuccessCallback');
- expect(App.ajax.send.getCall(0).args[0].callback).to.be.called;
- expect(controller.setDBProperty.calledWith('currentVersion', {
- repository_version: '2.2'
- })).to.be.true;
- });
- });
- describe("#upgradeSuccessCallback()", function() {
- before(function () {
- sinon.stub(App.clusterStatus, 'setClusterStatus', Em.K);
- sinon.stub(controller, 'openUpgradeDialog', Em.K);
- sinon.stub(controller, 'setDBProperties', Em.K);
- sinon.stub(controller, 'load', Em.K);
- });
- after(function () {
- App.clusterStatus.setClusterStatus.restore();
- controller.openUpgradeDialog.restore();
- controller.setDBProperties.restore();
- controller.load.restore();
- });
- it("open upgrade dialog", function() {
- var data = {
- resources: [
- {
- Upgrade: {
- request_id: 1
- }
- }
- ]
- };
- controller.upgradeMethods = [
- Em.Object.create({
- displayName: Em.I18n.t('admin.stackVersions.version.upgrade.upgradeOptions.RU.title'),
- type: 'ROLLING'
- }),
- Em.Object.create({
- displayName: Em.I18n.t('admin.stackVersions.version.upgrade.upgradeOptions.EU.title'),
- type: 'NON-ROLLING'
- })
- ];
- controller.upgradeSuccessCallback(data, {}, {label: 'HDP-2.2.1', isDowngrade: true});
- expect(controller.load.calledOnce).to.be.true;
- expect(controller.get('upgradeVersion')).to.equal('HDP-2.2.1');
- expect(controller.get('upgradeData')).to.be.null;
- expect(controller.get('isDowngrade')).to.be.true;
- expect(App.clusterStatus.setClusterStatus.calledOnce).to.be.true;
- expect(controller.openUpgradeDialog.calledOnce).to.be.true;
- });
- });
- describe("#updateUpgradeData()", function() {
- beforeEach(function () {
- sinon.stub(controller, 'initUpgradeData', Em.K);
- });
- afterEach(function () {
- controller.initUpgradeData.restore();
- });
- it("data loaded first time", function() {
- controller.set('upgradeData', null);
- controller.updateUpgradeData({});
- expect(controller.initUpgradeData.calledWith({})).to.be.true;
- });
- it("update loaded data", function() {
- var oldData = Em.Object.create({
- upgradeGroups: [
- Em.Object.create({
- group_id: 1,
- upgradeItems: [
- Em.Object.create({
- stage_id: 1
- })
- ]
- }),
- Em.Object.create({
- group_id: 2,
- upgradeItems: [
- Em.Object.create({
- stage_id: 2
- }),
- Em.Object.create({
- stage_id: 3
- })
- ]
- })
- ]
- });
- var newData = {
- Upgrade: {
- request_id: 1
- },
- upgrade_groups: [
- {
- UpgradeGroup: {
- group_id: 1,
- status: 'COMPLETED',
- progress_percent: 100,
- completed_task_count: 3
- },
- upgrade_items: [
- {
- UpgradeItem: {
- stage_id: 1,
- status: 'COMPLETED',
- progress_percent: 100
- }
- }
- ]
- },
- {
- UpgradeGroup: {
- group_id: 2,
- status: 'ABORTED',
- progress_percent: 50,
- completed_task_count: 1
- },
- upgrade_items: [
- {
- UpgradeItem: {
- stage_id: 2,
- status: 'ABORTED',
- progress_percent: 99
- }
- },
- {
- UpgradeItem: {
- stage_id: 3,
- status: 'PENDING',
- progress_percent: 0
- }
- }
- ]
- }
- ]
- };
- controller.set('upgradeData', oldData);
- controller.updateUpgradeData(newData);
- expect(controller.get('upgradeData.upgradeGroups')[0].get('status')).to.equal('COMPLETED');
- expect(controller.get('upgradeData.upgradeGroups')[0].get('progress_percent')).to.equal(100);
- expect(controller.get('upgradeData.upgradeGroups')[0].get('completed_task_count')).to.equal(3);
- expect(controller.get('upgradeData.upgradeGroups')[0].get('upgradeItems')[0].get('status')).to.equal('COMPLETED');
- expect(controller.get('upgradeData.upgradeGroups')[0].get('upgradeItems')[0].get('progress_percent')).to.equal(100);
- expect(controller.get('upgradeData.upgradeGroups')[0].get('hasExpandableItems')).to.be.true;
- expect(controller.get('upgradeData.upgradeGroups')[1].get('status')).to.equal('ABORTED');
- expect(controller.get('upgradeData.upgradeGroups')[1].get('progress_percent')).to.equal(50);
- expect(controller.get('upgradeData.upgradeGroups')[1].get('completed_task_count')).to.equal(1);
- expect(controller.get('upgradeData.upgradeGroups')[1].get('upgradeItems')[0].get('status')).to.equal('ABORTED');
- expect(controller.get('upgradeData.upgradeGroups')[1].get('upgradeItems')[1].get('status')).to.equal('PENDING');
- expect(controller.get('upgradeData.upgradeGroups')[1].get('upgradeItems')[0].get('progress_percent')).to.equal(99);
- expect(controller.get('upgradeData.upgradeGroups')[1].get('upgradeItems')[1].get('progress_percent')).to.equal(0);
- expect(controller.get('upgradeData.upgradeGroups')[1].get('hasExpandableItems')).to.be.false;
- });
- });
- describe("#initUpgradeData()", function() {
- it("", function() {
- var newData = {
- Upgrade: {
- request_id: 1
- },
- upgrade_groups: [
- {
- UpgradeGroup: {
- group_id: 1
- },
- upgrade_items: [
- {
- UpgradeItem: {
- stage_id: 1,
- status: 'IN_PROGRESS'
- }
- },
- {
- UpgradeItem: {
- stage_id: 2
- }
- }
- ]
- },
- {
- UpgradeGroup: {
- group_id: 2
- },
- upgrade_items: []
- },
- {
- UpgradeGroup: {
- group_id: 3
- },
- upgrade_items: [
- {
- UpgradeItem: {
- stage_id: 3,
- status: 'ABORTED'
- }
- },
- {
- UpgradeItem: {
- stage_id: 4,
- status: 'PENDING'
- }
- }
- ]
- }
- ]
- };
- controller.initUpgradeData(newData);
- expect(controller.get('upgradeData.Upgrade.request_id')).to.equal(1);
- expect(controller.get('upgradeData.upgradeGroups')[0].get('group_id')).to.equal(3);
- expect(controller.get('upgradeData.upgradeGroups')[1].get('group_id')).to.equal(2);
- expect(controller.get('upgradeData.upgradeGroups')[2].get('group_id')).to.equal(1);
- expect(controller.get('upgradeData.upgradeGroups')[2].get('upgradeItems')[0].get('stage_id')).to.equal(2);
- expect(controller.get('upgradeData.upgradeGroups')[2].get('upgradeItems')[1].get('stage_id')).to.equal(1);
- expect(controller.get('upgradeData.upgradeGroups')[0].get('hasExpandableItems')).to.be.false;
- expect(controller.get('upgradeData.upgradeGroups')[1].get('hasExpandableItems')).to.be.false;
- expect(controller.get('upgradeData.upgradeGroups')[2].get('hasExpandableItems')).to.be.true;
- });
- });
- describe.skip("#finish()", function() {
- before(function () {
- sinon.stub(App.clusterStatus, 'setClusterStatus', Em.K);
- sinon.stub(controller, 'setDBProperty', Em.K);
- });
- after(function () {
- App.clusterStatus.setClusterStatus.restore();
- controller.setDBProperty.restore();
- });
- it("upgradeState is not COMPLETED", function() {
- App.set('upgradeState', 'UPGRADING');
- controller.finish();
- expect(App.clusterStatus.setClusterStatus.called).to.be.false;
- });
- it("upgradeState is COMPLETED", function() {
- App.set('upgradeState', 'COMPLETED');
- controller.finish();
- expect(controller.setDBProperty.calledWith('upgradeId', undefined)).to.be.true;
- expect(controller.setDBProperty.calledWith('upgradeVersion', undefined)).to.be.true;
- expect(controller.setDBProperty.calledWith('upgradeState', 'INIT')).to.be.true;
- expect(controller.setDBProperty.calledWith('currentVersion', undefined)).to.be.true;
- expect(App.get('upgradeState')).to.equal('INIT');
- expect(App.clusterStatus.setClusterStatus.calledOnce).to.be.true;
- });
- });
- describe("#confirmDowngrade()", function() {
- before(function () {
- sinon.spy(App, 'showConfirmationPopup');
- sinon.stub(controller, 'downgrade', Em.K);
- });
- after(function () {
- App.showConfirmationPopup.restore();
- controller.downgrade.restore();
- });
- it("show confirmation popup", function() {
- controller.set('currentVersion', Em.Object.create({
- repository_version: '2.2',
- repository_name: 'HDP-2.2'
- }));
- var popup = controller.confirmDowngrade();
- expect(App.showConfirmationPopup.calledOnce).to.be.true;
- popup.onPrimary();
- expect(controller.downgrade.calledWith(Em.Object.create({
- repository_version: '2.2',
- repository_name: 'HDP-2.2'
- }))).to.be.true;
- });
- });
- describe("#upgradeOptions()", function() {
- before(function () {
- sinon.spy(App, 'ModalPopup');
- sinon.spy(App, 'showConfirmationFeedBackPopup');
- sinon.stub(controller, 'runPreUpgradeCheck', Em.K);
- });
- after(function () {
- App.ModalPopup.restore();
- App.showConfirmationFeedBackPopup.restore();
- controller.runPreUpgradeCheck.restore();
- });
- it("show confirmation popup", function() {
- var version = Em.Object.create({displayName: 'HDP-2.2'});
- controller.upgradeMethods = [
- Em.Object.create({
- displayName: Em.I18n.t('admin.stackVersions.version.upgrade.upgradeOptions.RU.title'),
- type: 'ROLLING',
- icon: "icon-dashboard",
- description: Em.I18n.t('admin.stackVersions.version.upgrade.upgradeOptions.RU.description'),
- selected: true,
- allowed: true
- }),
- Em.Object.create({
- displayName: Em.I18n.t('admin.stackVersions.version.upgrade.upgradeOptions.EU.title'),
- type: 'NON-ROLLING',
- icon: "icon-bolt",
- description: Em.I18n.t('admin.stackVersions.version.upgrade.upgradeOptions.EU.description'),
- selected: false,
- allowed: true
- })
- ];
- controller.set('isDowngrade', false);
- var popup = controller.upgradeOptions(false, version);
- expect(App.ModalPopup.calledOnce).to.be.true;
- var confirmPopup = popup.onPrimary();
- expect(App.showConfirmationFeedBackPopup.calledOnce).to.be.true;
- confirmPopup.onPrimary();
- expect(controller.runPreUpgradeCheck.calledWith(version)).to.be.true;
- });
- it("NOT show confirmation popup on Downgrade", function() {
- var version = Em.Object.create({displayName: 'HDP-2.2'});
- controller.set('isDowngrade', true);
- var popup = controller.upgradeOptions(false, version);
- expect(App.ModalPopup.calledOnce).to.be.false;
- });
- });
- describe("#confirmUpgrade()", function() {
- before(function () {
- sinon.stub(controller, 'upgradeOptions', Em.K);
- });
- after(function () {
- controller.upgradeOptions.restore();
- });
- it("show show upgrade options popup window", function() {
- var version = Em.Object.create({displayName: 'HDP-2.2'});
- controller.confirmUpgrade(version);
- expect(controller.upgradeOptions.calledWith(false, version)).to.be.true;
- });
- });
- describe("#downgrade()", function() {
- before(function () {
- sinon.stub(App.ajax, 'send', Em.K);
- sinon.stub(controller, 'abortUpgrade');
- sinon.stub(App.RepositoryVersion, 'find').returns([
- Em.Object.create({
- displayName: 'HDP-2.3',
- repositoryVersion: '2.3'
- })
- ]);
- });
- after(function () {
- App.ajax.send.restore();
- controller.abortUpgrade.restore();
- App.RepositoryVersion.find.restore();
- });
- it("make ajax call", function() {
- controller.set('upgradeVersion', 'HDP-2.3');
- controller.downgrade(Em.Object.create({
- repository_version: '2.2',
- repository_name: 'HDP-2.2'
- }), {context: 'context'});
- expect(controller.abortUpgrade.calledOnce).to.be.true;
- expect(App.ajax.send.getCall(0).args[0].data).to.eql({
- value: '2.2',
- label: 'HDP-2.2',
- from: '2.3',
- isDowngrade: true
- });
- expect(App.ajax.send.getCall(0).args[0].name).to.eql('admin.downgrade.start');
- expect(App.ajax.send.getCall(0).args[0].sender).to.eql(controller);
- expect(App.ajax.send.getCall(0).args[0].success).to.eql('upgradeSuccessCallback');
- expect(App.ajax.send.getCall(0).args[0].callback).to.be.called;
- });
- });
- describe("#installRepoVersionConfirmation()", function () {
- before(function () {
- sinon.stub(controller, 'installRepoVersion', Em.K);
- });
- after(function () {
- controller.installRepoVersion.restore();
- });
- it("show popup", function () {
- var repo = Em.Object.create({'displayName': 'HDP-2.2'});
- var popup = controller.installRepoVersionConfirmation(repo);
- popup.onPrimary();
- expect(controller.installRepoVersion.calledWith(repo)).to.be.true;
- });
- });
- describe("#installRepoVersion()", function () {
- before(function () {
- sinon.stub(App.ajax, 'send', Em.K);
- });
- after(function () {
- App.ajax.send.restore();
- });
- it("make ajax call", function () {
- var repo = Em.Object.create({
- stackVersionType: 'HDP',
- stackVersionNumber: '2.2',
- repositoryVersion: '2.2.1',
- repoId: 1
- });
- controller.installRepoVersion(repo);
- expect(App.ajax.send.calledOnce).to.be.true;
- });
- });
- describe("#installRepoVersionSuccess()", function() {
- var mock = Em.Object.create({
- id: 1,
- defaultStatus: 'INIT',
- stackVersion: {}
- });
- before(function () {
- sinon.spy(mock, 'set');
- sinon.stub(App.db, 'set', Em.K);
- sinon.stub(App.clusterStatus, 'setClusterStatus', Em.K);
- sinon.stub(App.RepositoryVersion, 'find').returns(mock);
- });
- after(function () {
- App.db.set.restore();
- App.clusterStatus.setClusterStatus.restore();
- App.RepositoryVersion.find.restore();
- });
- it("", function() {
- controller.installRepoVersionSuccess({Requests: {id: 1}}, {}, {id: 1});
- expect(App.db.set.calledWith('repoVersionInstall', 'id', [1])).to.be.true;
- expect(App.clusterStatus.setClusterStatus.calledOnce).to.be.true;
- expect(App.RepositoryVersion.find.calledWith(1)).to.be.true;
- expect(App.RepositoryVersion.find(1).get('defaultStatus')).to.equal('INSTALLING');
- expect(App.RepositoryVersion.find(1).get('stackVersion.state')).to.equal('INSTALLING');
- });
- });
- describe("#setUpgradeItemStatus()", function () {
- before(function () {
- sinon.stub(App.ajax, 'send', function () {
- return {
- done: function (callback) {
- callback();
- }
- }
- });
- });
- after(function () {
- App.ajax.send.restore();
- });
- it("", function () {
- var item = Em.Object.create({
- request_id: 1,
- stage_id: 1,
- group_id: 1
- });
- controller.setUpgradeItemStatus(item, 'PENDING');
- expect(App.ajax.send.getCall(0).args[0].data).to.eql({upgradeId: 1, itemId: 1, groupId: 1, status: 'PENDING'});
- expect(App.ajax.send.getCall(0).args[0].name).to.eql('admin.upgrade.upgradeItem.setState');
- expect(App.ajax.send.getCall(0).args[0].sender).to.eql(controller);
- expect(App.ajax.send.getCall(0).args[0].callback).to.be.called;
- expect(item.get('status')).to.equal('PENDING');
- });
- });
- describe("#prepareRepoForSaving()", function () {
- it("prepare date for saving", function () {
- var repo = Em.Object.create({
- operatingSystems: [
- Em.Object.create({
- osType: "redhat6",
- isDisabled: Ember.computed.not('isSelected'),
- repositories: [Em.Object.create({
- "baseUrl": "111121",
- "repoId": "HDP-2.2",
- "repoName": "HDP",
- hasError: false
- }),
- Em.Object.create({
- "baseUrl": "1",
- "repoId": "HDP-UTILS-1.1.0.20",
- "repoName": "HDP-UTILS",
- hasError: false
- })]
- })
- ]
- });
- var result = {
- "operating_systems": [
- {
- "OperatingSystems": {
- "os_type": "redhat6"
- },
- "repositories": [
- {
- "Repositories": {
- "base_url": "111121",
- "repo_id": "HDP-2.2",
- "repo_name": "HDP"
- }
- },
- {
- "Repositories": {
- "base_url": "1",
- "repo_id": "HDP-UTILS-1.1.0.20",
- "repo_name": "HDP-UTILS"
- }
- }
- ]
- }
- ]};
- expect(controller.prepareRepoForSaving(repo)).to.eql(result);
- });
- });
- describe("#getStackVersionNumber()", function(){
- it("get stack version number", function(){
- var repo = Em.Object.create({
- "stackVersionType": 'HDP',
- "stackVersion": '2.3',
- "repositoryVersion": '2.2.1'
- });
-
- var stackVersion = controller.getStackVersionNumber(repo);
- expect(stackVersion).to.equal('2.3');
- });
-
- it("get default stack version number", function(){
- App.set('currentStackVersion', '1.2.3');
- var repo = Em.Object.create({
- "stackVersionType": 'HDP',
- "repositoryVersion": '2.2.1'
- });
-
- var stackVersion = controller.getStackVersionNumber(repo);
- expect(stackVersion).to.equal('1.2.3');
- });
- });
-
- describe("#saveRepoOS()", function() {
- before(function(){
- this.mock = sinon.stub(controller, 'validateRepoVersions');
- sinon.stub(controller, 'prepareRepoForSaving', Em.K);
- sinon.stub(App.ajax, 'send').returns({success: Em.K});
- });
- after(function(){
- this.mock.restore();
- controller.prepareRepoForSaving.restore();
- App.ajax.send.restore();
- });
- it("validation errors present", function() {
- this.mock.returns({
- done: function(callback) {callback([1]);}
- });
- controller.saveRepoOS(Em.Object.create({repoVersionId: 1}), true);
- expect(controller.validateRepoVersions.calledWith(Em.Object.create({repoVersionId: 1}), true)).to.be.true;
- expect(controller.prepareRepoForSaving.called).to.be.false;
- expect(App.ajax.send.called).to.be.false;
- });
- it("no validation errors", function() {
- this.mock.returns({
- done: function(callback) {callback([]);}
- });
- controller.saveRepoOS(Em.Object.create({repoVersionId: 1}), true);
- expect(controller.validateRepoVersions.calledWith(Em.Object.create({repoVersionId: 1}), true)).to.be.true;
- expect(controller.prepareRepoForSaving.calledWith(Em.Object.create({repoVersionId: 1}))).to.be.true;
- expect(App.ajax.send.calledOnce).to.be.true;
- });
- });
- describe("#validateRepoVersions()", function () {
- before(function () {
- sinon.stub(App.ajax, 'send').returns({success: Em.K, error: Em.K});
- });
- after(function () {
- App.ajax.send.restore();
- });
- it("skip validation", function () {
- controller.validateRepoVersions(Em.Object.create({repoVersionId: 1}), true);
- expect(App.ajax.send.called).to.be.false;
- });
- it("do validation", function () {
- var repo = Em.Object.create({
- repoVersionId: 1,
- operatingSystems: [
- Em.Object.create({
- isSelected: true,
- repositories: [
- Em.Object.create()
- ]
- })
- ]
- });
- controller.validateRepoVersions(repo, false);
- expect(App.ajax.send.calledOnce).to.be.true;
- });
- });
- describe("#showProgressPopup()", function () {
- var mock = {
- initPopup: Em.K
- };
- before(function () {
- sinon.stub(App.router, 'get').withArgs('highAvailabilityProgressPopupController').returns(mock);
- sinon.spy(mock, 'initPopup');
- });
- after(function () {
- App.router.get.restore();
- mock.initPopup.restore();
- });
- it("", function () {
- controller.showProgressPopup(Em.Object.create());
- expect(mock.initPopup.calledOnce).to.be.true;
- });
- });
- describe("#getUrl()", function() {
- beforeEach(function(){
- controller.reopen({
- realStackUrl: 'realStackUrl',
- realRepoUrl: 'realRepoUrl',
- realUpdateUrl: 'realUpdateUrl'
- });
- });
- it("full load is true, stack is null", function() {
- expect(controller.getUrl(null, true)).to.equal('realRepoUrl');
- });
- it("full load is true, stack is valid", function() {
- expect(controller.getUrl({}, true)).to.equal('realStackUrl');
- });
- it("full load is false, stack is valid", function() {
- expect(controller.getUrl({}, false)).to.equal('realUpdateUrl');
- });
- });
- describe("#loadStackVersionsToModel()", function () {
- before(function () {
- sinon.stub(App.HttpClient, 'get');
- });
- after(function () {
- App.HttpClient.get.restore();
- });
- it("", function () {
- controller.loadStackVersionsToModel();
- expect(App.HttpClient.get.calledOnce).to.be.true;
- });
- });
- describe("#loadRepoVersionsToModel()", function () {
- before(function () {
- sinon.stub(App.HttpClient, 'get');
- });
- after(function () {
- App.HttpClient.get.restore();
- });
- it("", function () {
- controller.loadRepoVersionsToModel();
- expect(App.HttpClient.get.calledOnce).to.be.true;
- });
- });
- describe('#currentVersionObserver()', function () {
- var cases = [
- {
- stackVersionType: 'HDP',
- repoVersion: '2.2.1.1.0-1',
- isStormMetricsSupported: false,
- title: 'HDP < 2.2.2'
- },
- {
- stackVersionType: 'HDP',
- repoVersion: '2.2.2.1.0-1',
- isStormMetricsSupported: true,
- title: 'HDP 2.2.2'
- },
- {
- stackVersionType: 'HDP',
- repoVersion: '2.2.3.1.0-1',
- isStormMetricsSupported: true,
- title: 'HDP > 2.2.2'
- },
- {
- stackVersionType: 'BIGTOP',
- repoVersion: '0.8.1.1.0-1',
- isStormMetricsSupported: true,
- title: 'not HDP'
- }
- ];
- afterEach(function () {
- App.RepositoryVersion.find.restore();
- });
- cases.forEach(function (item) {
- it(item.title, function () {
- sinon.stub(App.RepositoryVersion, 'find').returns([
- Em.Object.create({
- status: 'CURRENT',
- stackVersionType: item.stackVersionType
- })
- ]);
- controller.set('currentVersion', {
- repository_version: item.repoVersion
- });
- expect(App.get('isStormMetricsSupported')).to.equal(item.isStormMetricsSupported);
- });
- });
- });
- describe('#updateFinalize', function () {
- beforeEach(function() {
- sinon.stub($, 'ajax', Em.K);
- controller.set('isFinalizeItem', true);
- });
- afterEach(function () {
- $.ajax.restore();
- });
- it('should do ajax-request', function () {
- sinon.stub(App, 'get').withArgs('upgradeState').returns('HOLDING');
- controller.updateFinalize();
- App.get.restore();
- expect($.ajax.calledOnce).to.be.true;
- });
- it('shouldn\'t do ajax-request', function () {
- sinon.stub(App, 'get').withArgs('upgradeState').returns('HOLDING_TIMEDOUT');
- controller.updateFinalize();
- App.get.restore();
- expect(controller.get('isFinalizeItem')).to.be.false;
- expect($.ajax.calledOnce).to.be.false;
- });
- });
- describe('#updateFinalizeSuccessCallback', function () {
- it('data exists and Finalize should be true', function() {
- var data = {
- items: [
- {
- upgrade_groups: [
- {
- upgrade_items: [
- {
- UpgradeItem: {
- context: controller.get('finalizeContext'),
- status: "HOLDING"
- }
- }
- ]
- }
- ]
- }
- ]
- };
- controller.set('isFinalizeItem', false);
- controller.updateFinalizeSuccessCallback(data);
- expect(controller.get('isFinalizeItem')).to.be.true;
- });
- it('data exists and Finalize should be false', function() {
- var data = {
- upgrade_groups: [
- {
- upgrade_items: [
- {
- UpgradeItem: {
- context: '!@#$%^&',
- status: "HOLDING"
- }
- }
- ]
- }
- ]
- };
- controller.set('isFinalizeItem', true);
- controller.updateFinalizeSuccessCallback(data);
- expect(controller.get('isFinalizeItem')).to.be.false;
- });
- it('data doesn\'t exist', function() {
- var data = null;
- controller.set('isFinalizeItem', true);
- controller.updateFinalizeSuccessCallback(data);
- expect(controller.get('isFinalizeItem')).to.be.false;
- });
- });
- describe('#updateFinalizeErrorCallback', function () {
- it('should set isFinalizeItem to false', function () {
- controller.set('isFinalizeItem', true);
- controller.updateFinalizeErrorCallback();
- expect(controller.get('isFinalizeItem')).to.be.false;
- });
- });
- describe("#suspendUpgrade()", function() {
- beforeEach(function () {
- sinon.stub(controller, 'abortUpgrade').returns({
- done: function (callback) {
- callback();
- }
- });
- sinon.stub(controller, 'setDBProperty', Em.K);
- sinon.stub(App.clusterStatus, 'setClusterStatus', Em.K);
- });
- afterEach(function () {
- controller.abortUpgrade.restore();
- controller.setDBProperty.restore();
- App.clusterStatus.setClusterStatus.restore();
- });
- it("", function() {
- controller.suspendUpgrade();
- expect(controller.abortUpgrade.calledOnce).to.be.true;
- expect(App.get('upgradeState')).to.equal('ABORTED');
- expect(controller.get('isSuspended')).to.be.true;
- expect(controller.setDBProperty.calledWith('upgradeState', 'ABORTED')).to.be.true;
- expect(controller.setDBProperty.calledWith('isSuspended', true)).to.be.true;
- expect(App.clusterStatus.setClusterStatus.calledOnce).to.be.true;
- });
- });
- describe("#resumeUpgrade()", function() {
- beforeEach(function () {
- sinon.stub(controller, 'retryUpgrade').returns({
- done: function (callback) {
- callback();
- }
- });
- sinon.stub(controller, 'setDBProperty', Em.K);
- sinon.stub(App.clusterStatus, 'setClusterStatus', Em.K);
- });
- afterEach(function () {
- controller.retryUpgrade.restore();
- controller.setDBProperty.restore();
- App.clusterStatus.setClusterStatus.restore();
- });
- it("", function() {
- controller.resumeUpgrade();
- expect(controller.retryUpgrade.calledOnce).to.be.true;
- expect(App.get('upgradeState')).to.equal('PENDING');
- expect(controller.get('isSuspended')).to.be.false;
- expect(controller.setDBProperty.calledWith('upgradeState', 'PENDING')).to.be.true;
- expect(controller.setDBProperty.calledWith('isSuspended', false)).to.be.true;
- expect(App.clusterStatus.setClusterStatus.calledOnce).to.be.true;
- });
- });
- });
|