Ejemplo de programa Java Selenium Webdriver (código de muestra)

Ejemplo de selenio Java

Usando el Java clase “miclase” que creamos en el tutorial anterior, intentemos crear un script WebDriver que:

Paso 1: buscar la página de inicio de Mercury Tours
Paso 2: verificar su título
Paso 3: imprimir el resultado de la comparación
Paso 4: ciérrelo antes de finalizar todo el programa.

Código de muestra de Selenium WebDriver

A continuación se muestra el código WebDriver real para la lógica presentada por el escenario anterior.

package newproject;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.firefox.FirefoxDriver;
//comment the above line and uncomment below line to use Chrome
//import org.openqa.selenium.chrome.ChromeDriver;
public class PG1 {


    public static void main(String[] args) {
        // declaration and instantiation of objects/variables
    	System.setProperty("webdriver.gecko.driver","C:\\geckodriver.exe");
		WebDriver driver = new FirefoxDriver();
		//comment the above 2 lines and uncomment below 2 lines to use Chrome
		//System.setProperty("webdriver.chrome.driver","G:\\chromedriver.exe");
		//WebDriver driver = new ChromeDriver();
    	
        String baseUrl = "http://demo.guru99.com/test/newtours/";
        String expectedTitle = "Welcome: Mercury Tours";
        String actualTitle = "";

        // launch Fire fox and direct it to the Base URL
        driver.get(baseUrl);

        // get the actual value of the title
        actualTitle = driver.getTitle();

        /*
         * compare the actual title of the page with the expected one and print
         * the result as "Passed" or "Failed"
         */
        if (actualTitle.contentEquals(expectedTitle)){
            System.out.println("Test Passed!");
        } else {
            System.out.println("Test Failed");
        }
       
        //close Fire fox
        driver.close();
    }

}

Nota: Comenzando Firefox 35, necesitas usar el controlador gecko creado por Mozilla para usar Web Driver. Selenio 3.0, gecko y firefox tiene problemas de compatibilidad y configurarlos correctamente podría convertirse en una tarea ardua. Si el código no funciona, baje a Firefox versión 47 o inferior. Alternativamente, puede ejecutar sus scripts en Chrome. El selenio funciona a partir del box para Chrome. Sólo necesitas cambiar 3 líneas de código para que tu script funcione con Chrome o Firefox

Explicando el código

Importación de paquetes

Para comenzar, necesitas importar followwing dos paquetes:

  1. org.openqa.selenio.*– contiene la clase WebDriver necesaria para crear una instancia de un nuevo navegador cargado con un controlador específico
  2. org.openqa.selenium.firefox.FirefoxDestornillador - contiene el FirefoxClase de controlador necesaria para crear una instancia de un Firefox-controlador específico en el navegador instanciado por la clase WebDriver

Si su prueba necesita acciones más complicadas, como acceder a otra clase, tomar capturas de pantalla del navegador o manipular archivos externos, definitivamente necesitará importar más paquetes.

Creación de instancias de objetos y variables.

Normalmente, así es como se crea una instancia de un objeto controlador.

WebDriver driver = new FirefoxDriver();

A FirefoxLa clase de controlador sin parámetros significa que el valor predeterminado Firefox El perfil será iniciado por nuestro programa Java. El valor por defecto Firefox El perfil es similar al de lanzamiento. Firefox en modo seguro (no se cargan extensiones).

Por conveniencia, guardamos la URL base y el título esperado como variables.

Iniciar una sesión de navegador

WebDriver's get () El método se utiliza para iniciar una nueva sesión del navegador y la dirige a la URL que usted especifica como parámetro.

driver.get(baseUrl);

Obtenga el título de la página real

La clase WebDriver tiene la getTitle () método que siempre se utiliza para obtener el título de la página actualmente cargada.

actualTitle = driver.getTitle();

Compare los valores esperados y reales

Esta parte del código simplemente utiliza una estructura básica de Java if-else para comparar el título real con el esperado.

if (actualTitle.contentEquals(expectedTitle)){
            System.out.println("Test Passed!");
        } else {
            System.out.println("Test Failed");
        }

Terminar una sesión del navegador

Los "close()El método "se utiliza para cerrar la ventana del navegador.

driver.close();

Terminar todo el programa

