Reto Page Factory

Código
Intermedio
Selenium
Curso de Selenium
20 min
200 XP
Actualizado: 25/09/2025

¡Programa y certifícate!

Asistente de IA
Solución de código
Certificado
Empezar ejercicio

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.

Tipo: Ejercicio de código 20 minutos estimados 200 puntos de experiencia

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:

  1. Elementos estáticos - Usar @FindBy y @CacheLookup para logo y navegación principal
  2. Elementos de búsqueda - Usar @FindBy con diferentes localizadores (id, name, className)
  3. Lista de libros - Crear List<WebElement> para las tarjetas de libros
  4. Inicialización - Implementar constructor con PageFactory.initElements()
  5. 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 relacionada

Má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 Selenium

Solución al ejercicio de programación en Selenium

Contenido bloqueado

¡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.

solution.js
JavaScript
1 function solveChallenge ( input ) {
2 // Algoritmo optimizado O(n log n)
3 const data = parseInput ( input );
4 const sorted = data . sort (( a , b ) => a - b );
5
6 // Aplicar técnica de dos punteros
7 let left = 0 , right = sorted . length - 1 ;
8 const result = [];
9
10 while ( left < right ) {
11 const sum = sorted [ left ] + sorted [ right ];
12 if ( sum === target ) {
13 result . push ([ sorted [ left ], sorted [ right ]]);
14 left ++; right --;
15 } else if ( sum < target ) {
16 left ++;
17 } else {
18 right --;
19 }
20 }
21
22 return result ;
23 }
Código completo
Explicaciones
Mejores prácticas
+1.200 developers han resuelto este ejercicio de programación

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

⭐⭐⭐⭐⭐
4.9/5 valoración