How to create shortcut to launch emulator and Simulator ?


To create shortcut for emulator launch
  
  STEP 1: Identify list of emualtors available into system
  
  Open Terminal and execute following command
  
  emulator -list-avds
  
  ouput :
  
  
STEP 2: Create a batch file to launch emulator Open TextEdit Add following commands Note: Add emulator name which we want to launch
And Save file as text file STEP 3: Provide persmission to launch file using bash shell First go to the directory where file has saved cd /Users/apple/Desktop/DeviceLaunch/
Then provide permissions chmod +x ./androidAPI31device.txt Note: This will give exec permission to user, group and other, so beware of possible security issues. So we can use chmod u+x ./androidAPI31device.txt, This will grant exec permission only to user
STEP 4: Set default file open in Terminal Right Click on file -> Open with " Other "-> Enable " All files" option-> Search " Terminal " -> Ticked always open with option and Click on Open StEP 3: Launch Emulator Just dobule clicked on the file and emulator will be launched
To create shortcut for simulator launch STEP 1: Identify list of emualtors available into system Open Terminal and execute following command xcrun simctl list ouput :
STEP 2: Create a batch file to launch simulator Open TextEdit Add following commands #! /bin/bash open -a Simulator.app
STEP 3: Provide persmission to launch file using bash shell First go to the directory where file has saved cd /Users/apple/Desktop/DeviceLaunch/
Then provide permissions chmod +x ./iOS14_5Simulator.txt STEP 4: Set default file open in Terminal Right Click on file -> Open with " Other "-> Enable " All files" option-> Search " Terminal " -> Ticked always open with option and Click on Open StEP 3: Launch Simulator Just dobule clicked on the file and Simulator will be launched

How to set PATH variables into macbook ?


 How to set Path variables into mac
  
  Open terminal and hit following command
  
  vim ~/.zshrc
  
  Then Select proper option  Read Only , Edit , Delete etc.
  
  Then Add required varible path
  
  Refer following varibles which is used for Android and iOS automation on macbook
  
  
If VI is not working then hit following command and try commands again. export PATH="/usr/local/bin:/usr/bin:/bin:/usr/sbin:/sbin"

How to identify if an app is native or flutter


 
You can find whether an app is using flutter or not by using the following method,

1) Extract the apk file. You can simply rename the file extension to .zip and extract it.
2) Navigate to the lib folder.
3) You will find a list of subfolders for different architectures.
4) The subfolder will contain a libflutter.so file. This libflutter.so will be present in all 
  flutter apps.

Sauce Lab Cloud APPIUM Automation Demo


First We need to create free trail account on Sauce Lab
  
  https://saucelabs.com/
 
  
Login Sauce Lab Account and Open following url . We will get all necessary steps in below document which is provided by Saucelab
 
  
  https://www.browserstack.com/docs/app-automate/appium/getting-started/java
  
  
We will get sample app for android and iOS on following sauce lab link
  
  https://github.com/saucelabs/sample-app-mobile/releases
  

We will get devices list on following link
  https://saucelabs.com/platform/supported-browsers-devices
Note: Username and Access key is important while performing testing sauce lab
  
  Execution 
  
  

How to install iOS and Android build into Simulator/Emulator through Terminal


  In IOS
We need .app file to install into iPhone Simulator
  
Then Open terminal and follow given below steps
  
  1) Enter following command to get device list
  
  xcrun simctl list
  
  2) Then Copy simualtor UDID which we want to install app
  
  3) Enter following command to install app
  
  xcrun simctl install 700332EF-8DE1-4040-B5F9-CC56D9CB1554 ~/Desktop/Runner.app
  
  where 700332EF-8DE1-4040-B5F9-CC56D9CB1554 is simulator UDID and ~/Desktop/Runner.app is path of .app file
  
  
  In ANDROID,
   We need .apk file to install into android emulator
  
    Then Open terminal and follow given below steps
  
    1) Enter following command to get device list
  
    adb install ~/Desktop/46.apk
  
    where ~/Desktop/46.apk is path of apk
  

Abstarct and Interface Class/ Methods use in Selenium Webdriver


Selenium is an interface and the Class like FirefoxDriver, ChromeDriver, 
  InternetExplorerDriver, SafariDriver and AndroidDriver which implement the 
  Selenium interface has their own implementation for the all the abstract methods
  in Selenium interface. So all the Classes are implementing the same interface to 
  have the same methods across all the browsers but the methods implemented 
  (coding of method body) will be different for FirefoxDriver (to make the automation 
  work for Firefox Browser) and ChromeDriver (methods implemented differently to make
  the automation work on Chrome Browser)
  
  
WebDriver driver = new FirefoxDriver();

Or

WebDriver driver = new ChromeDriver();

Here, WebDriver Is Interface and FirefoxDriver and ChromeDriver are the class files where 
WebDriver Interface Is Implemented.

Use of Collection and Selenium Webdriver

