https://dosideas.com/wiki/api.php?action=feedcontributions&user=200.73.52.205&feedformat=atomDos Ideas. - Contribuciones del usuario [es]2024-03-28T23:58:20ZContribuciones del usuarioMediaWiki 1.28.2https://dosideas.com/wiki/index.php?title=Selenium&diff=5747Selenium2011-04-28T21:31:18Z<p>200.73.52.205: /* Sobre waitForPageToLoad */</p>
<hr />
<div>[[Selenium]] es una herramienta de [[Software Libre]] para pruebas de aplicaciones Web. Las pruebas de [[Selenium]] se ejecutan directamente en un navegador y facilitan las pruebas de compatibilidad en navegadores, también como pruebas funcionales de aceptación de aplicaciones Web.<br />
<br />
La herramienta [[Selenium]] posee un ambiente de desarrollo llamado [[Selenium]] IDE, este facilita el registro de pruebas de aceptación y su depuración.<br />
<br />
==Integracion con JUnit 4.x==<br />
<br />
Para poder armar el test es necesario incluir los siguientes jars.<br />
<br />
*selenium-java-client-driver-tests.jar<br />
*selenium-java-client-driver.jar<br />
*selenium-server-tests.jar<br />
*selenium-server.jar<br />
<br />
Se pueden descargar de acá: [http://archiva.openqa.org/repository/releases/org/openqa/selenium/selenium-remote-control/1.0-beta-1/selenium-remote-control-1.0-beta-1-dist.zip Librerías]<br />
<br />
<br />
<code java><br />
import org.junit.Before;<br />
import org.junit.Test;<br />
import org.openqa.selenium.server.SeleniumServer;<br />
<br />
import com.thoughtworks.selenium.DefaultSelenium;<br />
import com.thoughtworks.selenium.SeleneseTestCase;<br />
<br />
public class GoogleWebTest extends SeleneseTestCase {<br />
<br />
private DefaultSelenium selenium;<br />
private SeleniumServer seleniumServer;<br />
<br />
@Override<br />
@Before<br />
public void setUp(String browser) throws Exception {<br />
// Se instancia el server de selenium por default toma el puerto 4444<br />
seleniumServer = new SeleniumServer();<br />
seleniumServer.start();<br />
<br />
// Se configura el acceso a la pagina por medio del server de selenium<br />
// DefaultSelenium("SELENIUM_HOST", PUERTO, "BROWSER", URL_DE_LA_APLICACION);<br />
// En este ejemplo, se utiliza Internet Explorer: "*iehta"<br />
selenium = new DefaultSelenium("localhost", 4444, "*iehta", "http://www.google.com");<br />
selenium.start();<br />
}<br />
<br />
/** Al finalizar los tests, detener el server de Selenium <br />
*/<br />
@Override<br />
public void tearDown() throws Exception {<br />
// Se para la conexión con la pagina <br />
selenium.stop();<br />
<br />
// Se para la instancia del server de selenium<br />
seleniumServer.stop();<br />
}<br />
<br />
<br />
/** Testeamos una búsqueda en Google<br />
* Accedemos a Google, realizamos una búsqueda y comprobamos que venga el resultado esperado<br />
*/<br />
@Test<br />
public void testGoogle() throws Exception {<br />
selenium.open("http://www.google.com/webhp");<br />
assertEquals("Google", selenium.getTitle());<br />
selenium.type("q", "Selenium OpenQA");<br />
assertEquals("Selenium OpenQA", selenium.getValue("q"));<br />
selenium.click("btnG");<br />
selenium.waitForPageToLoad("30000");<br />
assertEquals("Selenium OpenQA - Google Search", selenium.getTitle());<br />
}<br />
<br />
}<br />
</code><br />
<br />
==Sobre waitForPageToLoad==<br />
<br />
Es importante que la página esté cargada antes de hacer las verificaciones sobre el nuevo contenido. Para hacer más sólido el caso de prueba ubica un waitForPageToLoad luego de un click.<br />
<br />
Es recomendable que al terminar un caso de prueba ubiques un waitForPageToLoad y así te aseguras que el próximo caso de prueba no falle al comenzar.<br />
ghjgjgj<br />
<br />
==Sobre assertTextNotPresent==<br />
<br />
Este comando es útil después de cada comando clickAndWait para confirmar un texto no debe estar presente en la página.<br />
<br />
==Sobre assertTextPresent==<br />
<br />
Este comando es útil después de cada comando clickAndWait para confirmar un texto debe estar presente en la página.<br />
<br />
<br />
==Sobre verifyTrue==<br />
<br />
Al realizar [http://www.dosideas.com/java/743-test-secuencial-con-selenium-y-junit.html test secuencial] con [[Selenium]] IDE, y verificar texto en la página, después de convertir el test a código Java -para correrlo con JUnit- queda generado con el comando <br />
<br />
<code html4strict><br />
<br />
verifyTrue(selenium.isTextPresent("Algun texto"));<br />
<br />
</code><br />
<br />
Este comando no genera fallas en el test en caso que el texto buscado no se encuentre en la página. El comando adecuado para que se genere la falla es <br />
<br />
<code html4strict><br />
<br />
assertTrue(selenium.isTextPresent("Algun texto"));<br />
<br />
</code><br />
<br />
== Sobre Popups ==<br />
<br />
En Selenium, se trabaja con una ventana a la vez. Para trabajar con diferentes ventanas (por ejemplo, un popup) se necesita primero elegir la ventana en cuestión. Y no solo basta con esto, tambien dicha ventana tiene que ser identificada. La forma mas facil de realizar esto es capturar el id de la nueva ventana con Selenium IDE. <br />
<br />
Si la ventana se abre con un target="_blank" no se podrá utilizar Selenium para acceder a dicha ventana dado a que el id que se genera es random. Hay un [http://jira.openqa.org/browse/SEL-203 Jira] abierto en Selenium para resolver esto.<br />
<br />
== Sobre caracteres especiales ==<br />
<br />
Para que hudson tome bien los acentos (y caracteres especiales) en los test de selenium hay que usar unicode.<br />
<br />
Los codigos son:<br />
<br />
*á -> \u00e1<br />
*é -> \u00e9<br />
*í -> \u00ed<br />
*ó -> \u00f3<br />
*ú -> \u00fa<br />
*Á -> \u00c1<br />
*É -> \u00c9<br />
*Í -> \u00cd<br />
*Ó -> \u00d3<br />
*Ú -> \u00da<br />
*ñ -> \u00f1<br />
*Ñ -> \u00d1<br />
<br />
*ü -> \u00FC<br />
*Ü -> \u00DC<br />
*ç -> \u00E7<br />
*Ç -> \u00C7<br />
*¿ -> \u00BF<br />
*¡ -> \u00A1<br />
<br />
== Sobre la integración contínua ==<br />
<br />
Cuando se usa Selenium en un proceso de integración contínua puede pasar que nos encontremos con tests que fallan porque no se encuentran los elementos esperados. Lo bueno es saber qué se encontró en lugar de lo que se esperaba.<br />
<br />
El método selenium.getBody() retorna un String con el texto de la página en la que se encuentra selenium en ese momento, pero lo mejor de todo es que además lo escribe en consola.<br />
<br />
Si miramos la salida por consola del test fallido vamos a encontrar la secuencia de los comandos de selenium y en los lugares donde hayamos puesto los getBody() vamos a ver intercalado los textos que mostraba la página en ese momento.<br />
<br />
==Ver también==<br />
*[[Herramientas Para Pruebas De Aceptacion]]<br />
*[http://selenium.openqa.org/ Web oficial de Selenium]<br />
*[http://www.pghcodingdojo.org/index.php/Selenium_RC_Tutorial Selenium RC Tutorial]<br />
*[http://www.dosideas.com/java/743-test-secuencial-con-selenium-y-junit.html Test Secuencial con Selenium y JUnit]<br />
*[http://seleniumhq.org/docs/04_selenese_commands.html#verifying-page-elements Comandos de Verificación de elementos en páginas web]<br />
*[http://wiki.openqa.org/display/SEL/Selenium+Core+FAQ#SeleniumCoreFAQ-HowdoIworkwithapopupwindow%3F Popup con Selenium]<br />
*[[Simplium]]<br />
<br />
[[Category:ATDD]]</div>200.73.52.205