Si usa este comando sin cerrar todo el navegador windows Primero, todo su programa Java finalizará dejando abierta la ventana del navegador.

System.exit(0);

Ejecución de la prueba

Hay dos formas de ejecutar código en Eclipse IDE

  1. On Eclipsebarra de menú, haga clic en Ejecutar > Ejecutar.
  2. Prensa Ctrl + F11 para ejecutar el código completo.

Ejecución de la prueba

Si hiciste todo correctamente, Eclipse mostraría "¡Prueba aprobada!"

Ejecución de la prueba

Localización de elementos de la GUI

La localización de elementos en WebDriver se realiza utilizando el botón "encontrarElemento(Por.localizador())" método. La parte "localizador" del código es la misma que cualquiera de los localizadores discutidos anteriormente en el Selenio IDE capítulos de estos tutoriales. De hecho, se recomienda que ubique los elementos de la GUI utilizando IDE y, una vez identificados correctamente, exporte el código a WebDriver.

Aquí hay un código de muestra de Selenium que ubica un elemento por su identificación. Facebook se utiliza como URL base.

package newproject;
import org.openqa.selenium.By;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.firefox.FirefoxDriver;

public class PG2 {
    public static void main(String[] args) {
    	System.setProperty("webdriver.gecko.driver","C:\\geckodriver.exe");
    	WebDriver driver = new FirefoxDriver();
        String baseUrl = "http://www.facebook.com";
        String tagName = "";
        
        driver.get(baseUrl);
        tagName = driver.findElement(By.id("email")).getTagName();
        System.out.println(tagName);
        driver.close();
        System.exit(0);
}
}

Se utilizó el getTagName () método para extraer el nombre de la etiqueta de ese elemento en particular cuya identificación es "email”. Cuando se ejecute, este código debería poder identificar correctamente el nombre de la etiqueta "entrada" y lo imprimirá en EclipseLa ventana de la consola.

Localización de elementos de la GUI

Resumen para localizar elementos

