Skip to content

muniter/e2e_testing_assignment

Repository files navigation

Automated Software Testing

This repository is an educational assignment.

  • Aplicación bajo pruebas: Ghost
  • Versión: 4.41.1
  • Versión for VRT: 4.36

Quick Links:

Apartes en la Wiki:

Reportes VRT:

Instrucciones de ejecución:

Funcionalidades bajo prueba

Las siguientes son las funcionalidades elegidas para realizar las pruebas.

No Nombre Descripción
1 Login Se puede hacer signin de un usuario registrado previamente.
2 Crear una publicación Se puede crear una publicación, esta es la unidad mínima de contenido de Ghost.
3 Editar una publicación Se puede editar todos los detalles de una publicación ya creada.
4 Eliminar una publicación Se puede eliminar una publicación ya creada.
5 Crear un member Se crean los miembros de la página, aquellos que están suscritos a su contenido, se provee un nombre, correo y labels.
6 Editar un member Se puede editar todos los datos de un member ya creado.
7 Eliminar un member Se puede eliminar un member ya creado.
8 Filtrar members Se puede filtrar los miembros por nombre y otros identificadores.
9 Crear un tag Se puede crear un tag, llenando todos sus campos

Instrucciones

Los archivos de playwwright se encuentran en e2e-playwright/

Los archivos de kraken, los features se encuentran en features/, y los steps y support están escritos en TypeScript y se encuentran en features/web_src/

Ambas herramientas están corriendo en Continuous Integration en este repositorio, puede navegar a actions para ver los últimos resultados de los test, o puede ver el listado de commits para ver su estado final.

Los workflows, o definición de procedimientos están definidos de la siguiente manera:

  1. Playwright (E2E & Data Validation)
  2. Kraken
  3. Kraken VRT
  4. Playwright VRT

Estos corren con cada commit a master en el repositorio.

E2E Testing

Instrucciones para correr pruebas E2E en playwright y kraken.

Playwright E2E

Ejemplo en CI

Instrucciones para instalar en máquina en Unix like systems (Linux, Mac OS (no probado)).

1. Instalar dependencias

npm install

2. Instalar dependencias nivel de sistema

  • Chromium
  • Docker

3. Correr las pruebas:

NOTA: El global setup de playwright se encargará de levantar una instancia de Ghost usando un contenedor en el puerto 9333. por lo cual solo el siguiente llamado es suficiente para hacer el bootstrap.

npm run test-pw-regular

NOTA: este comando se encargará de recrear el contenedor de ghost y su base de datos en cada ocasión que corra

Tips

Si tiene problemas para instalar o correr playwright dirígase a la guía de instalación

También le puede servir verificar como las pruebas automátizadas se definen en CI


Kraken E2E

Ejemplo en CI

Instrucciones para instalar en máquina en Unix like systems (Linux, Mac OS (no probado)).

1. Instalar dependencias

npm install

2. Instalar dependencias nivel de sistema

3. Correr tests de kraken

NOTA: El before step de kraken se encargará de levantar una instancia de Ghost usando un contenedor en el puerto 9333. por lo cual solo el siguiente llamado es suficiente para hacer el bootstrap.

npm run kraken

NOTA: este comando se encargará de recrear el contenedor de ghost y su base de datos en cada ocasión que corra


Visual Regression Testing

Instrucciones para correr pruebas de VRT en playwright y kraken.

Actualmente las pruebas de VRT se corren en cada commit de este repositorio, como se puede ver en los siguientes workflows:

Los resultados son publicados automáticamente a la rama gh-pages de este repositorio y por lo tanto se sirve como contenido web en los siguientes links:

Para correr las pruebas en modos VRT se hace necesario lo siguiente:


Playwright VRT

Siga las instrucciones descritas para correr playwright E2E ignorando el paso 3, y luego:

1. Run the test suite in both Ghost versions

CI=1 GHOST_VRT=1 GHOST_VERSION=4.41.1 npx playwright test --workers 1
CI=1 GHOST_VRT=1 GHOST_VERSION=4.36 npx playwright test --workers 1

2. Artifacts processing and report generation

npm run reporter -- --process playwright --prev 4.36 --post 4.41.1

Esto generará un archivo en la base del repositorio playwright.html.


Kraken VRT

Siga las instrucciones descritas para correr kraken E2E ignorando el paso 3, y luego:

1. Run the test suite in both Ghost versions

NOTA: El before step de kraken se encargará de levantar una instancia de Ghost usando un contenedor en el puerto 9333. por lo cual solo el siguiente llamado es suficiente para hacer el bootstrap.

CI=1 GHOST_VRT=1 GHOST_VERSION=4.41.1 npm run kraken
CI=1 GHOST_VRT=1 GHOST_VERSION=4.36 npm run kraken

2. Artifacts processing and report generation

npm run reporter -- --process playwright --prev 4.36 --post 4.41.1

Esto generará un archivo en la base del repositorio playwright.html.

About processing test run artifacts

La automatización de este procesamiento se encuentra en el script reporter donde se toman los resultados de los screenshots, se analizan con resembleJS y luego se aplican un template HTML usando nunjucks.

Data Validation Testing

Instrucciones para correr pruebas de validación de datos en playwright y kraken.

Explicación e inventario: Data Validation Scenarios

Playwright Data

Ejemplo en CI

Siga las instrucciones descritas para correr playwright E2E ignorando el paso 3, y luego:

Correr las pruebas:

NOTA: este comando se encargará de crear/recrear el contenedor de ghost y su base de datos en cada ocasión que corra

npm run test-data

Kraken Data

Siga las mismas instrucciones para correr kraken E2E, son las mismas pruebas.

Tips

Si tiene problemas para instalar o correr playwright dirígase a la guía de instalación

También le puede servir verificar como las pruebas automátizadas se definen en CI

Authors

About

Educational purposes

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 4

  •  
  •  
  •  
  •