2016-02-19 02:27:40 +08:00
|
|
|
/**
|
|
|
|
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.
|
|
|
|
*/
|
|
|
|
|
2018-06-18 14:15:24 +08:00
|
|
|
const rewire = require('rewire');
|
|
|
|
|
|
|
|
describe('run', () => {
|
|
|
|
let run;
|
|
|
|
|
|
|
|
beforeEach(() => {
|
|
|
|
run = rewire('../../bin/templates/cordova/lib/run');
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('getInstallTarget', () => {
|
|
|
|
const targetOpts = { target: 'emu' };
|
|
|
|
const deviceOpts = { device: true };
|
|
|
|
const emulatorOpts = { emulator: true };
|
|
|
|
const emptyOpts = {};
|
|
|
|
|
|
|
|
it('Test#001 : should select correct target based on the run opts', () => {
|
|
|
|
const getInstallTarget = run.__get__('getInstallTarget');
|
2017-06-14 02:42:20 +08:00
|
|
|
expect(getInstallTarget(targetOpts)).toBe('emu');
|
|
|
|
expect(getInstallTarget(deviceOpts)).toBe('--device');
|
|
|
|
expect(getInstallTarget(emulatorOpts)).toBe('--emulator');
|
|
|
|
expect(getInstallTarget(emptyOpts)).toBeUndefined();
|
|
|
|
});
|
2016-02-19 02:27:40 +08:00
|
|
|
});
|
2018-06-18 14:15:24 +08:00
|
|
|
|
|
|
|
describe('run method', () => {
|
|
|
|
let deviceSpyObj;
|
|
|
|
let emulatorSpyObj;
|
|
|
|
let eventsSpyObj;
|
|
|
|
let getInstallTargetSpy;
|
|
|
|
|
|
|
|
beforeEach(() => {
|
|
|
|
deviceSpyObj = jasmine.createSpyObj('deviceSpy', ['install', 'list', 'resolveTarget']);
|
|
|
|
emulatorSpyObj = jasmine.createSpyObj('emulatorSpy', ['install', 'list_images', 'list_started', 'resolveTarget', 'start', 'wait_for_boot']);
|
|
|
|
eventsSpyObj = jasmine.createSpyObj('eventsSpy', ['emit']);
|
|
|
|
getInstallTargetSpy = jasmine.createSpy('getInstallTargetSpy');
|
|
|
|
|
|
|
|
run.__set__({
|
|
|
|
device: deviceSpyObj,
|
|
|
|
emulator: emulatorSpyObj,
|
|
|
|
events: eventsSpyObj,
|
|
|
|
getInstallTarget: getInstallTargetSpy
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should run on default device when no target arguments are specified', () => {
|
|
|
|
const deviceList = ['testDevice1', 'testDevice2'];
|
|
|
|
|
|
|
|
getInstallTargetSpy.and.returnValue(null);
|
|
|
|
deviceSpyObj.list.and.returnValue(Promise.resolve(deviceList));
|
|
|
|
|
|
|
|
return run.run().then(() => {
|
|
|
|
expect(deviceSpyObj.resolveTarget).toHaveBeenCalledWith(deviceList[0]);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should run on emulator when no target arguments are specified, and no devices are found', () => {
|
|
|
|
const deviceList = [];
|
|
|
|
|
|
|
|
getInstallTargetSpy.and.returnValue(null);
|
|
|
|
deviceSpyObj.list.and.returnValue(Promise.resolve(deviceList));
|
|
|
|
emulatorSpyObj.list_started.and.returnValue(Promise.resolve([]));
|
|
|
|
|
|
|
|
return run.run().then(() => {
|
|
|
|
expect(emulatorSpyObj.list_started).toHaveBeenCalled();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should run on default device when device is requested, but none specified', () => {
|
|
|
|
getInstallTargetSpy.and.returnValue('--device');
|
|
|
|
|
|
|
|
return run.run().then(() => {
|
|
|
|
// Default device is selected by calling device.resolveTarget(null)
|
|
|
|
expect(deviceSpyObj.resolveTarget).toHaveBeenCalledWith(null);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should run on a running emulator if one exists', () => {
|
|
|
|
const emulatorList = ['emulator1', 'emulator2'];
|
|
|
|
|
|
|
|
getInstallTargetSpy.and.returnValue('--emulator');
|
|
|
|
emulatorSpyObj.list_started.and.returnValue(Promise.resolve(emulatorList));
|
|
|
|
|
|
|
|
return run.run().then(() => {
|
|
|
|
expect(emulatorSpyObj.resolveTarget).toHaveBeenCalledWith(emulatorList[0]);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should start an emulator and run on that if none is running', () => {
|
|
|
|
const emulatorList = [];
|
|
|
|
const defaultEmulator = 'default-emu';
|
|
|
|
|
|
|
|
getInstallTargetSpy.and.returnValue('--emulator');
|
|
|
|
emulatorSpyObj.list_started.and.returnValue(Promise.resolve(emulatorList));
|
|
|
|
emulatorSpyObj.start.and.returnValue(Promise.resolve(defaultEmulator));
|
|
|
|
|
|
|
|
return run.run().then(() => {
|
|
|
|
expect(emulatorSpyObj.resolveTarget).toHaveBeenCalledWith(defaultEmulator);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should run on a named device if it is specified', () => {
|
|
|
|
const deviceList = ['device1', 'device2', 'device3'];
|
|
|
|
getInstallTargetSpy.and.returnValue(deviceList[1]);
|
|
|
|
|
|
|
|
deviceSpyObj.list.and.returnValue(Promise.resolve(deviceList));
|
|
|
|
|
|
|
|
return run.run().then(() => {
|
|
|
|
expect(deviceSpyObj.resolveTarget).toHaveBeenCalledWith(deviceList[1]);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should run on a named emulator if it is specified', () => {
|
|
|
|
const startedEmulatorList = ['emu1', 'emu2', 'emu3'];
|
|
|
|
getInstallTargetSpy.and.returnValue(startedEmulatorList[2]);
|
|
|
|
|
|
|
|
deviceSpyObj.list.and.returnValue(Promise.resolve([]));
|
|
|
|
emulatorSpyObj.list_started.and.returnValue(Promise.resolve(startedEmulatorList));
|
|
|
|
|
|
|
|
return run.run().then(() => {
|
|
|
|
expect(emulatorSpyObj.resolveTarget).toHaveBeenCalledWith(startedEmulatorList[2]);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should start named emulator and then run on it if it is specified', () => {
|
|
|
|
const emulatorList = [
|
|
|
|
{ name: 'emu1', id: 1 },
|
|
|
|
{ name: 'emu2', id: 2 },
|
|
|
|
{ name: 'emu3', id: 3 }
|
|
|
|
];
|
|
|
|
getInstallTargetSpy.and.returnValue(emulatorList[2].name);
|
|
|
|
|
|
|
|
deviceSpyObj.list.and.returnValue(Promise.resolve([]));
|
|
|
|
emulatorSpyObj.list_started.and.returnValue(Promise.resolve([]));
|
|
|
|
emulatorSpyObj.list_images.and.returnValue(Promise.resolve(emulatorList));
|
|
|
|
emulatorSpyObj.start.and.returnValue(Promise.resolve(emulatorList[2].id));
|
|
|
|
|
|
|
|
return run.run().then(() => {
|
|
|
|
expect(emulatorSpyObj.start).toHaveBeenCalledWith(emulatorList[2].name);
|
|
|
|
expect(emulatorSpyObj.resolveTarget).toHaveBeenCalledWith(emulatorList[2].id);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should throw an error if target is specified but does not exist', () => {
|
|
|
|
const emulatorList = [{ name: 'emu1', id: 1 }];
|
|
|
|
const deviceList = ['device1'];
|
|
|
|
const target = 'nonexistentdevice';
|
|
|
|
getInstallTargetSpy.and.returnValue(target);
|
|
|
|
|
|
|
|
deviceSpyObj.list.and.returnValue(Promise.resolve(deviceList));
|
|
|
|
emulatorSpyObj.list_started.and.returnValue(Promise.resolve([]));
|
|
|
|
emulatorSpyObj.list_images.and.returnValue(Promise.resolve(emulatorList));
|
|
|
|
|
|
|
|
return run.run().then(
|
|
|
|
() => fail('Expected error to be thrown'),
|
|
|
|
err => expect(err).toContain(target)
|
|
|
|
);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should install on device after build', () => {
|
|
|
|
const deviceTarget = { target: 'device1', isEmulator: false };
|
|
|
|
getInstallTargetSpy.and.returnValue('--device');
|
|
|
|
deviceSpyObj.resolveTarget.and.returnValue(deviceTarget);
|
|
|
|
|
|
|
|
return run.run().then(() => {
|
2018-09-06 10:06:18 +08:00
|
|
|
expect(deviceSpyObj.install).toHaveBeenCalledWith(deviceTarget, {apkPaths: [], buildType: 'debug'});
|
2018-06-18 14:15:24 +08:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should install on emulator after build', () => {
|
|
|
|
const emulatorTarget = { target: 'emu1', isEmulator: true };
|
|
|
|
getInstallTargetSpy.and.returnValue('--emulator');
|
|
|
|
emulatorSpyObj.list_started.and.returnValue(Promise.resolve([emulatorTarget.target]));
|
|
|
|
emulatorSpyObj.resolveTarget.and.returnValue(emulatorTarget);
|
|
|
|
emulatorSpyObj.wait_for_boot.and.returnValue(Promise.resolve());
|
|
|
|
|
|
|
|
return run.run().then(() => {
|
2018-09-06 10:06:18 +08:00
|
|
|
expect(emulatorSpyObj.install).toHaveBeenCalledWith(emulatorTarget, {apkPaths: [], buildType: 'debug'});
|
2018-06-18 14:15:24 +08:00
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('help', () => {
|
|
|
|
it('should print out usage and help', () => {
|
|
|
|
const logSpy = jasmine.createSpy();
|
|
|
|
const procStub = { exit: _ => null, cwd: _ => '', argv: ['', ''] };
|
|
|
|
run.__set__({ console: { log: logSpy }, process: procStub });
|
|
|
|
|
|
|
|
run.help();
|
|
|
|
expect(logSpy).toHaveBeenCalledWith(jasmine.stringMatching(/^Usage:/));
|
|
|
|
});
|
|
|
|
});
|
2016-02-19 02:27:40 +08:00
|
|
|
});
|