Skip to content

Run Java and Appium scripts on LambdaTest automation cloud. A sample repo to help you run Java based test scripts in parallel with LambdaTest

Notifications You must be signed in to change notification settings

LambdaTest/LT-appium-java

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

18 Commits
 
 
 
 
 
 

Repository files navigation

How to handle permission pop-ups in Java with Appium on LambdaTest

While performing app automation testing with appium on LambdaTest Grid, you may face a scenario where you would like to automatically handle permission pop-ups. You may choose to either accept all permission pop-ups or dismiss all of them. You can handle the case as mentioned below separately for Android or iOS apps. You can refer to sample test repo here.

Steps:

The following is an example on how to set permissions in the capabilities. You can make the change in the vanilla_android.java and vanilla_ios.java file:

Below is the vanilla_android.java example shown:

public class vanilla_android { public static String userName = System.getenv("LT_USERNAME") == null ? "LT_USERNAME" //Add username here : System.getenv("LT_USERNAME"); public static String accessKey = System.getenv("LT_ACCESS_KEY") == null ? "LT_ACCESS_KEY" //Add accessKey here : System.getenv("LT_ACCESS_KEY"); private static AppiumDriver driver; public static void main(String args[]) throws MalformedURLException, InterruptedException { try { DesiredCapabilities capabilities = new DesiredCapabilities(); capabilities.setCapability("deviceName", "Galaxy S20"); capabilities.setCapability("platformVersion", "11"); capabilities.setCapability("platformName", "Android"); capabilities.setCapability("isRealMobile", true); capabilities.setCapability("app", "APP_ID"); //Enter your app url capabilities.setCapability("deviceOrientation", "PORTRAIT"); capabilities.setCapability("build", "Java Vanilla - iOS"); capabilities.setCapability("name", "Sample Test Java"); capabilities.setCapability("console", true); capabilities.setCapability("network", false); capabilities.setCapability("visual", true); capabilities.setCapability("devicelog", true); //GRANT PERMISSIONS FOR ANDROID capabilities.setCapability("autoGrantPermissions", true); //ACCEPT ALERTS FOR IOS capabilities.setCapability("autoDismissAlerts", true); //DISMISS ALERTS FOR IOS capabilities.setCapability("autoAcceptAlerts", true); driver = new AppiumDriver(new URL("https://" +userName + ":" + accessKey + "@mobile-hub.lambdatest.com/wd/hub"), capabilities); MobileElement color = (MobileElement) driver.findElement(MobileBy.id("com.lambdatest.proverbial:id/color")); color.click(); MobileElement text = (MobileElement) driver.findElement(MobileBy.id("com.lambdatest.proverbial:id/Text")); //Changes the text to proverbial text.click(); //toast is visible MobileElement toast = (MobileElement) driver.findElement(MobileBy.id("com.lambdatest.proverbial:id/toast")); toast.click(); //notification is visible MobileElement notification = (MobileElement) driver.findElement(MobileBy.id("com.lambdatest.proverbial:id/notification")); notification.click(); } catch (AssertionError a) { ((JavascriptExecutor) driver).executeScript("lambda-status=failed"); a.printStackTrace(); } // The driver.quit statement is required, otherwise the test continues to execute, leading to a timeout. driver.quit(); } }

Executing The Test

Execute the following commands to install the required dependencies:

mvn clean install

The tests can be executed in the terminal using the following command:

Android:

mvn test -P android

iOS:

mvn test -P ios

Your test results would be displayed on the test console (or command-line interface if you are using terminal/cmd) and on the LambdaTest App Automation Dashboard.

Additional Links

Documentation & Resources 📚

Visit the following links to learn more about LambdaTest's features, setup and tutorials around test automation, mobile app testing, responsive testing, and manual testing.

LambdaTest Community 👥

The LambdaTest Community allows people to interact with tech enthusiasts. Connect, ask questions, and learn from tech-savvy people. Discuss best practises in web development, testing, and DevOps with professionals from across the globe 🌎

What's New At LambdaTest ❓

To stay updated with the latest features and product add-ons, visit Changelog

About LambdaTest

LambdaTest is a leading test execution and orchestration platform that is fast, reliable, scalable, and secure. It allows users to run both manual and automated testing of web and mobile apps across 3000+ different browsers, operating systems, and real device combinations. Using LambdaTest, businesses can ensure quicker developer feedback and hence achieve faster go to market. Over 500 enterprises and 1 Million + users across 130+ countries rely on LambdaTest for their testing needs.

Features

  • Run Selenium, Cypress, Puppeteer, Playwright, and Appium automation tests across 3000+ real desktop and mobile environments.
  • Real-time cross browser testing on 3000+ environments.
  • Test on Real device cloud
  • Blazing fast test automation with HyperExecute
  • Accelerate testing, shorten job times and get faster feedback on code changes with Test At Scale.
  • Smart Visual Regression Testing on cloud
  • 120+ third-party integrations with your favorite tool for CI/CD, Project Management, Codeless Automation, and more.
  • Automated Screenshot testing across multiple browsers in a single click.
  • Local testing of web and mobile apps.
  • Online Accessibility Testing across 3000+ desktop and mobile browsers, browser versions, and operating systems.
  • Geolocation testing of web and mobile apps across 53+ countries.
  • LT Browser - for responsive testing across 50+ pre-installed mobile, tablets, desktop, and laptop viewports

We are here to help you 🎧

About

Run Java and Appium scripts on LambdaTest automation cloud. A sample repo to help you run Java based test scripts in parallel with LambdaTest

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 8

Languages