Ejercicio de programación: Reto Page Factory
Este ejercicio de programación está diseñado para poner a prueba tus conocimientos en Selenium. Es un ejercicio de nivel intermedio que requiere conocimientos sólidos de la tecnología.
Información adicional del ejercicio
Aprende a implementar el Patrón POM y su instanciación con Page Factory en Selenium.
Contenido del ejercicio
Objetivo
Dominar el patrón PageFactory utilizando anotaciones @FindBy y @CacheLookup para crear Page Objects más mantenibles y expresivos.
Escenario
Crea una Page Object para una biblioteca online que permita buscar libros. El HTML de la página es:
<!DOCTYPE html>
<html>
<head>
<title>Biblioteca Online - PageFactory Challenge</title>
</head>
<body>
<header id="main-header">
<div class="site-logo">📚 BiblioTech</div>
<nav class="main-navigation">
<a href="/inicio">Inicio</a>
<a href="/catalogo">Catálogo</a>
<a href="/mi-cuenta">Mi Cuenta</a>
</nav>
</header>
<main>
<div class="search-section">
<h1>Buscar Libros</h1>
<input id="search-input" type="text" placeholder="Título o autor del libro">
<select name="category" id="category-select">
<option value="">Todas las categorías</option>
<option value="fiction">Ficción</option>
<option value="science">Ciencia</option>
<option value="history">Historia</option>
</select>
<button type="submit" class="search-btn">Buscar</button>
</div>
<div class="results-section">
<div class="book-card" data-testid="book-1">
<h3 class="book-title">El Quijote</h3>
<span class="book-author">Miguel de Cervantes</span>
<button class="add-favorite">♥ Favorito</button>
</div>
<div class="book-card" data-testid="book-2">
<h3 class="book-title">1984</h3>
<span class="book-author">George Orwell</span>
<button class="add-favorite">♥ Favorito</button>
</div>
<div class="book-card" data-testid="book-3">
<h3 class="book-title">Sapiens</h3>
<span class="book-author">Yuval Noah Harari</span>
<button class="add-favorite">♥ Favorito</button>
</div>
</div>
</main>
</body>
</html>
Tareas a realizar
Crea una clase **LibraryPage**
usando PageFactory:
- Elementos estáticos - Usar @FindBy y @CacheLookup para logo y navegación principal
- Elementos de búsqueda - Usar @FindBy con diferentes localizadores (id, name, className)
- Lista de libros - Crear List<WebElement> para las tarjetas de libros
- Inicialización - Implementar constructor con PageFactory.initElements()
- Métodos de acción - Crear métodos para buscar y obtener títulos de libros
Requisitos técnicos
- Crea clase
LibraryPage
separada del test - Usa
PageFactory.initElements(driver, this)
en constructor - Aplica @CacheLookup solo a elementos estáticos apropiados
- Incluye al menos 4 tipos diferentes de localizadores @FindBy
- Bonus: Usa XPath o CSS selector avanzado en al menos un @FindBy
Criterios de evaluación
- ✅ Clase Page Object con PageFactory correctamente inicializada
- ✅ @FindBy con id, name, className
- ✅ @CacheLookup aplicado apropiadamente a elementos estáticos
- ✅ List<WebElement> para colecciones de elementos
- ✅ Métodos de acción que encapsulen la lógica de interacción
- ✅ Test que demuestre el uso de la Page Object
¡No olvides los imports necesarios para PageFactory!
Lección relacionada
Este ejercicio está relacionado con la lección "Page Factory" de Selenium. Te recomendamos revisar la lección antes de comenzar.
Ver lección relacionadaMás ejercicios de Selenium
Explora más ejercicios de programación en Selenium para mejorar tus habilidades y obtener tu certificación.
Ver más ejercicios de SeleniumSolución al ejercicio de programación en Selenium
¡Desbloquea la solución completa!
Completa el ejercicio de programación en Selenium para acceder a la solución paso a paso, explicaciones detalladas y mejores prácticas.
Practica con ejercicios de programación en Selenium
Mejora tus habilidades con cientos de ejercicios de práctica, recibe retroalimentación instantánea y obtén tu certificación cuando estés listo.
Asistente de IA
Aprende de tus errores
Progreso
Mide tu avance
Certificación
Valida tus habilidades
Únete a miles de desarrolladores mejorando sus habilidades en Selenium