Mercurial > hg > thermostat-ng > web-client
view src/app/components/jvm-info/kill-vm.service.spec.js @ 245:2eb2ae0f3b3f
Transition project to Angular 4 Hybrid
Reviewed-by: jkang
Review-thread: http://icedtea.classpath.org/pipermail/thermostat/2017-October/025266.html
author | Andrew Azores <aazores@redhat.com> |
---|---|
date | Fri, 13 Oct 2017 14:05:09 -0400 |
parents | e3ef516af2f4 |
children |
line wrap: on
line source
/** * Copyright 2012-2017 Red Hat, Inc. * * Thermostat is distributed under the GNU General Public License, * version 2 or any later version (with a special exception described * below, commonly known as the "Classpath Exception"). * * A copy of GNU General Public License (GPL) is included in this * distribution, in the file COPYING. * * Linking Thermostat code with other modules is making a combined work * based on Thermostat. Thus, the terms and conditions of the GPL * cover the whole combination. * * As a special exception, the copyright holders of Thermostat give you * permission to link this code with independent modules to produce an * executable, regardless of the license terms of these independent * modules, and to copy and distribute the resulting executable under * terms of your choice, provided that you also meet, for each linked * independent module, the terms and conditions of the license of that * module. An independent module is a module which is not derived from * or based on Thermostat code. If you modify Thermostat, you may * extend this exception to your version of the software, but you are * not obligated to do so. If you do not wish to do so, delete this * exception statement from your version. */ import serviceModule from './kill-vm.service.js'; import servicesModule from 'shared/services/services.module.js'; describe('KillVmService', () => { let svc, scope, commandChannel; beforeEach(() => { commandChannel = {}; angular.mock.module(servicesModule, $provide => { 'ngInject'; $provide.value('commandChannelService', commandChannel); }); angular.mock.module(serviceModule); angular.mock.inject((killVmService, $rootScope, $q) => { 'ngInject'; scope = $rootScope; let promise = $q.defer(); commandChannel.promise = promise; commandChannel.sendMessage = sinon.stub().returns(promise.promise); commandChannel.sequence = 444; commandChannel.responseCodes = { OK: { value: 'OK', message: 'Request succeeded' }, ERROR: { value: 'ERROR', message: 'Request failed for unknown reason' }, AUTH_FAIL: { value: 'AUTH_FAIL', message: 'Request failed due to authentication or authorization issues' } }; svc = killVmService; }); }); it('should exist', () => { should.exist(svc); }); it('should include sequence number in request URL', () => { svc.getPath('foo', 'bar', 'baz').should.containEql('sequence/444'); }); describe('CommandChannel delegation', () => { it('should delegate', () => { svc.killVm('foo', 'bar', 'baz', 9999); commandChannel.sendMessage.should.be.calledWith(sinon.match(svc.getPath('foo', 'bar', 'baz')), sinon.match({ 'vm-pid': 9999 })); scope.$apply(); }); it('should resolve true on command channel success', done => { svc.killVm('foo').then(success => { success.should.have.ownProperty('status'); success.status.should.be.true(); done(); }); commandChannel.promise.resolve({ type: 100, sequence: 1, payload: { respType: { value: 'OK', message: 'Request succeeded' } } }); scope.$apply(); }); it('should resolve false on command channel response error', done => { svc.killVm('foo', 'bar', 'baz').then(success => { success.should.have.ownProperty('status'); success.status.should.be.false(); success.should.have.ownProperty('reason'); success.reason.should.equal('Request failed for unknown reason'); done(); }); commandChannel.promise.resolve({ type: 100, sequence: 1, payload: { respType: { value: 'ERROR', message: 'Request failed for unknown reason' } } }); scope.$apply(); }); it('should resolve false on command channel response auth fail', done => { svc.killVm('foo', 'bar', 'baz').then(success => { success.should.have.ownProperty('status'); success.status.should.be.false(); success.should.have.ownProperty('reason'); success.reason.should.equal('Request failed due to authentication or authorization issues'); done(); }); commandChannel.promise.resolve({ type: 100, sequence: 1, payload: { respType: { value: 'AUTH_FAIL', message: 'Request failed due to authentication or authorization issues' } } }); scope.$apply(); }); it('should reject false on command channel request error', done => { svc.killVm('foo', 'bar', 'baz').catch(failure => { failure.should.equal('fooFailure'); done(); }); commandChannel.promise.reject('fooFailure'); scope.$apply(); }); it('should handle unknown response type', done => { svc.killVm('foo', 'bar', 'baz').then(success => { success.should.have.ownProperty('status'); success.status.should.be.false(); success.should.have.ownProperty('reason'); success.reason.should.equal('Request failed with unknown response type'); done(); }); commandChannel.promise.resolve({ type: 100, sequence: 1, payload: { respType: { value: 'UNKNOWN', message: 'Request failed with unknown response type' } } }); scope.$apply(); }); }); });