UNPKG

appium-adb-test

Version:

Android Debug Bridge interface

333 lines (279 loc) 32 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;charset=utf8;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';\r\nimport chaiAsPromised from 'chai-as-promised';\r\nimport ADB from '../..';\r\nimport * as teen_process from 'teen_process';\r\nimport { withMocks } from 'appium-test-support';\r\nimport B from 'bluebird';\r\n\r\n\r\nchai.use(chaiAsPromised);\r\nconst adb = new ADB();\r\nadb.executable.path = 'adb_path';\r\nconst avdName = 'AVD_NAME';\r\n\r\ndescribe('System calls', withMocks({teen_process}, (mocks) => {\r\n  it('getConnectedDevices should get all connected devices', async () => {\r\n    mocks.teen_process.expects(\"exec\")\r\n      .once().withExactArgs(adb.executable.path, ['devices'])\r\n      .returns({stdout:\"List of devices attached \\n emulator-5554\tdevice\"});\r\n    let devices = await adb.getConnectedDevices();\r\n    devices.should.have.length.above(0);\r\n    mocks.teen_process.verify();\r\n  });\r\n  it('getConnectedDevices should fail when adb devices returns unexpected output', async () => {\r\n    mocks.teen_process.expects(\"exec\")\r\n      .once().withExactArgs(adb.executable.path, ['devices'])\r\n      .returns({stdout:\"foobar\"});\r\n    await adb.getConnectedDevices().should.eventually.be\r\n                                   .rejectedWith(\"Unexpected output while trying to get devices\");\r\n    mocks.teen_process.verify();\r\n  });\r\n  it('getDevicesWithRetry should fail when there are no connected devices', async () => {\r\n    mocks.teen_process.expects(\"exec\")\r\n      .atLeast(2).withExactArgs(adb.executable.path, ['devices'])\r\n      .returns({stdout:\"List of devices attached\"});\r\n    await adb.getDevicesWithRetry(1000).should.eventually.be\r\n                                       .rejectedWith(\"Could not find a connected Android device.\");\r\n    mocks.teen_process.verify();\r\n  });\r\n  it('getDevicesWithRetry should fail when adb devices returns unexpected output', async () => {\r\n    mocks.teen_process.expects(\"exec\")\r\n      .atLeast(2).withExactArgs(adb.executable.path, ['devices'])\r\n      .returns({stdout:\"foobar\"});\r\n    await adb.getDevicesWithRetry(1000).should.eventually.be\r\n                                       .rejectedWith(\"Could not find a connected Android device.\");\r\n    mocks.teen_process.verify();\r\n  });\r\n  it('getDevicesWithRetry should get all connected devices', async () => {\r\n    mocks.teen_process.expects(\"exec\")\r\n      .once().withExactArgs(adb.executable.path, ['devices'])\r\n      .returns({stdout:\"List of devices attached \\n emulator-5554\tdevice\"});\r\n    let devices = await adb.getDevicesWithRetry(1000);\r\n    devices.should.have.length.above(0);\r\n    mocks.teen_process.verify();\r\n  });\r\n  it('getDevicesWithRetry should get all connected devices second time', async () => {\r\n    mocks.teen_process.expects(\"exec\")\r\n      .onCall(0)\r\n      .returns({stdout:\"Foobar\"});\r\n    mocks.teen_process.expects(\"exec\")\r\n      .withExactArgs(adb.executable.path, ['devices'])\r\n      .returns({stdout:\"List of devices attached \\n emulator-5554\tdevice\"});\r\n    let devices = await adb.getDevicesWithRetry(2000);\r\n    devices.should.have.length.above(0);\r\n    mocks.teen_process.verify();\r\n  });\r\n  it('getDevicesWithRetry should fail when exec throws an error', async () => {\r\n    mocks.teen_process.expects(\"exec\")\r\n      .atLeast(2)\r\n      .throws(\"Error foobar\");\r\n    await adb.getDevicesWithRetry(1000).should.eventually.be\r\n                                       .rejectedWith(\"Could not find a connected Android device.\");\r\n    mocks.teen_process.verify();\r\n  });\r\n  it('setDeviceId should set the device id', () => {\r\n    adb.setDeviceId('foobar');\r\n    adb.curDeviceId.should.equal('foobar');\r\n    adb.executable.defaultArgs.should.include('foobar');\r\n  });\r\n  it('setDevice should set the device id and emu port from obj', () => {\r\n    adb.setDevice({udid: 'emulator-1234'});\r\n    adb.curDeviceId.should.equal('emulator-1234');\r\n    adb.executable.defaultArgs.should.include('emulator-1234');\r\n    adb.emulatorPort.should.equal(1234);\r\n  });\r\n  it('setEmulatorPort should change emulator port', () => {\r\n    adb.setEmulatorPort(5554);\r\n    adb.emulatorPort.should.equal(5554);\r\n  });\r\n  describe('createSubProcess', () => {\r\n    it('should return an instance of SubProcess', () => {\r\n      adb.createSubProcess([]).should.be.an.instanceof(teen_process.SubProcess);\r\n    });\r\n  });\r\n}));\r\n\r\ndescribe('System calls',  withMocks({adb, B}, (mocks) => {\r\n  it('fileExists should return true for if ls returns', async () => {\r\n    mocks.adb.expects(\"ls\")\r\n      .once().withExactArgs('foo')\r\n      .returns(['bar']);\r\n    await adb.fileExists(\"foo\").should.eventually.equal(true);\r\n    mocks.adb.verify();\r\n  });\r\n  it('ls should return list', async () => {\r\n    mocks.adb.expects(\"shell\")\r\n      .once().withExactArgs(['ls', 'foo'])\r\n      .returns('bar');\r\n    let list = await adb.ls(\"foo\");\r\n    list.should.deep.equal(['bar']);\r\n    mocks.adb.verify();\r\n  });\r\n  it('reboot should call stop and start using shell', async () => {\r\n    mocks.adb.expects(\"shell\")\r\n      .once().withExactArgs(['stop']);\r\n    mocks.adb.expects(\"setDeviceProperty\")\r\n      .once().withExactArgs('sys.boot_completed', 0);\r\n    mocks.adb.expects(\"shell\")\r\n      .once().withExactArgs(['start']);\r\n    mocks.adb.expects(\"getDeviceProperty\")\r\n      .once().withExactArgs('sys.boot_completed')\r\n      .returns('1');\r\n    mocks.B.expects(\"delay\")\r\n      .once().withExactArgs(2000);\r\n    await adb.reboot().should.eventually.not.be.rejected;\r\n    mocks.adb.verify();\r\n    mocks.B.verify();\r\n  });\r\n  it('getRunningAVD should get connected avd', async () => {\r\n    let udid = 'emulator-5554';\r\n    let port = 5554;\r\n    let emulator = {udid, port};\r\n    mocks.adb.expects(\"getConnectedEmulators\")\r\n      .once().withExactArgs()\r\n      .returns([emulator]);\r\n    mocks.adb.expects(\"setEmulatorPort\")\r\n      .once().withExactArgs(port);\r\n    mocks.adb.expects(\"sendTelnetCommand\")\r\n      .once().withExactArgs(\"avd name\")\r\n      .returns(avdName);\r\n    mocks.adb.expects(\"setDeviceId\")\r\n      .once().withExactArgs(udid);\r\n    (await adb.getRunningAVD(avdName)).should.equal(emulator);\r\n    mocks.adb.verify();\r\n  });\r\n  it('getRunningAVD should return null when expected avd is not connected', async () => {\r\n    let udid = 'emulator-5554';\r\n    let port = 5554;\r\n    let emulator = {udid, port};\r\n    mocks.adb.expects(\"getConnectedEmulators\")\r\n      .once().withExactArgs()\r\n      .returns([emulator]);\r\n    mocks.adb.expects(\"setEmulatorPort\")\r\n      .once().withExactArgs(port);\r\n    mocks.adb.expects(\"sendTelnetCommand\")\r\n      .once().withExactArgs(\"avd name\")\r\n      .returns('OTHER_AVD');\r\n    chai.expect(await adb.getRunningAVD(avdName)).to.be.null;\r\n    mocks.adb.verify();\r\n  });\r\n  it('getRunningAVD should return null when no avd is connected', async () => {\r\n    mocks.adb.expects(\"getConnectedEmulators\")\r\n      .once().withExactArgs()\r\n      .returns([]);\r\n    chai.expect(await adb.getRunningAVD(avdName)).to.be.null;\r\n    mocks.adb.verify();\r\n  });\r\n}));\r\n"],"sourceRoot":"..\\..\\.."}