Collections in java is a framework that provides an architecture to store and manipulate the 
group of objects. The Collection helps the user to store only the Object class type, but every 
single class in java is subclass to Object class, which means we can store anything with help 
classes present in the collection.
  
  
Where we use collections in selenium : Whenever we deal with more than one item, then we 
use collections in selenium webdriver. Few places are:
  

when we try to retrieve the more than one match of elements
when we handle multiple tabs/windows
When we retrieve option from the dropdown using getOptions() method
  
  
how to use arraylist in selenium webdriver
As per my knowledge, we do not use ArrayList in selenium, but we do use List. People prefer List 
over ArrayList because when you use a List, you can store a different kind of list categories 
like ArrayList, LinkedList, TreeList so on. But when we use ArrayList, then we can only store 
only the ArrayList type.

This is the primary reason why the findElements method returns List(broad) rather than ArrayList(narrow).
  
  
Now if you are like me then you get this doubt, why cannot I use ArrayList for it instead of List.
So we have to store the value based on the return type only, so when you should store the list of web elements using List only. But I did not mean that we cannot store the list of web elements in ArrayList, but it is not recommended. If you think who cares about the recommendation, then you got to downcast the returned values to store it in ArrayList with selenium.
For example, if we want to verify a value by splitting the string output, then splitting always returns an Array of values., there values will be substrings.
Few things to remember about for each loop: It starts with the keyword for like a normal for-loop. Instead of declaring and initializing a loop counter variable, you declare a variable that is the same type as the base type of the array, followed by a colon, which is then followed by the array name. In the loop body, you can use the loop variable you created rather than using an indexed array element. It's commonly used to iterate over an array or a Collections class (e.g., ArrayList, HashSet) You might need to declare a variable outside the loop if you want to terminate the loop after some iterations how to use Set in selenium webdriver Java Set is a collection of objects that allows no duplicate elements to be stored. Java Set is an interface that extends the Collection interface. Unlike List, Java Set is NOT an ordered collection; its elements does NOT have a particular order. Java Set does NOT provide control over the position where you can insert an element. You cannot access elements by their index and also search elements in the list. Set is used when we are dealing with a unique element or values like window handles, getWindowHandles()returns set of String Set allGUID = driver.getWindowHandles(); how to use the Map in selenium We can use Maps or hashMaps in selenium when we want to read key-pair values; For example, when we read data from the properties files or JSON file, we would be using HashMaps along with Selenium. Maps are perfect to use for key-value association mapping such as dictionaries. The maps are used to perform lookups by keys or when someone wants to retrieve and update elements by keys. Some examples are: A map of error codes and their descriptions. A map of zip codes and cities. A map of managers and employees. Each manager (key) is associated with a list of employees (value) he manages. A map of classes and students. Each class (key) is associated with a list of students (value).

JMeter Jenkins Integration


STEP 1: Install JMeter
  
  https://jmeter.apache.org/download_jmeter.cgi

STEP 2: Create a sample script in jemter
  
Start JMeter
  
Go to the bin folder exist in downloaded JMeter folder and Double click on 
ApacheJMeter.jar
Add Thread Group ex. demo and add Number of threads, remp up time and Loop count
Then Add Http Request
Then add Table and Graph Listener
Then Add some assertion points for request verification ex status code, duration , Size
Then Execute Script
Now save script in to default location . ex /Users/apple/Desktop/apache-jmeter-5.4.1/bin STEP 3: Create job in Jenkins First install Performance Trend Per Test Case plugin from plugin manager Create a free style job ex. jmeter jenkins demo Then add following configuration
cd /Users/apple/Desktop/apache-jmeter-5.4.1/bin sh jmeter.sh -Jjmeter.save.saveservice.output_format=xml -n -t /Users/apple/Desktop/apache-jmeter-5.4.1/bin/Demo.jmx -l /Users/apple/Desktop/apache-jmeter-5.4.1/bin/TestResult1.jtl
first part is jmeter script and another is report generation file name and location
Then add peformance Trend report in post build
Then execute build 3-4 times , we will get following reports
Execution Demo

What is StaleElementReferenceException in Selenium Webdriver

Stale means old, decayed, no longer fresh. Stale Element means an old element or no 
longer available element. Assume there is an element that is found on a web page referenced
as a WebElement in WebDriver. If the DOM changes then the WebElement goes stale. If we try 
to interact with an element which is staled then the StaleElementReferenceException is thrown.
  
  
What are the Causes of StaleElement Exception
We face this stale element reference exception when the element we are interacting with is destroyed 
and then recreated again. When this happens the reference of the element in the DOM becomes stale. 
Hence we are not able to get the reference to the element.
  
  
Cause 1: The referenced web element has been deleted completely. 
Cause 2: The referenced element is no longer attached to the DOM
  

How To Overcome Stale Element Reference Exception in Selenium:
  
Solution 1: Refreshing the web page
driver.navigate().refersh();
driver.findElement(By.xpath("xpath here")).click();
  
