appium-adb
Version:
249 lines (207 loc) • 23.6 kB
JavaScript
;
var _regeneratorRuntime = require('babel-runtime/regenerator')['default'];
var _interopRequireDefault = require('babel-runtime/helpers/interop-require-default')['default'];
var _interopRequireWildcard = require('babel-runtime/helpers/interop-require-wildcard')['default'];
var _this = this;
var _chai = require('chai');
var _chai2 = _interopRequireDefault(_chai);
var _chaiAsPromised = require('chai-as-promised');
var _chaiAsPromised2 = _interopRequireDefault(_chaiAsPromised);
var _ = require('../..');
var _2 = _interopRequireDefault(_);
var _teen_process = require('teen_process');
var teen_process = _interopRequireWildcard(_teen_process);
var _appiumTestSupport = require('appium-test-support');
var _bluebird = require('bluebird');
var _bluebird2 = _interopRequireDefault(_bluebird);
_chai2['default'].use(_chaiAsPromised2['default']);
var adb = new _2['default']();
adb.executable.path = 'adb_path';
describe('System calls', (0, _appiumTestSupport.withMocks)({ teen_process: teen_process }, function (mocks) {
it('getConnectedDevices should get all connected devices', function callee$1$0() {
var devices;
return _regeneratorRuntime.async(function callee$1$0$(context$2$0) {
while (1) switch (context$2$0.prev = context$2$0.next) {
case 0:
mocks.teen_process.expects("exec").once().withExactArgs(adb.executable.path, ['devices']).returns({ stdout: "List of devices attached \n emulator-5554 device" });
context$2$0.next = 3;
return _regeneratorRuntime.awrap(adb.getConnectedDevices());
case 3:
devices = context$2$0.sent;
devices.should.have.length.above(0);
mocks.teen_process.verify();
case 6:
case 'end':
return context$2$0.stop();
}
}, null, _this);
});
it('getConnectedDevices should fail when adb devices returns unexpected output', function callee$1$0() {
return _regeneratorRuntime.async(function callee$1$0$(context$2$0) {
while (1) switch (context$2$0.prev = context$2$0.next) {
case 0:
mocks.teen_process.expects("exec").once().withExactArgs(adb.executable.path, ['devices']).returns({ stdout: "foobar" });
context$2$0.next = 3;
return _regeneratorRuntime.awrap(adb.getConnectedDevices().should.eventually.be.rejectedWith("Unexpected output while trying to get devices"));
case 3:
mocks.teen_process.verify();
case 4:
case 'end':
return context$2$0.stop();
}
}, null, _this);
});
it('getDevicesWithRetry should fail when there are no connected devices', function callee$1$0() {
return _regeneratorRuntime.async(function callee$1$0$(context$2$0) {
while (1) switch (context$2$0.prev = context$2$0.next) {
case 0:
mocks.teen_process.expects("exec").atLeast(2).withExactArgs(adb.executable.path, ['devices']).returns({ stdout: "List of devices attached" });
context$2$0.next = 3;
return _regeneratorRuntime.awrap(adb.getDevicesWithRetry(1000).should.eventually.be.rejectedWith("Could not find a connected Android device."));
case 3:
mocks.teen_process.verify();
case 4:
case 'end':
return context$2$0.stop();
}
}, null, _this);
});
it('getDevicesWithRetry should fail when adb devices returns unexpected output', function callee$1$0() {
return _regeneratorRuntime.async(function callee$1$0$(context$2$0) {
while (1) switch (context$2$0.prev = context$2$0.next) {
case 0:
mocks.teen_process.expects("exec").atLeast(2).withExactArgs(adb.executable.path, ['devices']).returns({ stdout: "foobar" });
context$2$0.next = 3;
return _regeneratorRuntime.awrap(adb.getDevicesWithRetry(1000).should.eventually.be.rejectedWith("Could not find a connected Android device."));
case 3:
mocks.teen_process.verify();
case 4:
case 'end':
return context$2$0.stop();
}
}, null, _this);
});
it('getDevicesWithRetry should get all connected devices', function callee$1$0() {
var devices;
return _regeneratorRuntime.async(function callee$1$0$(context$2$0) {
while (1) switch (context$2$0.prev = context$2$0.next) {
case 0:
mocks.teen_process.expects("exec").once().withExactArgs(adb.executable.path, ['devices']).returns({ stdout: "List of devices attached \n emulator-5554 device" });
context$2$0.next = 3;
return _regeneratorRuntime.awrap(adb.getDevicesWithRetry(1000));
case 3:
devices = context$2$0.sent;
devices.should.have.length.above(0);
mocks.teen_process.verify();
case 6:
case 'end':
return context$2$0.stop();
}
}, null, _this);
});
it('getDevicesWithRetry should get all connected devices second time', function callee$1$0() {
var devices;
return _regeneratorRuntime.async(function callee$1$0$(context$2$0) {
while (1) switch (context$2$0.prev = context$2$0.next) {
case 0:
mocks.teen_process.expects("exec").onCall(0).returns({ stdout: "Foobar" });
mocks.teen_process.expects("exec").withExactArgs(adb.executable.path, ['devices']).returns({ stdout: "List of devices attached \n emulator-5554 device" });
context$2$0.next = 4;
return _regeneratorRuntime.awrap(adb.getDevicesWithRetry(2000));
case 4:
devices = context$2$0.sent;
devices.should.have.length.above(0);
mocks.teen_process.verify();
case 7:
case 'end':
return context$2$0.stop();
}
}, null, _this);
});
it('getDevicesWithRetry should fail when exec throws an error', function callee$1$0() {
return _regeneratorRuntime.async(function callee$1$0$(context$2$0) {
while (1) switch (context$2$0.prev = context$2$0.next) {
case 0:
mocks.teen_process.expects("exec").atLeast(2).throws("Error foobar");
context$2$0.next = 3;
return _regeneratorRuntime.awrap(adb.getDevicesWithRetry(1000).should.eventually.be.rejectedWith("Could not find a connected Android device."));
case 3:
mocks.teen_process.verify();
case 4:
case 'end':
return context$2$0.stop();
}
}, null, _this);
});
it('setDeviceId should set the device id', function () {
adb.setDeviceId('foobar');
adb.curDeviceId.should.equal('foobar');
adb.executable.defaultArgs.should.include('foobar');
});
it('setDevice should set the device id and emu port from obj', function () {
adb.setDevice({ udid: 'emulator-1234' });
adb.curDeviceId.should.equal('emulator-1234');
adb.executable.defaultArgs.should.include('emulator-1234');
adb.emulatorPort.should.equal(1234);
});
it('setEmulatorPort should change emulator port', function () {
adb.setEmulatorPort(5554);
adb.emulatorPort.should.equal(5554);
});
}));
describe('System calls', (0, _appiumTestSupport.withMocks)({ adb: adb, B: _bluebird2['default'] }, function (mocks) {
it('fileExists should return true for if ls returns', function callee$1$0() {
return _regeneratorRuntime.async(function callee$1$0$(context$2$0) {
while (1) switch (context$2$0.prev = context$2$0.next) {
case 0:
mocks.adb.expects("ls").once().withExactArgs('foo').returns(['bar']);
context$2$0.next = 3;
return _regeneratorRuntime.awrap(adb.fileExists("foo").should.eventually.equal(true));
case 3:
mocks.adb.verify();
case 4:
case 'end':
return context$2$0.stop();
}
}, null, _this);
});
it('ls should return list', function callee$1$0() {
var list;
return _regeneratorRuntime.async(function callee$1$0$(context$2$0) {
while (1) switch (context$2$0.prev = context$2$0.next) {
case 0:
mocks.adb.expects("shell").once().withExactArgs(['ls', 'foo']).returns('bar');
context$2$0.next = 3;
return _regeneratorRuntime.awrap(adb.ls("foo"));
case 3:
list = context$2$0.sent;
list.should.deep.equal(['bar']);
mocks.adb.verify();
case 6:
case 'end':
return context$2$0.stop();
}
}, null, _this);
});
it('reboot should call stop and start using shell', function callee$1$0() {
return _regeneratorRuntime.async(function callee$1$0$(context$2$0) {
while (1) switch (context$2$0.prev = context$2$0.next) {
case 0:
mocks.adb.expects("shell").once().withExactArgs(['stop']);
mocks.adb.expects("setDeviceProperty").once().withExactArgs('sys.boot_completed', 0);
mocks.adb.expects("shell").once().withExactArgs(['start']);
mocks.adb.expects("getDeviceProperty").once().withExactArgs('sys.boot_completed').returns('1');
mocks.B.expects("delay").once().withExactArgs(2000);
context$2$0.next = 7;
return _regeneratorRuntime.awrap(adb.reboot().should.eventually.not.be.rejected);
case 7:
mocks.adb.verify();
mocks.B.verify();
case 9:
case 'end':
return context$2$0.stop();
}
}, null, _this);
});
}));
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["test/unit/syscalls-specs.js"],"names":[],"mappings":"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","file":"test/unit/syscalls-specs.js","sourcesContent":["import chai from 'chai';\nimport chaiAsPromised from 'chai-as-promised';\nimport ADB from '../..';\nimport * as teen_process from 'teen_process';\nimport { withMocks } from 'appium-test-support';\nimport B from 'bluebird';\n\n\nchai.use(chaiAsPromised);\nconst adb = new ADB();\nadb.executable.path = 'adb_path';\n\ndescribe('System calls', withMocks({teen_process}, (mocks) => {\n  it('getConnectedDevices should get all connected devices', async () => {\n    mocks.teen_process.expects(\"exec\")\n      .once().withExactArgs(adb.executable.path, ['devices'])\n      .returns({stdout:\"List of devices attached \\n emulator-5554\tdevice\"});\n    let devices = await adb.getConnectedDevices();\n    devices.should.have.length.above(0);\n    mocks.teen_process.verify();\n  });\n  it('getConnectedDevices should fail when adb devices returns unexpected output', async () => {\n    mocks.teen_process.expects(\"exec\")\n      .once().withExactArgs(adb.executable.path, ['devices'])\n      .returns({stdout:\"foobar\"});\n    await adb.getConnectedDevices().should.eventually.be\n                                   .rejectedWith(\"Unexpected output while trying to get devices\");\n    mocks.teen_process.verify();\n  });\n  it('getDevicesWithRetry should fail when there are no connected devices', async () => {\n    mocks.teen_process.expects(\"exec\")\n      .atLeast(2).withExactArgs(adb.executable.path, ['devices'])\n      .returns({stdout:\"List of devices attached\"});\n    await adb.getDevicesWithRetry(1000).should.eventually.be\n                                       .rejectedWith(\"Could not find a connected Android device.\");\n    mocks.teen_process.verify();\n  });\n  it('getDevicesWithRetry should fail when adb devices returns unexpected output', async () => {\n    mocks.teen_process.expects(\"exec\")\n      .atLeast(2).withExactArgs(adb.executable.path, ['devices'])\n      .returns({stdout:\"foobar\"});\n    await adb.getDevicesWithRetry(1000).should.eventually.be\n                                       .rejectedWith(\"Could not find a connected Android device.\");\n    mocks.teen_process.verify();\n  });\n  it('getDevicesWithRetry should get all connected devices', async () => {\n    mocks.teen_process.expects(\"exec\")\n      .once().withExactArgs(adb.executable.path, ['devices'])\n      .returns({stdout:\"List of devices attached \\n emulator-5554\tdevice\"});\n    let devices = await adb.getDevicesWithRetry(1000);\n    devices.should.have.length.above(0);\n    mocks.teen_process.verify();\n  });\n  it('getDevicesWithRetry should get all connected devices second time', async () => {\n    mocks.teen_process.expects(\"exec\")\n      .onCall(0)\n      .returns({stdout:\"Foobar\"});\n    mocks.teen_process.expects(\"exec\")\n      .withExactArgs(adb.executable.path, ['devices'])\n      .returns({stdout:\"List of devices attached \\n emulator-5554\tdevice\"});\n    let devices = await adb.getDevicesWithRetry(2000);\n    devices.should.have.length.above(0);\n    mocks.teen_process.verify();\n  });\n  it('getDevicesWithRetry should fail when exec throws an error', async () => {\n    mocks.teen_process.expects(\"exec\")\n      .atLeast(2)\n      .throws(\"Error foobar\");\n    await adb.getDevicesWithRetry(1000).should.eventually.be\n                                       .rejectedWith(\"Could not find a connected Android device.\");\n    mocks.teen_process.verify();\n  });\n  it('setDeviceId should set the device id', () => {\n    adb.setDeviceId('foobar');\n    adb.curDeviceId.should.equal('foobar');\n    adb.executable.defaultArgs.should.include('foobar');\n  });\n  it('setDevice should set the device id and emu port from obj', () => {\n    adb.setDevice({udid: 'emulator-1234'});\n    adb.curDeviceId.should.equal('emulator-1234');\n    adb.executable.defaultArgs.should.include('emulator-1234');\n    adb.emulatorPort.should.equal(1234);\n  });\n  it('setEmulatorPort should change emulator port', () => {\n    adb.setEmulatorPort(5554);\n    adb.emulatorPort.should.equal(5554);\n  });\n}));\n\ndescribe('System calls',  withMocks({adb, B}, (mocks) => {\n  it('fileExists should return true for if ls returns', async () => {\n    mocks.adb.expects(\"ls\")\n      .once().withExactArgs('foo')\n      .returns(['bar']);\n    await adb.fileExists(\"foo\").should.eventually.equal(true);\n    mocks.adb.verify();\n  });\n  it('ls should return list', async () => {\n    mocks.adb.expects(\"shell\")\n      .once().withExactArgs(['ls', 'foo'])\n      .returns('bar');\n    let list = await adb.ls(\"foo\");\n    list.should.deep.equal(['bar']);\n    mocks.adb.verify();\n  });\n  it('reboot should call stop and start using shell', async () => {\n    mocks.adb.expects(\"shell\")\n      .once().withExactArgs(['stop']);\n    mocks.adb.expects(\"setDeviceProperty\")\n      .once().withExactArgs('sys.boot_completed', 0);\n    mocks.adb.expects(\"shell\")\n      .once().withExactArgs(['start']);\n    mocks.adb.expects(\"getDeviceProperty\")\n      .once().withExactArgs('sys.boot_completed')\n      .returns('1');\n    mocks.B.expects(\"delay\")\n      .once().withExactArgs(2000);\n    await adb.reboot().should.eventually.not.be.rejected;\n    mocks.adb.verify();\n    mocks.B.verify();\n  });\n}));\n"]}