UNPKG

appium-adb

Version:

Android Debug Bridge interface

332 lines (279 loc) 31.6 kB
'use strict'; 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'; var avdName = 'AVD_NAME'; 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('createSubProcess', function () { it('should return an instance of SubProcess', function () { adb.createSubProcess([]).should.be.an['instanceof'](teen_process.SubProcess); }); }); })); 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); }); it('getRunningAVD should get connected avd', function callee$1$0() { var udid, port, emulator; return _regeneratorRuntime.async(function callee$1$0$(context$2$0) { while (1) switch (context$2$0.prev = context$2$0.next) { case 0: udid = 'emulator-5554'; port = 5554; emulator = { 'udid': udid, 'port': port }; mocks.adb.expects("getConnectedEmulators").once().withExactArgs().returns([emulator]); mocks.adb.expects("setEmulatorPort").once().withExactArgs(port); mocks.adb.expects("sendTelnetCommand").once().withExactArgs("avd name").returns(avdName); mocks.adb.expects("setDeviceId").once().withExactArgs(udid); context$2$0.next = 9; return _regeneratorRuntime.awrap(adb.getRunningAVD(avdName)); case 9: context$2$0.t0 = emulator; context$2$0.sent.should.equal(context$2$0.t0); mocks.adb.verify(); case 12: case 'end': return context$2$0.stop(); } }, null, _this); }); it('getRunningAVD should return null when expected avd is not connected', function callee$1$0() { var udid, port, emulator; return _regeneratorRuntime.async(function callee$1$0$(context$2$0) { while (1) switch (context$2$0.prev = context$2$0.next) { case 0: udid = 'emulator-5554'; port = 5554; emulator = { 'udid': udid, 'port': port }; mocks.adb.expects("getConnectedEmulators").once().withExactArgs().returns([emulator]); mocks.adb.expects("setEmulatorPort").once().withExactArgs(port); mocks.adb.expects("sendTelnetCommand").once().withExactArgs("avd name").returns('OTHER_AVD'); context$2$0.t0 = _chai2['default']; context$2$0.next = 9; return _regeneratorRuntime.awrap(adb.getRunningAVD(avdName)); case 9: context$2$0.t1 = context$2$0.sent; context$2$0.t0.expect.call(context$2$0.t0, context$2$0.t1).to.be['null']; mocks.adb.verify(); case 12: case 'end': return context$2$0.stop(); } }, null, _this); }); it('getRunningAVD should return null when no avd is connected', 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("getConnectedEmulators").once().withExactArgs().returns([]); context$2$0.t0 = _chai2['default']; context$2$0.next = 4; return _regeneratorRuntime.awrap(adb.getRunningAVD(avdName)); case 4: context$2$0.t1 = context$2$0.sent; context$2$0.t0.expect.call(context$2$0.t0, context$2$0.t1).to.be['null']; mocks.adb.verify(); case 7: 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';\nconst avdName = 'AVD_NAME';\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  describe('createSubProcess', () => {\n    it('should return an instance of SubProcess', () => {\n      adb.createSubProcess([]).should.be.an.instanceof(teen_process.SubProcess);\n    });\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  it('getRunningAVD should get connected avd', async () => {\n    let udid = 'emulator-5554';\n    let port = 5554;\n    let emulator = {'udid': udid, 'port': port};\n    mocks.adb.expects(\"getConnectedEmulators\")\n      .once().withExactArgs()\n      .returns([emulator]);\n    mocks.adb.expects(\"setEmulatorPort\")\n      .once().withExactArgs(port);\n    mocks.adb.expects(\"sendTelnetCommand\")\n      .once().withExactArgs(\"avd name\")\n      .returns(avdName);\n    mocks.adb.expects(\"setDeviceId\")\n      .once().withExactArgs(udid);\n    (await adb.getRunningAVD(avdName)).should.equal(emulator);\n    mocks.adb.verify();\n  });\n  it('getRunningAVD should return null when expected avd is not connected', async () => {\n    let udid = 'emulator-5554';\n    let port = 5554;\n    let emulator = {'udid': udid, 'port': port};\n    mocks.adb.expects(\"getConnectedEmulators\")\n      .once().withExactArgs()\n      .returns([emulator]);\n    mocks.adb.expects(\"setEmulatorPort\")\n      .once().withExactArgs(port);\n    mocks.adb.expects(\"sendTelnetCommand\")\n      .once().withExactArgs(\"avd name\")\n      .returns('OTHER_AVD');\n    chai.expect(await adb.getRunningAVD(avdName)).to.be.null;\n    mocks.adb.verify();\n  });\n  it('getRunningAVD should return null when no avd is connected', async () => {\n    mocks.adb.expects(\"getConnectedEmulators\")\n      .once().withExactArgs()\n      .returns([]);\n    chai.expect(await adb.getRunningAVD(avdName)).to.be.null;\n    mocks.adb.verify();\n  });\n}));\n"]}