Solution 2: Using Try Catch Block
  for(int i=0; i<=2;i++){
  try{
     driver.findElement(By.xpath("xpath here")).click();
     break;
  }
  catch(Exception e){
     Sysout(e.getMessage());
  }
}
                         
Solution 3: Using ExpectedConditions.refreshed                         
  
wait.until(ExpectedConditions.presenceOfElementLocated(By.id("table")));
                         
Solution 4: Using POM
We could avoid StaleElementException using POM. In POM, we use initElements() method which
loads the element but it won’t initialize elements. initElements() 
takes latest address. It initializes during run time when we try to 
perform any action on an element. This process is also known as Lazy Initialization.
                         
                                                 

How To Resolve Element Not Interactable Exception In Selenium

  
What is ‘element not interactable’ exception in selenium? OR
[exception in thread “main” org.openqa.selenium.elementnotinteractableexception: 
 element not interactable]
When a web element is present in the HTML DOM but it is not in the state that can be 
interacted. In other words when element is found but we can’t interact with it, then it throws ElementNotInteractableException.

Reason behind this exception: –
“element not interactable” exception may occur due to various reason.

Element is not visible
Element is present in off screen (After scroll down it will display)
Element is present behind any other element
Element is disable
  
  
Solutions: –

If element is not visible then wait until element is visible. For this we will use wait
command in selenium

WebDriverWait t = new WebDriverWait(driver, timeout); 
t.until(ExpectedConditions.visibilityOf(element));  
t.until(ExpectedConditions.elementToBeClickable(element));

If element is in off screen then we need to scroll down the browser and interact with element.
We will use JavaScriptExecutor interface that helps to execute JavaScript method through Selenium
Webdriver.

JavascriptExecutor Js1 = (JavascriptExecutor) driver;
Js1.executeScript("window.scrollBy(0,1000)");                   //scroll 1000 pixel vertical

How to handle multiple window in selenium

  
import java.util.Iterator; 
import java.util.Set; 
import org.openqa.selenium.By; 
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.chrome.ChromeDriver;

public class WindowHandle_Demo { 
	public static void main(String[] args) throws Exception {


		System.setProperty("webdriver.chrome.driver","Path to the driver"); 
		WebDriver driver = new ChromeDriver();

		driver.manage().window().maximize();

		// Load the website
		driver.get("http://www.naukri.com/");

		// It will return the parent window name as a String
		String parent=driver.getWindowHandle();
	
		Sets=driver.getWindowHandles();

		// Now iterate using Iterator
		Iterator I1= s.iterator();

		while(I1.hasNext())
		{

			String child_window=I1.next();


			if(!parent.equals(child_window))
			{
				driver.switchTo().window(child_window);

				System.out.println(driver.switchTo().window(child_window).getTitle());

				driver.close();
			}

		}
		//switch to the parent window
		driver.switchTo().window(parent);

}
}

Rules for Writing Automated Tests

  
Rules for Writing Automated Tests
  
Rule 1: Prioritize: Most apps include thousands of scenarios. Start by listing
the most important user flows, for example login, add to cart, checkout, etc.
  
Rule 2: Reduce, Recycle, Reuse: Break the user’s scenarios down to simple, single 
purpose, almost atomic flows. e.g. “Create user,” “Login,”  “Send email,” etc. Create a 
test for each of these flows. When completed, compare this to the the user stories.
Naming convention – Defining a good naming convention is an important part. For example,
including the component name in the flow name, which can result in flow structure (e.g 
“Account.login“ and “Account.logout”).
Reuse components. Don’t Copy/paste – for non-experienced developers/testers, a copy/paste 
seems like a reuse. However, the challenge is to update those steps when the flow changes. 
Even a single step/line that repeats in hundreds of tests is a huge hassle.

  
Rule 3: Create Structured, Single-Purpose Tests: Single purpose tests verify one
thing only!. 
  
Rule 4: Tests’ Initial State Should Always be Consistent: Since automated tests always
repeat the same set of steps, they should always start from the same initial state. The most
common maintenance issues when running automated tests are ensuring the integrity of the initial 
state. Since automated tests depend on that state, if it is not consistent test results won’t be
, either. The initial state is usually derived from user previous actions.
  
Rule 5: Compose Complex Tests from Simple Steps: Complex tests should emulate real user 
scenarios, you should prefer composing those test from simple tests parts (shared steps) 
instead of recording the entire scenario directly. Since you already tested all the simple
actions in the simple tests, the complex tests should only fail on integration issues 
  
Rule 6: Add Validations in Turnover Points: Validations are usually used at the end
of the test to signal the test is in a passed/failed state. It is also best to add them
at points of major changes as a checkpoint to stop the test if an action failed. 
  
Rule 7: No Sleep to Improve Stability: Sleep with random duration (what I call magic
numbers) is one of the main sources of flaky tests.The reason to avoid static sleep is you 
rarely know the load of machine upon you run the test on. Only in performance testing do
you have the machine to yourself (knowing for sure all CPU and memory are for you).
  
