Cucumber Francisco Javier Cervigon Ruckauer

Cucumber

Gherkin es de gran ayuda para los stakeholders (negocio, comerciales, etc.), para product owners y testers, proporcionando una forma sencilla de escribir test para que puedan ser entendidos por cualquiera.

Las herramientas que entienden Gherkin

En la siguiente tabla se muestran algunas de las herramientas disponibles que entienden Gherkin, son herramientas con las que podrás utilizar BDD. La más conocida es Cucumber pero hay muchas más y disponibles para diferentes lenguajes. Véamos las más destacadas y los lenguajes en los que se suelen utilizar (os señalo los más conocidos en negrita):
JavaJBehave , JDave , InstinctbeanSpec
CCSpec
C#NSpec, NBehave
.NETNSpec, NBehave, SpecFlow
PHPPHPSpec, Behat
RubyRSpec, Cucumber
JavaScriptJSSpec, jspec
PhythonFreshen

Gracias a estas herramientas se pueden ejecutar pruebas automatizadas escritas en texto plano utilizando las ideas de BDD. Estas pruebas interactúan directamente con el código de la aplicación y están escritas en un lenguaje que cualquier persona puede entender, es decir, Gherkin, que representa la forma en la que se escriben estas pruebas en texto plano.
Cucumber marcó un antes y un después en la difusión de BDD y fue justo en este contexto cuando se estandarizó la sintaxis de especificación en texto plano, conocida como Gherkin. Por ello nos fijaremos en Cucumber. Pero que la tabla no os confunda, Cucumber está escrito en Ruby y a menudo las pruebas se realicen en ese lenguaje, pero también se puede utilizar con aplicaciones escritas en otros lenguajes de programación, como Java o .Net.
Sea cual sea el lenguaje en el que se realicen las pruebas, Cucumber ejecuta las pruebas tal y como os enseño a continuación:

Cómo ejecuta Cucumber una prueba

Vamos a ver cómo ejecuta Cucumber una prueba, por ser la herramienta más popular. Podemos diferenciar dos partes en una prueba:
– El caso de prueba, está en los archivos .feature (que están en la carpeta features). Son el dadocuandoentoncespero e y.  Tienen esta pinta:

Y la definición de un caso de prueba(donde se implementa la prueba, se ubican dentro de la carpeta step_definitions).

Cada escenario en Gherkin contiene una serie de casos de prueba escritos en un lenguaje que entienden todos. Estos también forman la documentación del sistema y necesitan la definición de los caso de pruebapara decir a Cucumber qué es lo que tiene que hacer.
Cuando Cucumber ejecuta un caso de prueba (Dado, Cuando, Entonces, Y, Pero), en un escenario, busca la definición correspondiente de dicho caso de prueba, es decir, la que coincida su texto, y la ejecuta el código que tenga en ella.
Para las imágenes de antes:
1. Cucumber cogería primero el caso de prueba definido en una carpeta llamada features,un archivo con extensión .features que dice Dado un contexto inicial
  1. 2. A continuación, busca en una carpeta llamada step_definitions, la definición de caso de prueba que le corresponda. En este caso es:
  2. 3. Ejecuta el código que tenga dentro.
  3. 4. Repite el mismo proceso para el resto de los casos de prueba.
Francisco Javier Cervigon Ruckauer

No hay comentarios:

Publicar un comentario