Best JavaScript code snippet using appium-xcuitest-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
1const wd = require('wd');2async function main() {3 await driver.init({4 });5 await driver.unlock();6}7main();8[HTTP] {}9[debug] [W3C (6e9d7f9c)] Encountered internal error running command: Error: Command 'idevicediagnostics' not found. Is it installed?10[debug] [W3C (6e9d7f9c)] at IosRealDevice.unlock (/usr/local/lib/node_modules/appium/node_modules/appium-xcuitest-driver/lib/real-device-management/ios-real-device-management.js:60:11)11[debug] [W3C (6e9d7f9c)] at XCUITestDriver.unlock (/usr/local/lib/node_modules/appium/node_modules/appium-xcuitest-driver/lib/driver.js:1966:7)12[debug] [W3C (6e9d7f9c)] at XCUITestDriver.executeCommand (/usr/local/lib/node_modules/appium/node_modules/appium-xcuitest-driver/lib/driver.js:384:7)13[debug] [W3C (6e9d7f9c)] at AppiumDriver.executeCommand (/usr/local/lib/node_modules/appium/lib/appium.js:500:36)14[debug] [W3C (6e9d7f9c)] at process._tickCallback (internal/process/next_tick.js:68:7)
Using AI Code Generation
1var wd = require('wd');2driver.init({3}).then(function () {4 return driver.unlock();5}).then(function () {6 console.log('Unlocked');7});8{9 "scripts": {10 },11 "dependencies": {12 }13}14var wd = require('wd');15driver.unlock().then(function () {16 return driver.init({17 });18}).then(function () {19 console.log('Unlocked');20});21var wd = require('wd');
Using AI Code Generation
1const wd = require('wd');2const driver = wd.promiseChainRemote({3});4const caps = {5};6driver.init(caps)7 .then(() => driver.unlock())8 .then(() => driver.quit());9const wd = require('wd');10const driver = wd.promiseChainRemote({11});12const caps = {13};14driver.init(caps)15 .then(() => driver.unlock())16 .then(() => driver.quit());17const wd = require('wd');18const driver = wd.promiseChainRemote({19});20const caps = {21};22driver.init(caps)23 .then(() => driver.unlock())24 .catch((err) => {
Using AI Code Generation
1var wd = require('wd');2var assert = require('assert');3var path = require('path');4var fs = require('fs');5var desired = {6};7var driver = wd.promiseChainRemote('localhost', 4723);8driver.init(desired).then(function () {9 return driver.unlock();10}).then(function () {11 return driver.quit();12});13var wd = require('wd');14var assert = require('assert');15var path = require('path');16var fs = require('fs');17var desired = {18};19var driver = wd.promiseChainRemote('localhost', 4723);20driver.init(desired).then(function () {21 return driver.lock();22}).then(function () {23 return driver.quit();24});25var wd = require('wd');26var assert = require('assert');27var path = require('path');28var fs = require('fs');29var desired = {30};31var driver = wd.promiseChainRemote('localhost', 4723);32driver.init(desired).then(function () {33 return driver.touchId(true);
Using AI Code Generation
1var webdriver = require('selenium-webdriver');2var appium = require('appium');3var driver = new webdriver.Builder().forBrowser('selenium-webdriver').build();4var desiredCaps = {5};6driver.init(desiredCaps).then(function() {7 driver.unlock();8});
Using AI Code Generation
1const wd = require('wd');2const chai = require('chai');3const chaiAsPromised = require('chai-as-promised');4const assert = chai.assert;5const expect = chai.expect;6chai.use(chaiAsPromised);7async function unlockScreen() {8 const driver = await wd.promiseChainRemote({9 });10 const desiredCaps = {11 };12 await driver.init(desiredCaps);13 await driver.sleep(5000);14 await driver.unlock();15 console.log('Screen unlocked successfully');16}17unlockScreen();
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!!