Rule 8: Use a Minimum Two Levels of Abstractions: If your test is composed mostly of
user interactions, such as clicks and set-text actions, then you’re probably doing something
wrong. If you used low-level frameworks (e.g. Selenium), you might have heard of the PageObject
Design Pattern, which recommends to separate the business logic (e.g. login) from the low-level 
implementation (e.g. set username, set password and click login button). 
  
  
Rule 9: Reduce the Occurrences of Conditions:- A test should have as few as possible 
conditions (if-statements). Those that have many are usually unpredictable (don’t know 
the exact state you’re in) or complex (you might even see loops, too). Try to simplify your tests by:

Start your test at a predefined state;
Disable random popups; and
Disable random A/B testing, and choose a specific flow.
  
Rule 10: Write Independent and Isolated Tests: An important methodology of test 
authoring is creating self contained, independent flows. This allows to run tests in 
high parallelism, which is crucial for scaling the test suites.
  

How to run cuucmber script on multiple browser

 

  We can write start method in base class like below
  
  
  @Before
   public WebDriver start() {

        String webdriver = System.getProperty("browser", "chrome");
        switch(webdriver) {
            case "firefox":
                System.setProperty("webdriver.gecko.driver", System.getProperty("user.dir") + "/geckodriver");
                driver = new FirefoxDriver();
                driver.get("http://live.guru99.com/");
                driver.manage().window().maximize();
                waitDriver = new WebDriverWait(driver, TIMEOUT);
                driver.manage().timeouts().implicitlyWait(TIMEOUT, TimeUnit.SECONDS);
                driver.manage().timeouts().pageLoadTimeout(PAGE_LOAD_TIMEOUT, TimeUnit.SECONDS);
                return driver;
            case "chrome":
                System.setProperty("webdriver.chrome.driver", System.getProperty("user.dir") + "/chromedriver");
                driver = new ChromeDriver();
                driver.get("http://live.guru99.com/");
                driver.manage().window().maximize();
                waitDriver = new WebDriverWait(driver, TIMEOUT);
                driver.manage().timeouts().implicitlyWait(TIMEOUT, TimeUnit.SECONDS);
                driver.manage().timeouts().pageLoadTimeout(PAGE_LOAD_TIMEOUT, TimeUnit.SECONDS);
                return driver;
            default:
                throw new RuntimeException("Unsupported webdriver: " + webdriver);
        }

}
  
  
  Then we can run like mvn test -Dbrowser=chrome or mvn test -Dbrowser=firefox
  
  Default browser we set chrome
  
  mvn test 

Docker - Selenium Grid Web Demo

  
--------------------------------DOCKER INTALLATION----------------------------------------------
Step 1: We need to install docker
  
Go to the docker offical website https://www.docker.com/
Click on Get started button
Then Download docker as per your OS. I have used macOS for demo purpose
  
After downloading, Just install it.
  
  
Step 2:- Create a free account on docker website
  
Step 3:- Check docker installed or not successfully
  
Open terminal and hit following command
  
