Best JavaScript code snippet using appium-android-driver
migrate.js
Source:migrate.js
1const async = require('async');2const _ = require('lodash');3const crypto = require('crypto');4const debug = require('debug')('marv:migrate');5function migrate(...args) {6 if (args.length === 3) return migrate(args[0], args[1], {}, args[2]);7 const [migrations, driver, options, cb] = args;8 let connected = false;9 async.seq(10 connect,11 ensure,12 lock,13 getMigrations,14 namespaceMigrations15 )((err) => {16 if (!connected) return cb(err);17 async.seq(18 unlock,19 disconnect20 )(() => {21 cb(err);22 });23 });24 function connect(cb) {25 debug('Connecting driver');26 driver.connect((err) => {27 if (err) return cb(err);28 connected = true;29 cb();30 });31 }32 function ensure(cb) {33 debug('Ensuring migrations');34 driver.ensureMigrations(guard(cb));35 }36 function lock(cb) {37 debug('Locking migrations');38 driver.lockMigrations(guard(cb));39 }40 function getMigrations(cb) {41 debug('Getting existing migrations');42 driver.getMigrations(cb);43 }44 function namespaceMigrations(existingMigrations, cb) {45 debug('Namespacing existing migrations');46 const namespacedExisting = _.groupBy(existingMigrations, 'namespace');47 const namespacedMigrations = _(migrations).map(stampDefaultNamespace).groupBy('namespace').value();48 async.eachSeries(49 _.keys(namespacedMigrations),50 (namespace, cb) => {51 const deltas = calculateDeltas(namespace, namespacedExisting[namespace], namespacedMigrations[namespace]);52 runMigrations(namespace, deltas, cb);53 },54 cb55 );56 }57 function calculateDeltas(namespace, existingMigrations, proposedMigrations) {58 debug('Calculating deltas for namespace: %s', namespace);59 const watermark = _.sortBy(existingMigrations, 'level').reverse()[0];60 watermark ? debug('Current level is %d', watermark.level) : debug('No existing migrations');61 return _.chain(proposedMigrations)62 .filter((migration) => !watermark || migration.level > watermark.level)63 .sortBy('level')64 .map((migration) => _.merge({ timestamp: new Date(), checksum: checksum(migration.script) }, migration))65 .value();66 }67 function checksum(script) {68 return crypto.createHash('md5').update(script, 'utf8').digest('hex');69 }70 function runMigrations(namespace, migrations, cb) {71 debug('Running %d migrations for namespace: %s', migrations.length, namespace);72 async.eachSeries(73 migrations,74 (migration, cb) => {75 if (migration.hasOwnProperty('audit') && !migration.hasOwnProperty('directives')) {76 if (!options.quiet) console.warn("The 'audit' option is deprecated. Please use 'directives.audit' instead. You can disable this warning by setting 'quiet' to true.");77 _.set(migration, 'directives.audit', migration.audit);78 }79 driver.runMigration(migration, cb);80 },81 guard(cb)82 );83 }84 function unlock(cb) {85 debug('Unlocking migrations');86 driver.unlockMigrations(guard(cb));87 }88 function disconnect(cb) {89 debug('Disconnecting driver');90 driver.disconnect(guard(cb));91 }92 function guard(cb) {93 return function (err) {94 cb(err);95 };96 }97 function stampDefaultNamespace(migration) {98 return _.isNil(migration.namespace) ? _.assign({}, migration, { namespace: 'default' }) : migration;99 }100}...
itemsController.js
Source:itemsController.js
1angular.module("gdCameApp").controller("ItemsController",2[3 "$rootScope", "$scope", "gameData", "gdCameApiService",4 function ($rootScope, $scope, gameData, gdCameApiService) {5 $scope.items = [];6 $scope.itemsGroups = [];7 gameData.then(function (data) {8 $scope.items = data.items;9 var indexInGroup = 0;10 var itemsGroup = [];11 $scope.items.forEach(function (value, index) {12 if (indexInGroup === 4) {13 $scope.itemsGroups.push(itemsGroup);14 itemsGroup = [];15 indexInGroup = 0;16 }17 itemsGroup.push(value);18 indexInGroup++;19 });20 if (itemsGroup.length > 0) {21 itemsGroup.push(new Array(4 - itemsGroup.length));22 $scope.itemsGroups.push(itemsGroup);23 }24 });25 $scope.$on("update.items",26 function (event, value) {27 $scope.items = value.items;28 });29 $scope.buyFundDriver = function (fundDriverId) {30 var oldFundDriver = $scope.items.filter(function (item, index) {31 return item.id === fundDriverId;32 })[0];33 if (oldFundDriver && oldFundDriver.unlockBalance > $rootScope.gameData.cash.counters[0].value) {34 return;35 }36 gdCameApiService.buyFundDriver(fundDriverId)37 .then(function (value) {38 if (value.data == undefined) return;39 var itemIndex;40 var oldFundDriver = $scope.items.filter(function (item, index) {41 itemIndex = index;42 return item.id === value.data.itemBuyInfo.id;43 })[0];44 if (oldFundDriver != undefined) {45 oldFundDriver.bought = value.data.itemBuyInfo.bought;46 oldFundDriver.price = value.data.itemBuyInfo.price;47 if (value.data.modifiedCountersInfo != undefined) {48 $rootScope.$broadcast("counters.update", value.data.modifiedCountersInfo);49 }50 }51 });52 };53 }...
dataHandler.js
Source:dataHandler.js
1/**2 * (C) Copyright 2015 Manuel Martins.3 *4 * This module is inspired by json_file_system.5 * (json_file_system is Copyright (c) 2014 Jalal Hejazi,6 * Licensed under the MIT license.)7 *8 * Licensed under the Apache License, Version 2.0 (the "License");9 * you may not use this file except in compliance with the License.10 * You may obtain a copy of the License at11 *12 * http://www.apache.org/licenses/LICENSE-2.013 *14 * Unless required by applicable law or agreed to in writing, software15 * distributed under the License is distributed on an "AS IS" BASIS,16 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.17 * See the License for the specific language governing permissions and18 * limitations under the License.19 *20 * Created by: ManuelMartins21 * Created on: 26-01-201622 *23 */24'use strict';25var Memory = require('./memory');26var Disk = require('./disk');27/**28 * Provides the most common I/O operations.29 *30 * @param {object} options31 * @param {object} options.db32 * @param {object} options.db._33 * @param {string} options.db._._driver34 * @constructor35 */36function DataHandler(options) {37 options = options || {};38 var dataHandler = options.db._db._driver || 'disk';39 switch (dataHandler) {40 // load the driver to be used just once41 case 'memory':42 this.dataHandlerDriver = new Memory(options);43 break;44 case 'disk':45 default:46 this.dataHandlerDriver = new Disk(options);47 }48}49/**50 * Writes a list of objects to the data driver51 *52 * @param content the content to write53 * @param callback54 */55DataHandler.prototype.set = function write(content, callback) {56 return this.dataHandlerDriver.set(content, callback);57};58/**59 * Reads a list of objects from the data driver60 *61 * @param callback62 */63DataHandler.prototype.get = function read(callback) {64 return this.dataHandlerDriver.get(callback);65};66/**67 * Locks the data provider68 *69 * @param callback70 */71DataHandler.prototype.lock = function read(callback) {72 return this.dataHandlerDriver.lock(callback);73};74/**75 * Unlocks the data provider76 *77 * @param callback78 */79DataHandler.prototype.unlock = function read(callback) {80 return this.dataHandlerDriver.unlock(callback);81};...
index.js
Source:index.js
1'use strict';2(function () {3 function getDriver (callback) {4 var interval = window.setInterval(function () {5 var testCafeDriver = window['%testCafeDriverInstance%'];6 if (testCafeDriver) {7 window.clearInterval(interval);8 callback(testCafeDriver);9 }10 }, 50);11 }12 // NOTE: enable interaction with a page when the last test is completed13 var UNLOCK_PAGE_FLAG = 'testcafe-live|driver|unlock-page-flag';14 // TestCafe > 0.18.5 required15 getDriver(function (testCafeDriver) {16 var testCafeCore = window['%testCafeCore%'];17 var hammerhead = window['%hammerhead%'];18 testCafeDriver.setCustomCommandHandlers('unlock-page', function () {19 testCafeCore.disableRealEventsPreventing();20 testCafeDriver.contextStorage.setItem(UNLOCK_PAGE_FLAG, true);21 return hammerhead.Promise.resolve();22 });23 var chain = testCafeDriver.contextStorage ? hammerhead.Promise.resolve() : testCafeDriver.readyPromise;24 chain.then(function () {25 if (testCafeDriver.contextStorage.getItem(UNLOCK_PAGE_FLAG))26 testCafeCore.disableRealEventsPreventing();27 });28 });...
First.js
Source:First.js
1//-- To Lock a Device--2//driver.lock(5);3//--To Unlock a Device--4//driver.unlock(5);5//boolean value true / false6//driver.isLocked();7//Console log to print line8//To get Current Activity9console.log("Hello Ritzz", driver.getCurrentActivity());10//--To get Current Package11driver.getCurrentPackage();12//--To install Application into Device13driver.installApp(c://rit/flipkart.apk)14 //to check whether this app is installed or not package 15 driver.isAppInstalled(appId)16//to Terminate app17driver.terminateApp(appId)18//--To hide keyword ...
privacy.steps.js
Source:privacy.steps.js
...7When(/^I lock device$/, async () => {8 await driver.lock();9});10When(/^I unlock device$/, async () => {11 await driver.unlock();12});13When(/^I validate the privacy notice page$/, async () => {14 expect(PrivacyPage.screenTitle).toHaveText('Privacy Notice')15});16When(17 /^I tap on the privacy policy button$/,18 async () => {19 await PrivacyPage.txtAccept_tap();20 },21);22Then(/^I should be on the login screen$/, async () => {23 await expect(LoginPage.txtWelcome).toHaveText('Welcome!')24});25Then(/^I close the app$/, async () => {...
steps.js
Source:steps.js
...7When(/^I lock device$/, async () => {8 await driver.lock();9});10When(/^I unlock device$/, async () => {11 await driver.unlock();12});13When(/^I navigate to login tab$/, async () => {14 await LandingPage.btnLogin_tap();15});16When(17 /^I initiate login with ([^"]*)? and ([^"]*)?$/,18 async (email, password) => {19 await LoginPage.txtEmail_setText(email);20 await LoginPage.txtPassword_setText(password);21 await LoginPage.btnLogin_tap();22 },23);24Then(/^I close the app$/, async () => {25 await driver.closeApp();...
exercice3.js
Source:exercice3.js
...7 it('Can lock device', function() {8 driver.lock()9 driver.pause(3000)10 expect(driver.isLocked()).toBe(true)11 driver.unlock()12 })13 it('Can open settings app', function() {14 // android15 // adb shell dumpsys window windows | grep -E 'mCurrentFocus'16 driver.startActivity('com.android.settings', 'com.android.settings.Settings')17 driver.pause(3000)18 // ios19 // https://emm.how/t/ios-12-list-of-default-apps-and-bundle-id-s/79020 // driver.launchApp({ bundleId: "com.apple.Preferences" })21 })...
Using AI Code Generation
1var webdriverio = require('webdriverio');2var options = { desiredCapabilities: {browserName: 'Chrome'} };3 .remote(options)4 .init()5 .getTitle().then(function(title) {6 console.log('Title was: ' + title);7 })8 .end();9var webdriverio = require('webdriverio');10var options = { desiredCapabilities: {browserName: 'Chrome'} };11 .remote(options)12 .init()13 .getTitle().then(function(title) {14 console.log('Title was: ' + title);15 })16 .end();17var webdriverio = require('webdriverio');18var options = { desiredCapabilities: {browserName: 'Chrome'} };19 .remote(options)20 .init()21 .getTitle().then(function(title) {22 console.log('Title was: ' + title);23 })24 .end();25var webdriverio = require('webdriverio');26var options = { desiredCapabilities: {browserName: 'Chrome'} };27 .remote(options)28 .init()29 .getTitle().then(function(title) {30 console.log('Title was: ' + title);31 })32 .end();33var webdriverio = require('webdriverio');34var options = { desiredCapabilities: {browserName: 'Chrome'} };35 .remote(options)36 .init()37 .getTitle().then(function(title) {38 console.log('Title was: ' + title);39 })40 .end();41var webdriverio = require('webdriverio');42var options = { desiredCapabilities: {browserName: 'Chrome'} };43 .remote(options)44 .init()
Using AI Code Generation
1var webdriver = require('selenium-webdriver');2var driver = new webdriver.Builder().withCapabilities(webdriver.Capabilities.android()).build();3driver.sleep(5000);4driver.unlock();5driver.sleep(5000);6driver.quit();7var webdriver = require('selenium-webdriver');8var driver = new webdriver.Builder().withCapabilities(webdriver.Capabilities.android()).build();9driver.sleep(5000);10driver.lock();11driver.sleep(5000);12driver.quit();13var webdriver = require('selenium-webdriver');14var driver = new webdriver.Builder().withCapabilities(webdriver.Capabilities.android()).build();15driver.sleep(5000);16driver.hideKeyboard();17driver.sleep(5000);18driver.quit();19var webdriver = require('selenium-webdriver');20var driver = new webdriver.Builder().withCapabilities(webdriver.Capabilities.android()).build();21driver.sleep(5000);22driver.toggleWifi();23driver.sleep(5000);24driver.quit();25var webdriver = require('selenium-webdriver');26var driver = new webdriver.Builder().withCapabilities(webdriver.Capabilities.android()).build();27driver.sleep(5000);28driver.toggleLocationServices();29driver.sleep(5000);30driver.quit();31var webdriver = require('selenium-webdriver');32var driver = new webdriver.Builder().withCapabilities(webdriver.Capabilities.android()).build();33driver.sleep(5000);34driver.pressKeyCode(4);35driver.sleep(5000);36driver.quit();37var webdriver = require('selenium-webdriver');38var driver = new webdriver.Builder().withCapabilities(webdriver.Capabilities.android()).build();39driver.sleep(5000);
Using AI Code Generation
1var wd = require('wd');2var _ = require('underscore');3var assert = require('assert');4var Q = require('q');5var androidDriver = require('appium-android-driver');6var androidDriver = new androidDriver();7var desiredCaps = {8};9var driver = wd.promiseChainRemote('localhost', 4723);10driver.init(desiredCaps)11 .then(function() {12 return driver.unlock();13 }).catch(function(err) {14 console.log(err);15 });16module.exports = function unlock (keycode) {17 var adb = this.adb;18 var unlockTypes = ['pin', 'pattern', 'password', 'fingerprint', 'face'];19 var unlockType = unlockTypes.filter(function (type) {20 return adb.isScreenLocked(type);21 })[0];22 if (!unlockType) {23 return;24 }25 return adb.unlockScreen(unlockType, keycode);26};27helpers.unlockScreen = function (unlockType, keycode) {28 var adb = this.adb;29 var unlockTypes = ['pin', 'pattern', 'password', 'fingerprint', 'face'];30 if (!unlockTypes.includes(unlockType)) {31 throw new Error(`Invalid unlock type: ${unlockType}`);32 }33 return adb.shell(['wm', 'dismiss-keyguard'])34 .then(() => adb.waitForUnlock(unlockType))35 .then(() => adb.sendUnlockCommand(unlockType, keycode));36};37methods.waitForUnlock = async function (unlockType) {38 if (!_.contains(['pin', 'pattern', 'password', 'fingerprint', 'face'], unlockType)) {39 throw new Error(`Invalid unlock type: ${unlockType}`);40 }41 let cmd = `dumpsys window policy|grep isStatusBarKeyguard`;42 let result = await this.shell(cmd);43 if (unlockType === "fingerprint") {
Using AI Code Generation
1var webdriverio = require('webdriverio');2var options = {3 desiredCapabilities: {4 }5};6 .remote(options)7 .init()8 .then(function () {9 return this.unlock();10 })11 .then(function () {12 return this.pause(3000);13 })14 .end();
Using AI Code Generation
1var driver = new webdriver.Builder()2 .forBrowser('chrome')3 .build();4driver.unlock().then(function() {5 console.log('Unlocked the device');6});7driver.quit();
Using AI Code Generation
1var wd = require('wd');2var assert = require('assert');3var capabilities = {4};5var driver = wd.promiseChainRemote("localhost", 4723);6driver.init(capabilities).then(function() {7 return driver.unlock();8}).then(function() {9}).fin(function() {10 return driver.quit();11}).done();12info: Welcome to Appium v1.0.0 (REV d8d2b0a1b2f1d7a9b9d0f7c9a6a5b6f8d8e2d6c1)
Using AI Code Generation
1How to use driver.lock() method in Appium Android Driver2How to use driver.unlock() method in Appium Android Driver3How to use driver.isLocked() method in Appium Android Driver4How to use driver.backgroundApp() method in Appium Android Driver5How to use driver.startActivity() method in Appium Android Driver6How to use driver.getDeviceTime() method in Appium Android Driver7How to use driver.getPerformanceData() method in Appium Android Driver
Learn to execute automation testing from scratch with LambdaTest Learning Hub. Right from setting up the prerequisites to run your first automation test, to following best practices and diving deeper into advanced test scenarios. LambdaTest Learning Hubs compile a list of step-by-step guides to help you be proficient with different test automation frameworks i.e. Selenium, Cypress, TestNG etc.
You could also refer to video tutorials over LambdaTest YouTube channel to get step by step demonstration from industry experts.
Get 100 minutes of automation test minutes FREE!!