Variation Descripción Muestra
Por.nombredeclase encuentra elementos basados ​​en el valor del atributo "clase" findElement(By.className(“algunNombreClase”))
Por.cssSelector encuentra elementos basados ​​en el motor selector CSS subyacente del controlador findElement(By.cssSelector(“entrada#email”))
Por.id localiza elementos por el valor de su atributo "id" encontrarElemento(Por.id(“algúnId”))
 
Por.linkText encuentra un elemento de enlace por el texto exacto que muestra findElement(By.linkText(“REGISTRO”))
 
Por nombre localiza elementos por el valor del atributo "nombre" encontrarElemento(Por.nombre(“algúnNombre”))
 
Por.partialLinkText localiza elementos que contienen el texto del enlace dado findElement(By.partialLinkText(“REG”))
 
Por.nombredeetiqueta localiza elementos por su nombre de etiqueta encontrarElemento(By.tagName(“div”))
 
Por.xpath localiza elementos a través de XPath findElement(By.xpath(“//html/body/div/table/tbody/tr/td[2]/table/
tbody/tr[4]/td/table/tbody/tr/td[2]/table/tbody/tr[2]/td[3]/ form/table/tbody/tr[5]”))

Nota sobre el uso de findElement(By.cssSelector())

By.cssSelector() no admite la función "contiene". Considere el código IDE de Selenium a continuación:

Nota sobre el uso de findElement(By.cssSelector())

En Selenium IDE anterior, se pasó toda la prueba. Sin embargo, en el siguiente script de Selenium WebDriver, la misma prueba generó un error porque WebDriver no admite la palabra clave "contiene" cuando se usa en el método By.cssSelector().

Nota sobre el uso de findElement(By.cssSelector())

Comandos comunes

Creación de instancias de elementos web

En lugar de utilizar la sintaxis larga “driver.findElement(By.locator())” cada vez que acceda a un elemento en particular, podemos crear una instancia de un objeto WebElement para él. La clase WebElement está contenida en el paquete “org.openqa.selenium.*”.

Creación de instancias de elementos web

Al hacer clic en un elemento

Hacer clic es quizás la forma más común de interactuar con los elementos web. El click() El método se utiliza para simular el clic de cualquier elemento. el siguientewing El ejemplo de Selenium Java muestra cómo click() se utilizó para hacer clic en el botón "Iniciar sesión" de Mercury Tours.

Al hacer clic en un elemento

Following Se deben tener en cuenta algunas cosas al utilizar el método click().

  • No requiere ningún parámetro/argumento.
  • El método espera automáticamente a que se cargue una nueva página, si corresponde.
  • El elemento sobre el que se hará clic debe ser visible (el alto y el ancho no deben ser iguales a cero).

Obtener Comandos

Los comandos Get obtienen diversa información importante sobre la página/elemento. A continuación se muestran algunos comandos “obtener” importantes con los que debe estar familiarizado.

Comandos Uso
get ()

Uso de la muestra:

  • Abre automáticamente una nueva ventana del navegador y busca la página que especifica entre paréntesis.
  • Es la contraparte del comando "abrir" de Selenium IDE.
  • El parámetro debe ser un Cordón objeto.
getTitle ()

Uso de la muestra:

  • No necesita parámetros
  • Obtiene el título de la página actual.
  • Los espacios en blanco iniciales y finales se recortan
  • Devuelve una cadena nula si la página no tiene título
getPageSource()

Uso de la muestra:

  • No necesita parámetros
  • Devuelve el código fuente de la página como un valor de cadena.
obtenerUrlActual()

Uso de la muestra:

  • No necesita parámetros
  • Obtiene la cadena que representa la URL actual que el navegador está mirando
getText ()

Uso de la muestra:

  • Obtiene el texto interno del elemento que especifica

Comandos de navegación

Estos comandos le permiten actualizar, acceder y alternar entre diferentes páginas web.

navegar a()

Uso de la muestra:

  • Abre automáticamente una nueva ventana del navegador y busca la página que especifica entre paréntesis.
  • Hace exactamente lo mismo que el get() método.
navegar().actualizar()

Uso de la muestra:

  • No necesita parámetros.
  • Actualiza la página actual.
navegar().volver()

Uso de la muestra:

  • No necesita parámetros
  • Le lleva atrás una página en el historial del navegador.
navegar().adelante()

Uso de la muestra:

  • No necesita parámetros
  • Lo lleva hacia adelante una página en el historial del navegador.

Cerrar y salir del navegador Windows

close()

Uso de la muestra:

  • No necesita parámetros
  • Cierra sólo la ventana del navegador que WebDriver está controlando actualmente.
dejar()

Uso de la muestra:

  • No necesita parámetros
  • cierra todo windows que WebDriver ha abierto.

Cerrar y salir del navegador Windows

Para ilustrar claramente la diferencia entre close() y quit(), intente ejecutar el siguiente código. Utiliza una página web que abre automáticamente una ventana al cargar la página y abre otra después de salir.

Cerrar y salir del navegador Windows

Observe que solo se cerró la ventana principal del navegador y no las dos ventanas emergentes. windows.

Cerrar y salir del navegador Windows

Pero si usas quit(), todo windows estará cerrado, no solo el principal. Intente ejecutar el código siguiente y notará que las dos ventanas emergentes anteriores también se cerrarán automáticamente.

package newproject;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.firefox.FirefoxDriver;

public class PG3 {
    public static void main(String[] args) {
    	System.setProperty("webdriver.gecko.driver","C:\\geckodriver.exe");
    	WebDriver driver = new FirefoxDriver();
        driver.get("http://www.popuptest.com/popuptest2.html");
        driver.quit();  // using QUIT all windows will close
    }
}

Cambiar entre fotogramas

Para acceder a los elementos de la GUI en un marco, primero debemos indicarle a WebDriver que se centre en el marco o la ventana emergente antes de poder acceder a los elementos dentro de ellos. Tomemos, por ejemplo, la página web http://demo.guru99.com/selenium/deprecated.html

Cambiar entre fotogramas

Esta página tiene 3 marcos cuyos atributos de “nombre” se indican arriba. Deseamos acceder al enlace "Obsoleto" rodeado arriba en amarillo. Para hacer eso, primero debemos indicarle a WebDriver que cambie al marco "classFrame" usando el “cambiar a().frame()” método. Usaremos el atributo de nombre del marco como parámetro para la parte "frame()".

package newproject;
import org.openqa.selenium.By;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.firefox.FirefoxDriver;
public class PG4 {
	  public static void main(String[] args) {
		  	System.setProperty("webdriver.gecko.driver","C:\\geckodriver.exe");  
		  	WebDriver driver = new FirefoxDriver();
	        driver.get("http://demo.guru99.com/selenium/deprecated.html");
	        driver.switchTo().frame("classFrame");
	        driver.findElement(By.linkText("Deprecated")).click();
	        driver.close(); 
	    }
}

Después de ejecutar este código, verá que el marco "classFrame" se lleva a la página "API obsoleta", lo que significa que nuestro código pudo acceder con éxito al enlace "Obsoleto".

Cambiar entre ventanas emergentes Windows

WebDriver permite ventanas emergentes windows como alertas que se mostrarán, a diferencia de Selenium IDE. Para acceder a los elementos dentro de la alerta (como el mensaje que contiene), debemos utilizar el "switchTo().alert()" método. En el código siguiente, usaremos este método para acceder a la alerta. box y luego recuperar su mensaje usando el "getText()" método y luego cerrar automáticamente la alerta box usando el "switchTo().alert().accept()" método.

Primero, dirígete a https://output.jsbin.com/usidix/1 y haga clic manualmente en "¡Ir!" abotone allí y vea usted mismo el texto del mensaje.

Cambiar entre ventanas emergentes Windows

Veamos el código de ejemplo de Selenium para hacer esto.

package mypackage;

import org.openqa.selenium.By;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.firefox.FirefoxDriver;

public class myclass {

    public static void main(String[] args) {
    	System.setProperty("webdriver.gecko.driver","C:\\geckodriver.exe");
        WebDriver driver = new FirefoxDriver();
        String alertMessage = "";

        driver.get("http://jsbin.com/usidix/1");
        driver.findElement(By.cssSelector("input[value=\"Go!\"]")).click();
        alertMessage = driver.switchTo().alert().getText();
        driver.switchTo().alert().accept();
       
        System.out.println(alertMessage);
        driver.quit();
       
    }
}

En Eclipse consola, observe que el mensaje de alerta impreso es:

Cambiar entre ventanas emergentes Windows

Murga

Hay dos tipos de esperas.

  1. Espera implícita: se utiliza para establecer el tiempo de espera predeterminado en todo el programa.
  2. Espera explícita: se utiliza para establecer el tiempo de espera solo para una instancia en particular.

Espera implícita

  • Es más sencillo de codificar que las esperas explícitas.
  • Generalmente se declara en la parte de creación de instancias del código.
  • Sólo necesitarás un paquete adicional para importar.

Para comenzar a usar una espera implícita, deberá importar este paquete a su código.

Espera implícita

Luego, en la parte de creación de instancias de tu código, agrega esto.

Espera implícita

Espera explícita

Las esperas explícitas se realizan utilizando las clases WebDriverWait y ExpectedCondition.. Para el seguimientowing En el ejemplo de Selenium WebDriver, esperaremos hasta 10 segundos para que un elemento cuya identificación sea "nombre de usuario" se vuelva visible antes de continuar con el siguiente comando. Aquí están los pasos.

Paso 1:

Importe estos dos paquetes:

Espera explícita

Paso 2:

Declare una variable WebDriverWait. En este ejemplo, usaremos "myWaitVar" como nombre de la variable.

Espera explícita

Paso 3:

Utilice myWaitVar con ExpectedConditions en partes donde necesite que se produzca la espera explícita. En este caso, usaremos una espera explícita en la entrada "nombre de usuario" (Página de inicio de Mercury Tours) antes de escribir el texto "tutorial" en ella.

Espera explícita

Condiciones

Following Los métodos se utilizan en operaciones condicionales y de bucle.

  • está habilitado() Se utiliza cuando se desea verificar si un determinado elemento está habilitado o no antes de ejecutar un comando.

Las condiciones están habilitadas ()

  • se visualiza() Se utiliza cuando se desea verificar si un determinado elemento se muestra o no antes de ejecutar un comando.

Las condiciones se muestran()

  • isSelected () Se utiliza cuando se desea verificar si un determinado comprobar box, botón de opción u opción en un menú desplegable box está seleccionado. No funciona con otros elementos.

Las condiciones están seleccionadas ()

Usando condiciones esperadas

La clase ExpectedConditions ofrece un conjunto más amplio de condiciones que puede usar junto con el método Until() de WebDriverWait.

A continuación se muestran algunos de los métodos ExpectedConditions más comunes.

  • alertaEstáPresente() – espera hasta una alerta box se visualiza.

Usando la alerta de condiciones esperadasIsPresent()

  • elementoToBeClickable() – Espera hasta que un elemento sea visible y, al mismo tiempo, habilitado. El código de Selenium de muestra a continuación esperará hasta que el elemento con id=”nombre de usuario” se vuelva visible y se habilite primero antes de asignar ese elemento como una variable WebElement llamada “txtUserName”.

Usando condiciones esperadas

  • marcoToBeAvailableAndSwitchToIt() – Espera hasta que el marco dado ya esté disponible y luego cambia automáticamente a él.

Usando el elemento de condiciones esperadasToBeClickable()

Captura de excepciones

Cuando se utiliza isEnabled(), isDisplayed() y isSelected(), WebDriver supone que el elemento ya existe en la página. Otrowise, arrojará un Ninguna excepción de elemento tal. Para evitar esto, deberíamos utilizar un bloque try-catch para que el programa no se interrumpa.

WebElement txtbox_username = driver.findElement(By.id("username"));
try{
        if(txtbox_username.isEnabled()){
            txtbox_username.sendKeys("tutorial");
        }
    }

catch(NoSuchElementException nsee){
            System.out.println(nsee.toString());
 }

Si utiliza esperas explícitas, el tipo de excepción que debe detectar es "TimeoutException".

Captura de excepciones

Resumen

  • Para comenzar a utilizar la API WebDriver, debe importar al menos estos dos paquetes.
  • org.openqa.selenio.*
  • org.openqa.selenium.firefox.FirefoxDestornillador
  • El get() El método es el equivalente al comando "abrir" de Selenium IDE.
  • La localización de elementos en WebDriver se realiza utilizando el findElement() método.
  • El following son las opciones disponibles para localizar elementos en WebDriver:
  • Por.nombredeclase
  • Por.cssSelector
  • Por.id
  • Por.linkText
  • Por nombre
  • Por.partialLinkText
  • Por.nombredeetiqueta
  • Por.xpath
  • El By.cssSelector() no apoyen el "contiene" .
  • Puede crear una instancia de un elemento utilizando la clase WebElement.
  • Al hacer clic en un elemento se realiza utilizando el click() método.
  • WebDriver proporciona estos útiles comandos de obtención:
  • get ()
  • getTitle ()
  • getPageSource()
  • obtenerUrlActual()
  • getText ()
  • WebDriver proporciona estos útiles comandos de navegación
  • navegar().adelante()
  • navegar().volver()
  • navegar a()
  • navegar().actualizar()
  • Los métodos close() y quit() se utilizan para cerrar el navegador. windows. Close() se utiliza para cerrar una sola ventana; mientras quit() se utiliza para cerrar todo windows asociado a la ventana principal que controlaba el objeto WebDriver.
  • El switchTo().frame() y switchTo().alert() Los métodos se utilizan para dirigir el enfoque de WebDriver a un marco o alerta, respectivamente.
  • Implicit waits se utilizan para establecer el tiempo de espera a lo largo del programa, mientras explicit waits se utilizan sólo en porciones específicas.
  • Puede utilizar isEnabled(), isDisplayed(),isSelected() y una combinación de WebDriverEsperar y Condiciones esperadas métodos al verificar el estado de un elemento. Sin embargo, no verifican si el elemento no existe.
  • Cuando se llamó a isEnabled(), isDisplayed() o isSelected() mientras el elemento no existía, WebDriver generará un Ninguna excepción de elemento tal.
  • Cuando se llamaba a los métodos WebDriverWait y ExpectedConditions mientras el elemento no existía, WebDriver arrojaba un TimeoutException.

Nota:

driver.get(): Se utiliza para ir a un sitio web en particular, pero no mantiene el historial del navegador ni las cookies, por lo que no podemos usar el botón de avanzar y retroceder. Si hacemos clic en él, la página no obtendrá la programación.

driver.navigate(): se usa para ir al sitio web en particular, pero mantiene el historial del navegador y las cookies, por lo que podemos usar el botón de avance y retroceso para navegar entre las páginas durante la codificación de Testcase