docker version
We will get docker info Then hit following command to get complete info of docker
docker info
Then try to verify image
docker run hello-world
Then hit following command to get list of images exist into docker container docker run hello-world Step 4: Start docker application and login in.
Now we are going to create selenium grid docker demo
--------------------------------SELENIUM GRID IMAGES INSTALLATION---------------------------------------------- Step 5: First we need to install all required images Go to the google and search
docker selenium
and open first result or docker selenium url https://github.com/SeleniumHQ/docker-selenium Install following docker dependecies to execute Selenium Grid Open terminal and hit following command one by one Selenium hub
docker pull selenium/hub
Selenium firefox node
docker pull selenium/node-firefox
Selenium chrome node
docker pull selenium/node-chrome
Selenium firefox debug
docker pull selenium/node-firefox-debug
Selenium chrome debug
docker pull selenium/node-chrome-debug
Then check list of images, We will get above mentioned all images in result. Same will get in Docker desktop Application
docker images
--------------------------------START HUB AND NODE--------------------------------------------- Step 6: Now we need to start hub and node to execute script Start hub :
docker run -d -p 4545:4444 --name selenium-hub selenium/hub
Note:- Here we can take any name To check hub is started or not, Open browser and enter
http://localhost:4545/
. We will get hub console Start Node for Firefox
docker run -d -P --link selenium-hub:hub selenium/node-firefox-debug
To check node started or not, Open broweser and check node into hub Start Node for Chrome
docker run -d -P --link selenium-hub:hub selenium/node-chrome-debug
To check node started or not, Open broweser and check node into hub
--------------------------------VNC INSTALLATION TO VIEW NODE CONSOLE ---------------------------------- Step 7: To view firefox and chrome docker console, We need to download vnc and install it https://www.realvnc.com/en/connect/download/viewer/macos/ Start vnc , enter node url 0.0.0.0:55000 chrome will start , here 55000 is assigned to chrome browser node 0.0.0.0:55001 Firefox will start , here 55001 is assigned to firefox browser node
--------------------------------SELENIUM SCRIPT---------------------------------------------- Step 8: We need to create demo automation script to execute on nodes Create selenium script ex. Firefox
import org.openqa.selenium.remote.DesiredCapabilities; import org.openqa.selenium.remote.RemoteWebDriver; import org.testng.annotations.Test; import java.net.MalformedURLException; import java.net.URL; public class ffdemo { @Test public void testApp() throws MalformedURLException, InterruptedException { DesiredCapabilities cap= new DesiredCapabilities(); cap.setBrowserName(BrowserType.FIREFOX); WebDriver driver=new RemoteWebDriver(new URL("http://localhost:4545/wd/hub"),cap); driver.get("https://www.google.com/"); driver.findElement(By.name("q")).sendKeys("Autoamtion testing"); Thread.sleep(5000); driver.quit(); } }
ex. Chrome package dockerdemo; import org.openqa.selenium.By; import org.openqa.selenium.WebDriver; import org.openqa.selenium.remote.BrowserType; import org.openqa.selenium.remote.DesiredCapabilities; import org.openqa.selenium.remote.RemoteWebDriver; import org.testng.annotations.Test; import java.net.MalformedURLException; import java.net.URL; public class chromedemo { @Test public void testApp() throws MalformedURLException, InterruptedException { DesiredCapabilities cap= new DesiredCapabilities(); cap.setBrowserName(BrowserType.CHROME); WebDriver driver=new RemoteWebDriver(new URL("http://localhost:4545/wd/hub"),cap); driver.get("https://www.google.com/"); driver.findElement(By.name("q")).sendKeys("Autoamtion testing"); Thread.sleep(5000); driver.quit(); } } tetsng.xml for parallel execution How to execute script:- Right click on testng.xml and run as suite
--------------------------------EXECUTE SCRIPT---------------------------------------------- Step 9: Execute script , Execution will start on both console , Firefox ( 0.0.0.0:55001) and chrome ( 0.0.0.0:55000 )
--------------------------------EXECUTION DEMO---------------------------------------------- Execution Demo

What is JMeter

  
What is JMeter? Why it is used?
The Apache JMeterTM is pure Java open source software, which was first developed by
  Stefano Mazzocchi of the Apache Software Foundation, designed to load test functional
  behavior and measure performance. You can use JMeter to analyze and measure the performance
  of web application or a variety of services. Performance Testing means testing a web application
  against heavy load, multiple and concurrent user traffic. JMeter originally is used for testing 
  Web Application or FTP application.
  
 
Demo
 

OOPS real time examples into webdriver

  
1) ABSTRACTION
2) INTERFACE
3) INHERITANCE
4) POLYMORPHISM
5) METHOD OVERLOADING
6) METHOD OVERRIDING
7) ENCAPSULATION

-------------------------------------------------------------------------------------------------------  
 ABSTRACTION
In Page Object Model design pattern, we write locators (such as id, name, xpath etc.,) in a 
Page Class. We utilize these locators in tests but we can’t see these locators in the tests.
Literally we hide the locators from the tests.

Abstraction is the methodology of hiding the implementation of internal details and showing the
functionality to the users.

-------------------------------------------------------------------------------------------------------  
INTERFACE
Basic statement we all know in Selenium is WebDriver driver = new FirefoxDriver();

WebDriver itself is an Interface. So based on the above statement WebDriver driver = new FirefoxDriver();
we are initializing Firefox browser using Selenium WebDriver. It means we are creating a 
reference variable (driver) of the interface (WebDriver) and creating an Object. Here
WebDriver is an Interface as mentioned earlier and FirefoxDriver is a class.

An interface in Java looks similar to a class but both the interface and class are two different 
concepts. An interface can have methods and variables just like the class but the methods 
declared in interface are by default abstract. We can achieve 100% abstraction and multiple 
inheritance in Java with Interface.

-------------------------------------------------------------------------------------------------------  
INHERITANCE
We create a Base Class in the Framework to initialize WebDriver interface, WebDriver waits,
Property files, Excels, etc., in the Base Class.

We extend the Base Class in other classes such as Tests and Utility Class. Extending one 
class into other class is known as Inheritance.

-------------------------------------------------------------------------------------------------------  
POLYMORPHISM
Combination of overloading and overriding is known as Polymorphism. We will see both 
overloading and overriding below.

Polymorphism allows us to perform a task in multiple ways.

METHOD OVERLOADING
We use implicit wait in Selenium. Implicit wait is an example of overloading. In Implicit 
  wait we use different time stamps such as SECONDS, MINUTES, HOURS etc.,

A class having multiple methods with same name but different parameters is called Method Overloading

METHOD OVERRIDING
We use a method which was already implemented in another class by changing its parameters. 
To understand this you need to understand Overriding in Java.

