123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391 |
- /**
- * 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('models/host');
- require('models/service');
- require('models/host_component');
- require('mappers/server_data_mapper');
- require('views/main/host/summary');
- var mainHostSummaryView;
- var extendedMainHostSummaryView = App.MainHostSummaryView.extend({content: {}, addToolTip: function(){}, installedServices: []});
- describe('App.MainHostSummaryView', function() {
- beforeEach(function() {
- mainHostSummaryView = extendedMainHostSummaryView.create({});
- });
- describe('#sortedComponents', function() {
- var tests = Em.A([
- {
- content: Em.Object.create({
- hostComponents: Em.A([
- Em.Object.create({isMaster: false, isSlave: true, componentName: 'B'}),
- Em.Object.create({isMaster: true, isSlave: false, componentName: 'A'}),
- Em.Object.create({isMaster: true, isSlave: false, componentName: 'C'}),
- Em.Object.create({isMaster: false, isSlave: false, componentName: 'D'})
- ])
- }),
- m: 'List of masters, slaves and clients',
- e: ['A', 'C', 'B']
- },
- {
- content: Em.Object.create({
- hostComponents: Em.A([
- Em.Object.create({isMaster: false, isSlave: true, componentName: 'B'}),
- Em.Object.create({isMaster: true, isSlave: false, componentName: 'A'}),
- Em.Object.create({isMaster: true, isSlave: false, componentName: 'C'}),
- Em.Object.create({isMaster: true, isSlave: false, componentName: 'D'})
- ])
- }),
- m: 'List of masters and slaves',
- e: ['A', 'C', 'D', 'B']
- },
- {
- content: Em.Object.create({
- hostComponents: Em.A([
- Em.Object.create({isMaster: true, isSlave: false, componentName: 'B'}),
- Em.Object.create({isMaster: true, isSlave: false, componentName: 'A'}),
- Em.Object.create({isMaster: true, isSlave: false, componentName: 'C'}),
- Em.Object.create({isMaster: true, isSlave: false, componentName: 'D'})
- ])
- }),
- m: 'List of masters',
- e: ['B', 'A', 'C', 'D']
- },
- {
- content: Em.Object.create({
- hostComponents: Em.A([
- Em.Object.create({isMaster: false, isSlave: true, componentName: 'B'}),
- Em.Object.create({isMaster: false, isSlave: true, componentName: 'A'}),
- Em.Object.create({isMaster: false, isSlave: true, componentName: 'C'}),
- Em.Object.create({isMaster: false, isSlave: true, componentName: 'D'})
- ])
- }),
- m: 'List of slaves',
- e: ['B', 'A', 'C', 'D']
- },
- {
- content: Em.Object.create({
- hostComponents: Em.A([])
- }),
- m: 'Empty list',
- e: []
- },
- {
- content: Em.Object.create({
- hostComponents: Em.A([
- Em.Object.create({isMaster: false, isSlave: false, componentName: 'B'}),
- Em.Object.create({isMaster: false, isSlave: false, componentName: 'A'}),
- Em.Object.create({isMaster: false, isSlave: false, componentName: 'C'}),
- Em.Object.create({isMaster: false, isSlave: false, componentName: 'D'})
- ])
- }),
- m: 'List of clients',
- e: []
- }
- ]);
- tests.forEach(function(test) {
- it(test.m, function() {
- test.content.get('hostComponents').forEach(function(component) {
- component.set('id', component.get('componentName'));
- });
- mainHostSummaryView.set('sortedComponents', []);
- mainHostSummaryView.set('content', test.content);
- mainHostSummaryView.sortedComponentsFormatter();
- expect(mainHostSummaryView.get('sortedComponents').mapProperty('componentName')).to.eql(test.e);
- });
- });
- });
- describe('#clients', function() {
- var tests = Em.A([
- {
- content: Em.Object.create({
- hostComponents: Em.A([
- Em.Object.create({isMaster: false, isSlave: true, componentName: 'B'}),
- Em.Object.create({isMaster: true, isSlave: false, componentName: 'A'}),
- Em.Object.create({isMaster: true, isSlave: false, componentName: 'C'}),
- Em.Object.create({isMaster: false, isSlave: false, componentName: 'D'})
- ])
- }),
- m: 'List of masters, slaves and clients',
- e: ['D']
- },
- {
- content: Em.Object.create({
- hostComponents: Em.A([
- Em.Object.create({isMaster: false, isSlave: true, componentName: 'B'}),
- Em.Object.create({isMaster: true, isSlave: false, componentName: 'A'}),
- Em.Object.create({isMaster: true, isSlave: false, componentName: 'C'}),
- Em.Object.create({isMaster: true, isSlave: false, componentName: 'D'})
- ])
- }),
- m: 'List of masters and slaves',
- e: []
- },
- {
- content: Em.Object.create({
- hostComponents: Em.A([
- Em.Object.create({isMaster: true, isSlave: false, componentName: 'B'}),
- Em.Object.create({isMaster: true, isSlave: false, componentName: 'A'}),
- Em.Object.create({isMaster: true, isSlave: false, componentName: 'C'}),
- Em.Object.create({isMaster: true, isSlave: false, componentName: 'D'})
- ])
- }),
- m: 'List of masters',
- e: []
- },
- {
- content: Em.Object.create({
- hostComponents: Em.A([
- Em.Object.create({isMaster: false, isSlave: true, componentName: 'B'}),
- Em.Object.create({isMaster: false, isSlave: true, componentName: 'A'}),
- Em.Object.create({isMaster: false, isSlave: true, componentName: 'C'}),
- Em.Object.create({isMaster: false, isSlave: true, componentName: 'D'})
- ])
- }),
- m: 'List of slaves',
- e: []
- },
- {
- content: Em.Object.create({
- hostComponents: Em.A([])
- }),
- m: 'Empty list',
- e: []
- },
- {
- content: Em.Object.create({
- hostComponents: Em.A([
- Em.Object.create({isMaster: false, isSlave: false, componentName: 'B'}),
- Em.Object.create({isMaster: false, isSlave: false, componentName: 'A'}),
- Em.Object.create({isMaster: false, isSlave: false, componentName: 'C'}),
- Em.Object.create({isMaster: false, isSlave: false, componentName: 'D'})
- ])
- }),
- m: 'List of clients',
- e: ['B', 'A', 'C', 'D']
- }
- ]);
- tests.forEach(function(test) {
- it(test.m, function() {
- mainHostSummaryView.set('content', test.content);
- expect(mainHostSummaryView.get('clients').mapProperty('componentName')).to.eql(test.e);
- });
- });
- });
- describe('#areClientWithStaleConfigs', function() {
- var tests = Em.A([
- {
- content: Em.Object.create({
- hostComponents: Em.A([
- Em.Object.create({isMaster: false, isSlave: false, componentName: 'D', staleConfigs: true}),
- Em.Object.create({isMaster: false, isSlave: false, componentName: 'C', staleConfigs: false})
- ])
- }),
- m: 'Some clients with stale configs',
- e: true
- },
- {
- content: Em.Object.create({
- hostComponents: Em.A([
- Em.Object.create({isMaster: false, isSlave: false, componentName: 'D', staleConfigs: false}),
- Em.Object.create({isMaster: false, isSlave: false, componentName: 'C', staleConfigs: false})
- ])
- }),
- m: 'No clients with stale configs',
- e: false
- },
- {
- content: Em.Object.create({
- hostComponents: Em.A([
- Em.Object.create({isMaster: false, isSlave: false, componentName: 'D', staleConfigs: true}),
- Em.Object.create({isMaster: false, isSlave: false, componentName: 'C', staleConfigs: true})
- ])
- }),
- m: 'All clients with stale configs',
- e: true
- },
- {
- content: Em.Object.create({
- hostComponents: Em.A([])
- }),
- m: 'Empty list',
- e: false
- }
- ]);
- tests.forEach(function(test) {
- it(test.m, function() {
- mainHostSummaryView.set('content', test.content);
- expect(mainHostSummaryView.get('areClientWithStaleConfigs')).to.equal(test.e);
- });
- });
- });
- describe('#isAddComponent', function() {
- var tests = Em.A([
- {content: {healthClass: 'health-status-DEAD-YELLOW', hostComponents: Em.A([])}, e: false},
- {content: {healthClass: 'OTHER_VALUE', hostComponents: Em.A([])}, e: true}
- ]);
- tests.forEach(function(test) {
- it(test.content.healthClass, function() {
- mainHostSummaryView.set('content', test.content);
- expect(mainHostSummaryView.get('isAddComponent')).to.equal(test.e);
- });
- });
- });
- describe('#installableClientComponents', function() {
- it('delete host not supported', function() {
- App.set('supports.deleteHost', false);
- expect(mainHostSummaryView.get('installableClientComponents')).to.eql([]);
- App.set('supports.deleteHost', true);
- });
- var tests = Em.A([
- {
- content: Em.Object.create({
- hostComponents: Em.A([])
- }),
- services: ['HDFS', 'YARN', 'MAPREDUCE2'],
- e: ['HDFS_CLIENT', 'YARN_CLIENT', 'MAPREDUCE2_CLIENT'],
- m: 'no one client installed'
- },
- {
- content: Em.Object.create({
- hostComponents: Em.A([
- Em.Object.create({
- componentName: 'HDFS_CLIENT'
- })
- ])
- }),
- services: ['HDFS', 'YARN', 'MAPREDUCE2'],
- e: ['YARN_CLIENT', 'MAPREDUCE2_CLIENT'],
- m: 'some clients are already installed'
- },
- {
- content: Em.Object.create({
- hostComponents: Em.A([
- Em.Object.create({
- componentName: 'HDFS_CLIENT'
- }),
- Em.Object.create({
- componentName: 'YARN_CLIENT'
- }),
- Em.Object.create({
- componentName: 'MAPREDUCE2_CLIENT'
- })
- ])
- }),
- services: ['HDFS', 'YARN', 'MAPREDUCE2'],
- e: [],
- m: 'all clients are already installed'
- }
- ]);
- tests.forEach(function(test) {
- it(test.m, function() {
- mainHostSummaryView.set('content', test.content);
- mainHostSummaryView.set('installedServices', test.services);
- expect(mainHostSummaryView.get('installableClientComponents')).to.include.members(test.e);
- expect(test.e).to.include.members(mainHostSummaryView.get('installableClientComponents'));
- });
- });
- });
- describe('#addableComponents', function() {
- var tests = Em.A([
- {
- content: Em.Object.create({
- hostComponents: Em.A([])
- }),
- services: ['HDFS', 'YARN', 'MAPREDUCE2'],
- e: ['DATANODE', 'NODEMANAGER', 'CLIENTS'],
- m: 'no components on host (impossible IRL, but should be tested)'
- },
- {
- content: Em.Object.create({
- hostComponents: Em.A([
- Em.Object.create({
- componentName: 'HDFS_CLIENT'
- }),
- Em.Object.create({
- componentName: 'DATANODE'
- })
- ])
- }),
- services: ['HDFS', 'YARN', 'MAPREDUCE2'],
- e: ['NODEMANAGER', 'CLIENTS'],
- m: 'some components are already installed'
- },
- {
- content: Em.Object.create({
- hostComponents: Em.A([
- Em.Object.create({
- componentName: 'HDFS_CLIENT'
- }),
- Em.Object.create({
- componentName: 'YARN_CLIENT'
- }),
- Em.Object.create({
- componentName: 'MAPREDUCE2_CLIENT'
- }),
- Em.Object.create({
- componentName: 'NODEMANAGER'
- })
- ])
- }),
- services: ['HDFS', 'YARN', 'MAPREDUCE2'],
- e: ['DATANODE'],
- m: 'all clients and some other components are already installed'
- }
- ]);
- tests.forEach(function(test) {
- it(test.m, function() {
- mainHostSummaryView.set('content', test.content);
- mainHostSummaryView.set('installedServices', test.services);
- expect(mainHostSummaryView.get('addableComponents').mapProperty('componentName')).to.include.members(test.e);
- expect(test.e).to.include.members(mainHostSummaryView.get('addableComponents').mapProperty('componentName'));
- });
- });
- });
- });
|