Declaring a method in child class which is already present in the parent class is called 
Method Overriding. Examples are get and navigate methods of different drivers in Selenium .
-------------------------------------------------------------------------------------------------------  
ENCAPSULATION
All the classes in a framework are an example of Encapsulation. In POM classes, we declare
the data members using @FindBy and initialization of data members will be done using 
Constructor to utilize those in methods.

Encapsulation is a mechanism of binding code and data together in a single unit.

-------------------------------------------------------------------------------------------------------  
Following are some important topics

WEB ELEMENT:
Web element is an interface used to identify the elements in a web page.

WEBDRIVER:
WebDriver is an interface used to launch different browsers such as Firefox, Chrome,
Internet Explorer, Safari etc.,

FIND BY:
FindBy is an annotation used in Page Object Model design pattern to identify the elements.

FIND ELEMENT:
Find Element is a method in POM to identify the elements in a web page.
  

Appium Touch Actions

 ---------------------------------------------------------------------------------------------------------- 
Single tap
  
  public static void performSingleTap(AppiumDriver driver, MobileElement element){
	try {
		TouchActions action = new TouchActions(driver);
		action.singleTap(element);
		action.perform();
	}
	catch (Exception e) {
		Log.fail("Unable to perform Single Tap Operation" + e.getMessage(), driver);
	} 
}
  
------------------------------------------------------------------------------------------------------------ 
Double tap
  
  public static void performDoubleTap(AppiumDriver driver, MobileElement element){
	try {
		TouchActions action = new TouchActions(driver);
		action.doubleTap(element);
		action.perform();
	}
	catch (Exception e) {
		Log.fail("Unable to perform Double Tap Operation" + e.getMessage(), driver);
	} 
}

---------------------------------------------------------------------------------------------------------- 
Perform touch sequence
  
  public static void performTouchSequence(AppiumDriver driver, MobileElement element1,
  MobileElement element2){
  
	try {
		TouchAction action = new TouchAction(driver);
		action.press(element1);
		action.moveTo(element2);
		action.release();
		action.perform();
	}
	catch (Exception e) {
		Log.fail("Unable to perform Touch Sequence Operation" + e.getMessage());
	} 
}

----------------------------------------------------------------------------------------------------------   
Perform multi touch sequence containing different elements
  
  public static void performMultiTouch(AppiumDriver driver, MobileElement element1,
  MobileElement element2,MobileElement element3,MobileElement element4){
	try {
		TouchAction actionOne = new TouchAction(driver);
		actionOne.press(element1);
		actionOne.moveTo(element2);
		actionOne.release();
			
		TouchAction actionTwo = new TouchAction(driver);
		actionTwo.press(element3);
		actionTwo.moveTo(element4);
		actionTwo.release();
			
		MultiTouchAction action = new MultiTouchAction(driver);
		action.add(actionOne);
		action.add(actionTwo);
		action.perform();
	}
	catch (Exception e) {
		Log.fail("Unable to perform Multi Touch Operation" + e.getMessage(), driver);
	} 
}
  
----------------------------------------------------------------------------------------------------------   
Vertical Swipe ( Up and Down) 
  
  Method 1:- 
  public void verticalScroll(String direction) throws Exception {
        try {

            Dimension d = driver.manage().window().getSize();
            int x=d.getWidth()/2;
            int startY;
            int endY;
            
            switch(direction){
                case "up":
                    startY = (int) (d.getHeight() * 0.8);
                    endY = (int) (d.getHeight() * 0.2);
             		break;
                case "down":
                    startY = (int) (d.getHeight() * 0.2);
                    endY = (int) (d.getHeight() * 0.8);
                    break;
                default:
                    throw new IllegalStateException("Unexpected value: " + direction);
            }
            TouchAction touchAction = new TouchAction((AndroidDriver) driver)
                    .press(PointOption.point(x, startY))
                    .waitAction(WaitOptions.waitOptions(Duration.ofMillis(500)))
                    .moveTo(PointOption.point(x, endY))
                    .release().perform();

        } catch (Exception e) {
            e.getStackTrace();
        
        }

    }
  
  
  verticalScroll("up");
  verticalScroll("down");
  
Method 2 :
  
  public  void scrollVertical(String direction, long duration) throws InterruptedException {
		try {

			Dimension size = driver.manage().window().getSize();

			int startX = 0;
			int endX = 0;
			int startY = 0;
			int endY = 0;

			switch (direction){

				case "UP":
					endY= (int) (size.height * 0.70);
					startY  = (int) (size.height * 0.30);
					startX = (size.width / 2);
					break;


				case "DOWN":
					startY = (int) (size.height * 0.70);
					endY = (int) (size.height * 0.30);
					startX = (size.width / 2);

					break;

			}

			new TouchAction(driver)
					.press(PointOption.point(startX, startY))
					.waitAction(WaitOptions.waitOptions(Duration.ofMillis(duration)))
					.moveTo(PointOption.point(endX, endY))
					.release()
					.perform();

		} catch (Exception e) {
			e.getStackTrace();
		}

	}
        
  
  Method:-
  scrollVertical("UP",2000);
  scrollVertical("DOWN",2000);
  
 ----------------------------------------------------------------------------------------------------------  
 Horizontal Swipe ( Right and Left && Left to Right) 
  
  public  void scrollHorizontal(String direction, long duration) throws InterruptedException {
		try {

			Dimension size = driver.manage().window().getSize();

			int startX = 0;
			int endX = 0;
			int startY = 0;
			int endY = 0;

			switch (direction){
				case "RIGHT":
					startY = (int) (size.height /2);
					startX = (int) (size.width * 0.90);
					endX = (int) (size.width * 0.05);
					break;

				case "LEFT":
					startY = (int) (size.height /2);
					startX = (int) (size.width * 0.05);
					endX = (int) (size.width * 0.90);
					break;

			}

			new TouchAction(driver)
					.press(PointOption.point(startX, startY))
					.waitAction(WaitOptions.waitOptions(Duration.ofMillis(duration)))
					.moveTo(PointOption.point(endX, startY))
					.release()
					.perform();


		} catch (Exception e) {
			e.getStackTrace();
			test.log(LogStatus.FAIL, "Something Wrong");
		}
	}


  Methods:-
  scrollHorizontal("RIGHT",2000);
  scrollHorizontal("LEFT",2000);

  

Jenkins Blue Ocean

  
  STEP 1:-  First We need to install blue ocean plugin into jenkins
  
  Manage Jenkins-> Manage Tools-> search " blue ocean " and install related plugin
  
  
STEP 2:- Create pipeline job STEP 3:- Open Blue Ocean
Execution :-

Jenkins PIPELINE Script ( Local and Repo )


First We need to create pipeline project

Then configuration-> Pipeline -> Select pipeline script

And add pipeline script.


------------------------------------------ Local Machine pipeline script-------------------------------------
Ex. script ( Working directory from local machine )

pipeline {
   agent any

   tools {
      // Install the Maven version configured as "M3" and add it to the path.
      maven "MAVEN_HOME"
   }

   stages {
      stage('Compile') {
         steps {
        
        dir("/Users/apple/Desktop/Demo/BDDCucumber_RestAssured_APIFramework") {
            
            sh "mvn compile"
        }
          
      }

      }
      stage('Testing') {
         steps {
            dir("/Users/apple/Desktop/VaibhavDemo/BDDCucumber_RestAssured_APIFramework") {
            
            sh "mvn test"
        	}
          
        }

      }
       stage('Reporting') {
         steps {
         dir("/Users/apple/Desktop/VaibhavDemo/BDDCucumber_RestAssured_APIFramework") {
           cucumber failedFeaturesNumber: -1, failedScenariosNumber: -1, failedStepsNumber: -1,
           fileIncludePattern: 'cucumber.json', jsonReportDirectory: 'target', pendingStepsNumber: -1,
           skippedStepsNumber: -1, sortingMethod: 'ALPHABETICAL', undefinedStepsNumber: -1
           publishHTML([allowMissing: false, alwaysLinkToLastBuild: false, keepAll: false, reportDir: '', 
           reportFiles: 'report/maven-JVM-report/Maven-Extent-Reports/Extent-Report.html', 
           reportName: 'Extent_Report', reportTitles: ''])
         }
            }

        }
      stage('Mailing') {
         steps {
             dir("/Users/apple/Desktop/Demo/BDDCucumber_RestAssured_APIFramework") {
             emailext attachLog: true, attachmentsPattern: 'report/maven-JVM-report/Maven-Extent-Reports/Extent-Report.html', body: '''Hello Team, 


Please find below CICD Job execution details,


Thanks,
Automation Team
''', subject: '${JOB_NAME}, ${BUILD_STATUS}, Build #${BUILD_NUMBER}', to: 'qauser@gmail.com' } } } } post { always { dir("/Users/apple/Desktop/VaibhavDemo/BDDCucumber_RestAssured_APIFramework") { publishHTML([allowMissing: true, alwaysLinkToLastBuild: false, keepAll: true, reportDir: 'report/maven-JVM-report/Maven-Extent-Reports', reportFiles: 'Extent-Report.html', reportName: 'Blue_Ocean_Test_Report', reportTitles: '']) } } } } ----------------------------------------- Git Pipeline Script------------------------------------- Ex. script ( Working directory from Repo ex. GitHub) pipeline { agent any tools { // Install the Maven version configured as "M3" and add it to the path. maven "MAVEN_HOME" } stages { stage('Compile') { steps { // Get some code from a GitHub repository git branch: 'develop_ios', credentialsId: '2', url: 'https://test@bitbucket.org/demo/script.git' // Run Maven on a Unix agent. sh "mvn compile" // To run Maven on a Windows agent, use // bat "mvn -Dmaven.test.failure.ignore=true clean package" } } stage('Testing') { steps { // Get some code from a GitHub repository git branch: 'develop_ios', credentialsId: '2', url: 'https://test@bitbucket.org/demo/script.git' // Run Maven on a Unix agent. sh "mvn verify" // To run Maven on a Windows agent, use // bat "mvn -Dmaven.test.failure.ignore=true clean package" } } stage('Reporting') { steps { cucumber failedFeaturesNumber: -1, failedScenariosNumber: -1, failedStepsNumber: -1, fileIncludePattern: 'cucumber.json', jsonReportDirectory: 'target', pendingStepsNumber: -1, skippedStepsNumber: -1, sortingMethod: 'ALPHABETICAL', undefinedStepsNumber: -1 publishHTML([allowMissing: false, alwaysLinkToLastBuild: false, keepAll: false, reportDir: '', reportFiles: 'report/TestNG_Report/Report/iOS_Testing_Report.html', reportName: 'KASH iOS Test Report', reportTitles: '']) } } stage('Mailing') { steps { emailext attachLog: true, attachmentsPattern: 'report/TestNG_Report/Report/iOS_Testing_Report.html', body: '''Hello Team,

Please find below CICD Job execution details,


Thanks,
Automation Team
''', subject: '${JOB_NAME}, ${BUILD_STATUS}, Build #${BUILD_NUMBER}', to: 'qauser@gmail.com' } } } post { always { publishHTML([allowMissing: true, alwaysLinkToLastBuild: false, keepAll: true, reportDir: 'report/TestNG_Report/Report', reportFiles: 'iOS_Testing_Report.html', reportName: 'Blue Ocean Test Report', reportTitles: '']) publishHTML([allowMissing: true, alwaysLinkToLastBuild: false, keepAll: true, reportDir: 'report/TestNG_Report/JVM_Report/cucumber-html-reports', reportFiles: 'overview-features.html', reportName: 'Blue Ocean JVM Test Report', reportTitles: '']) } } }

API Authorization Demo ( GET, POST and DELETE )

  
  GitHub :- 
  Here I am taking example of GitHub Account for API authorization
  
  So First We nedd to login our GitHub account to generate authentication token.
  
  Account ( Profile Icon )-> Settings -> Developer Settings -> Personal Access Token -> Generate New Token ->
  Add Note ex "demotoken" , Select expiration, Tick Repo and delete_repo options > Click on generate token button.
  
  Copy and paste token somewhere.
  
  
To get GitHub API Url , Follow given below steps
  
  Go to the google search and search "github rest api"
  
  Open "https://docs.github.com/en/rest"
  
  Click on references -> Repositories Then we can list of repo option in left side ex "Create a repository for the   authenticated user", "Get a repository ","Update a repository", " Delete a repository"

  ex api url " https://api.github.com" and End point of POST is "/user/repos"
  
  
WE can create Envirnoment variable for api url Collection-> Edit -> variable
We can use it following way ,
Postman Create a collection and POST , GET and DELETE Requests
Note:- We can create Envrinoment varible for token
GET
POST
DELETE
POSTMAN Execution

How to create mock API

  
  1) Create a folder on Desktop or Any other place ex. users-api-server
  
  2) Open Terminal and Go to the folder directory . ex. cd /Users/apple/Desktop/users-api-server
  
  3) Init npm . " npm init -y "
  
  4) Install JSON-SERVER. "npm i -g json-server"
  
  5) Create "package.json" file into folder. ex users-api-server/package.json
  
  {
  "name": "users-api-server",
  "version": "1.0.0",
  "description": "",
  "main": "index.js",
  "scripts": {
    "test": "echo \"Error: no test specified\" && exit 1"
    “json:server”:”json-server — watch db.json”
  },
  "keywords": [],
  "author": "",
  "license": "ISC",
  "dependencies": {
    "json-server": "^0.16.3"
  }

}
  
  
  6) Create "users.json" file into flder. ex users-api-server/users.json
  
  
  {
  "users": [
    {
      "id": 1,
      "first_name": "Robert",
      "last_name": "Schwartz",
      "email": "rob23@gmail.com"
    },
    {
      "id": 2,
      "first_name": "Lucy",
      "last_name": "Ballmer",
      "email": "lucyb56@gmail.com"
    },
    {
      "id": 3,
      "first_name": "Anna",
      "last_name": "Smith",
      "email": "annasmith23@gmail.com"
    },
    {
      "id": 4,
      "first_name": "Robert",
      "last_name": "Brown",
      "email": "bobbrown432@yahoo.com"
    },
    {
      "id": 5,
      "first_name": "Roger",
      "last_name": "Bacon",
      "email": "rogerbacon12@yahoo.com"
    }
  ]
}
  
 
   users-api-server folder should be look like following way
  
  
7) Then start server. Go to the users-api-server folder on terminAL ex. cd /Users/apple/Desktop/users-api-server The "json-server --watch users.json ". Then mock api server will start output like below
Demo through POSTMAN
Demo through IDE ( IntelliJ )
If you are not start json server and try to execute api . Then you will get following error