From 4801489f9ef8b844ed2dd960e8f178fc3417f53f Mon Sep 17 00:00:00 2001 From: UO276900 Date: Sun, 1 May 2022 19:42:36 +0200 Subject: [PATCH 01/13] Caso2 Registro End2End --- webapp/e2e/steps/register-form.steps.ts | 34 ++++++++++++++++++++++++- 1 file changed, 33 insertions(+), 1 deletion(-) diff --git a/webapp/e2e/steps/register-form.steps.ts b/webapp/e2e/steps/register-form.steps.ts index 631f496..f315e67 100644 --- a/webapp/e2e/steps/register-form.steps.ts +++ b/webapp/e2e/steps/register-form.steps.ts @@ -54,7 +54,39 @@ defineFeature(feature, test => { then("I should be redirected to the login page", async () => { await page.waitForNavigation() await page.waitForTimeout(2000); - await expect(page).toMatch("Entrar en Sesión"); + await expect(page).toMatch("Iniciar Sesión"); + }); + }); + test("User Register blank email", ({given,when,then}) => { + let email:string + let name:string + let dni:string + let password:string + let confirmPassword:string + + given("Name, Dni, Password and confirmPassword of a user", () => { + email = " " + name = "Adri" + dni = "12345678" + password = "adri" + confirmPassword = "adri" + }); + + when("I click in Regístrate", async () => { + await page.setViewport({ width: 1200, height: 1300 }); + await expect(page).toMatch("Sedimentarias"); + await expect(page).toClick("a[href='/register']"); + await expect(page).toMatch("Crear cuenta"); + await expect(page).toFill("input[name='email']", email); + await expect(page).toFill("input[name='name']", name); + await expect(page).toFill("input[name='dni']", dni); + await expect(page).toFill("input[name='password']", password); + await expect(page).toFill("input[name='confirmPassword']", confirmPassword); + await expect(page).toClick('button', { text: 'Regístrate' }); + }); + + then("Warning below email", async () => { + await expect(page).toMatch("El campo no puede estar vacio"); }); }); }); From 3aae079ae8cca24e3a953fbda540755f1b7bcd0b Mon Sep 17 00:00:00 2001 From: UO276900 Date: Sun, 1 May 2022 19:45:48 +0200 Subject: [PATCH 02/13] Caso3 Register End2End --- webapp/e2e/steps/register-form.steps.ts | 32 +++++++++++++++++++++++++ 1 file changed, 32 insertions(+) diff --git a/webapp/e2e/steps/register-form.steps.ts b/webapp/e2e/steps/register-form.steps.ts index f315e67..e0ed892 100644 --- a/webapp/e2e/steps/register-form.steps.ts +++ b/webapp/e2e/steps/register-form.steps.ts @@ -89,4 +89,36 @@ defineFeature(feature, test => { await expect(page).toMatch("El campo no puede estar vacio"); }); }); + test("User Register blank name", ({given,when,then}) => { + let email:string + let name:string + let dni:string + let password:string + let confirmPassword:string + + given("Email, Dni, Password and confirmPassword of a user", () => { + email = "adri@gmail.com" + name = " " + dni = "12345678" + password = "adri" + confirmPassword = "adri" + }); + + when("I click in Regístrate", async () => { + await page.setViewport({ width: 1200, height: 1300 }); + await expect(page).toMatch("Sedimentarias"); + await expect(page).toClick("a[href='/register']"); + await expect(page).toMatch("Crear cuenta"); + await expect(page).toFill("input[name='email']", email); + await expect(page).toFill("input[name='name']", name); + await expect(page).toFill("input[name='dni']", dni); + await expect(page).toFill("input[name='password']", password); + await expect(page).toFill("input[name='confirmPassword']", confirmPassword); + await expect(page).toClick('button', { text: 'Regístrate' }); + }); + + then("Warning below name", async () => { + await expect(page).toMatch("El campo no puede estar vacio"); + }); + }); }); From 76ef70c7e34d9bfd5d685dfd7fbe369120e42050 Mon Sep 17 00:00:00 2001 From: UO276900 Date: Sun, 1 May 2022 19:47:31 +0200 Subject: [PATCH 03/13] Caso4 Register End2End --- webapp/e2e/steps/register-form.steps.ts | 36 +++++++++++++++++++++++-- 1 file changed, 34 insertions(+), 2 deletions(-) diff --git a/webapp/e2e/steps/register-form.steps.ts b/webapp/e2e/steps/register-form.steps.ts index e0ed892..88d05e5 100644 --- a/webapp/e2e/steps/register-form.steps.ts +++ b/webapp/e2e/steps/register-form.steps.ts @@ -65,7 +65,7 @@ defineFeature(feature, test => { let confirmPassword:string given("Name, Dni, Password and confirmPassword of a user", () => { - email = " " + email = "" name = "Adri" dni = "12345678" password = "adri" @@ -98,7 +98,7 @@ defineFeature(feature, test => { given("Email, Dni, Password and confirmPassword of a user", () => { email = "adri@gmail.com" - name = " " + name = "" dni = "12345678" password = "adri" confirmPassword = "adri" @@ -121,4 +121,36 @@ defineFeature(feature, test => { await expect(page).toMatch("El campo no puede estar vacio"); }); }); + test("User Register blank dni", ({given,when,then}) => { + let email:string + let name:string + let dni:string + let password:string + let confirmPassword:string + + given("Email, Name, Password and confirmPassword of a user", () => { + email = "adrian@gmail.com" + name = "Adri" + dni = "" + password = "adri" + confirmPassword = "adri" + }); + + when("I click in Regístrate", async () => { + await page.setViewport({ width: 1200, height: 1300 }); + await expect(page).toMatch("Sedimentarias"); + await expect(page).toClick("a[href='/register']"); + await expect(page).toMatch("Crear cuenta"); + await expect(page).toFill("input[name='email']", email); + await expect(page).toFill("input[name='name']", name); + await expect(page).toFill("input[name='dni']", dni); + await expect(page).toFill("input[name='password']", password); + await expect(page).toFill("input[name='confirmPassword']", confirmPassword); + await expect(page).toClick('button', { text: 'Regístrate' }); + }); + + then("Warning below dni", async () => { + await expect(page).toMatch("El campo no puede estar vacio"); + }); + }); }); From e5bb237b0eec50d093e1f36752969edbeb490467 Mon Sep 17 00:00:00 2001 From: UO276900 Date: Sun, 1 May 2022 19:51:03 +0200 Subject: [PATCH 04/13] Caso5 Register End2End --- webapp/e2e/steps/register-form.steps.ts | 64 +++++++++++++++++++++++++ 1 file changed, 64 insertions(+) diff --git a/webapp/e2e/steps/register-form.steps.ts b/webapp/e2e/steps/register-form.steps.ts index 88d05e5..26061fa 100644 --- a/webapp/e2e/steps/register-form.steps.ts +++ b/webapp/e2e/steps/register-form.steps.ts @@ -153,4 +153,68 @@ defineFeature(feature, test => { await expect(page).toMatch("El campo no puede estar vacio"); }); }); + test("User Register blank password", ({given,when,then}) => { + let email:string + let name:string + let dni:string + let password:string + let confirmPassword:string + + given("Email, Name, Dni and confirmPassword of a user", () => { + email = "adrian@gmail.com" + name = "Adri" + dni = "123456" + password = "" + confirmPassword = "adri" + }); + + when("I click in Regístrate", async () => { + await page.setViewport({ width: 1200, height: 1300 }); + await expect(page).toMatch("Sedimentarias"); + await expect(page).toClick("a[href='/register']"); + await expect(page).toMatch("Crear cuenta"); + await expect(page).toFill("input[name='email']", email); + await expect(page).toFill("input[name='name']", name); + await expect(page).toFill("input[name='dni']", dni); + await expect(page).toFill("input[name='password']", password); + await expect(page).toFill("input[name='confirmPassword']", confirmPassword); + await expect(page).toClick('button', { text: 'Regístrate' }); + }); + + then("Warning below password", async () => { + await expect(page).toMatch("El campo no puede estar vacio"); + }); + }); + test("User Register blank confirm password", ({given,when,then}) => { + let email:string + let name:string + let dni:string + let password:string + let confirmPassword:string + + given("Email, Name, Dni Password of a user", () => { + email = "adrian@gmail.com" + name = "Adri" + dni = "123456" + password = "adri" + confirmPassword = "" + }); + + when("I click in Regístrate", async () => { + await page.setViewport({ width: 1200, height: 1300 }); + await expect(page).toMatch("Sedimentarias"); + await expect(page).toClick("a[href='/register']"); + await expect(page).toMatch("Crear cuenta"); + await expect(page).toFill("input[name='email']", email); + await expect(page).toFill("input[name='name']", name); + await expect(page).toFill("input[name='dni']", dni); + await expect(page).toFill("input[name='password']", password); + await expect(page).toFill("input[name='confirmPassword']", confirmPassword); + await expect(page).toClick('button', { text: 'Regístrate' }); + }); + + then("Warning below confirmPassword", async () => { + await expect(page).toMatch("El campo no puede estar vacio"); + }); + }); }); From cc253166552b1d56897d7e735834b6f925e72c3c Mon Sep 17 00:00:00 2001 From: UO276900 Date: Sun, 1 May 2022 19:53:29 +0200 Subject: [PATCH 05/13] =?UTF-8?q?A=C3=B1adido=20trim=20en=20los=20campos?= =?UTF-8?q?=20de=20Registro=20para=20evitar=20espacios=20en=20blanco?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- webapp/src/components/Register.tsx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/webapp/src/components/Register.tsx b/webapp/src/components/Register.tsx index b05bba4..f6d4bc7 100644 --- a/webapp/src/components/Register.tsx +++ b/webapp/src/components/Register.tsx @@ -20,7 +20,7 @@ type NotificationType = { }; const checkParams = (text: String) => { - return text === "" || text == null; + return text.trim() === "" || text == null; }; const checkPaswwords = (repPass: String, pass: String) => { From 77d949a0eff5bdb390c64e86ad52d7e920924be6 Mon Sep 17 00:00:00 2001 From: UO276900 Date: Sun, 1 May 2022 19:55:50 +0200 Subject: [PATCH 06/13] =?UTF-8?q?A=C3=B1adido=20trim=20en=20verificacion?= =?UTF-8?q?=20campos=20Login?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- webapp/src/components/Login.tsx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/webapp/src/components/Login.tsx b/webapp/src/components/Login.tsx index d83d4d6..5c72ff9 100644 --- a/webapp/src/components/Login.tsx +++ b/webapp/src/components/Login.tsx @@ -14,7 +14,7 @@ import axios from 'axios'; import { Grid, Link, Typography } from '@mui/material'; const checkParams = (text: String) => { - return text === "" || text == null; + return text.trim() === "" || text == null; } type EmailFormProps = { From 8b703541ff76451d6e94ef79d44fb2fe6cb7048f Mon Sep 17 00:00:00 2001 From: UO276900 Date: Sun, 1 May 2022 19:58:31 +0200 Subject: [PATCH 07/13] Caso6 Register End2End --- webapp/e2e/steps/register-form.steps.ts | 32 +++++++++++++++++++++++++ 1 file changed, 32 insertions(+) diff --git a/webapp/e2e/steps/register-form.steps.ts b/webapp/e2e/steps/register-form.steps.ts index 26061fa..4d9a493 100644 --- a/webapp/e2e/steps/register-form.steps.ts +++ b/webapp/e2e/steps/register-form.steps.ts @@ -217,4 +217,36 @@ defineFeature(feature, test => { await expect(page).toMatch("El campo no puede estar vacio"); }); }); + test("Confirm Password and Password don't match", ({given,when,then}) => { + let email:string + let name:string + let dni:string + let password:string + let confirmPassword:string + + given("Email, Name, Dni Password of a user", () => { + email = "adrian@gmail.com" + name = "Adri" + dni = "123456" + password = "adri" + confirmPassword = "manuel" + }); + + when("I click in Regístrate", async () => { + await page.setViewport({ width: 1200, height: 1300 }); + await expect(page).toMatch("Sedimentarias"); + await expect(page).toClick("a[href='/register']"); + await expect(page).toMatch("Crear cuenta"); + await expect(page).toFill("input[name='email']", email); + await expect(page).toFill("input[name='name']", name); + await expect(page).toFill("input[name='dni']", dni); + await expect(page).toFill("input[name='password']", password); + await expect(page).toFill("input[name='confirmPassword']", confirmPassword); + await expect(page).toClick('button', { text: 'Regístrate' }); + }); + + then("Warning below confirmPassword", async () => { + await expect(page).toMatch("Las contraseñas no coinciden"); + }); + }); }); From 2b61a2b5c2b6f439583ec0d78cea19eddb06f834 Mon Sep 17 00:00:00 2001 From: UO276900 Date: Sun, 1 May 2022 20:22:44 +0200 Subject: [PATCH 08/13] Completado feature test end2end Register --- webapp/e2e/features/register-form.feature | 26 ++++++++++++++++++++++- 1 file changed, 25 insertions(+), 1 deletion(-) diff --git a/webapp/e2e/features/register-form.feature b/webapp/e2e/features/register-form.feature index df46788..11e2610 100644 --- a/webapp/e2e/features/register-form.feature +++ b/webapp/e2e/features/register-form.feature @@ -3,4 +3,28 @@ Feature: Registering a new user Scenario: The user is not registered in the site Given An unregistered user When I fill the data in the form and press Regístrate - Then I should be redirected to Login Page \ No newline at end of file + Then I should be redirected to Login Page +Scenario: User Register blank email + Given Name, Dni, Password and confirmPassword of a user + When I fill the data in the form and press Regístrate + Then Warning below email +Scenario: User Register blank name + Given Email, Dni, Password and confirmPassword of a user + When I fill the data in the form and press Regístrate + Then Warning below name +Scenario: User Register blank dni + Given Name, Email, Password and confirmPassword of a user + When I fill the data in the form and press Regístrate + Then Warning below dni +Scenario: User Register blank password + Given Name, Dni, Email and confirmPassword of a user + When I fill the data in the form and press Regístrate + Then Warning below Password +Scenario: User Register blank confirmPassword + Given Name, Dni, Password and Email of a user + When I fill the data in the form and press Regístrate + Then Warning below confirmPassword +Scenario: Password and Confirm Password don't match + Given Email, Name, Dni, Password and confirmPassword of a user + When I fill the data in the form and press Regístrate + Then Warning below confirmPassword (Las contraseñas no coinciden) \ No newline at end of file From 57465f605ed5a725abad0903ca1712810f4319f5 Mon Sep 17 00:00:00 2001 From: UO276900 Date: Sun, 1 May 2022 20:24:44 +0200 Subject: [PATCH 09/13] Caso2 Login End2End --- webapp/e2e/steps/login-form.steps.ts | 23 +++++++++++++++++++++++ 1 file changed, 23 insertions(+) diff --git a/webapp/e2e/steps/login-form.steps.ts b/webapp/e2e/steps/login-form.steps.ts index 48c9042..95081af 100644 --- a/webapp/e2e/steps/login-form.steps.ts +++ b/webapp/e2e/steps/login-form.steps.ts @@ -48,4 +48,27 @@ defineFeature(feature, test => { }); }); + test("User Login", ({given,when,then}) => { + let email:string + let password:string + + given("Blank Email and password of a user", () => { + email = " " + password = "admin" + }); + + when("I click in Iniciar Sesion", async () => { + await page.setViewport({ width: 1200, height: 1300 }); + await expect(page).toMatch("Sedimentarias"); + await expect(page).toClick("a[href='/login']"); + await expect(page).toFill("input[name='email']", email); + await expect(page).toFill("input[name='password']", password); + await expect(page).toClick('button', { text: 'Iniciar Sesión' }); + }); + + then("Warning below email", async () => { + await expect(page).toMatch("El campo no puede estar vacio"); + }); + }); + }); \ No newline at end of file From ff44a6b4b6701fa85368ed80644d35908af540e6 Mon Sep 17 00:00:00 2001 From: UO276900 Date: Sun, 1 May 2022 20:26:21 +0200 Subject: [PATCH 10/13] Caso3 Login End2End --- webapp/e2e/steps/login-form.steps.ts | 22 ++++++++++++++++++++++ 1 file changed, 22 insertions(+) diff --git a/webapp/e2e/steps/login-form.steps.ts b/webapp/e2e/steps/login-form.steps.ts index 95081af..afed0be 100644 --- a/webapp/e2e/steps/login-form.steps.ts +++ b/webapp/e2e/steps/login-form.steps.ts @@ -70,5 +70,27 @@ defineFeature(feature, test => { await expect(page).toMatch("El campo no puede estar vacio"); }); }); + test("User Login", ({given,when,then}) => { + let email:string + let password:string + + given("Email and blank password of a user", () => { + email = "adri@email.com" + password = " " + }); + + when("I click in Iniciar Sesion", async () => { + await page.setViewport({ width: 1200, height: 1300 }); + await expect(page).toMatch("Sedimentarias"); + await expect(page).toClick("a[href='/login']"); + await expect(page).toFill("input[name='email']", email); + await expect(page).toFill("input[name='password']", password); + await expect(page).toClick('button', { text: 'Iniciar Sesión' }); + }); + + then("Warning below password", async () => { + await expect(page).toMatch("El campo no puede estar vacio"); + }); + }); }); \ No newline at end of file From 127865c2b0bebf5619ad88cf6b1e8b9d7f9919b2 Mon Sep 17 00:00:00 2001 From: UO276900 Date: Sun, 1 May 2022 20:32:08 +0200 Subject: [PATCH 11/13] Feature Login Test End2End --- webapp/e2e/features/login-form.feature | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/webapp/e2e/features/login-form.feature b/webapp/e2e/features/login-form.feature index f851bc0..6691632 100644 --- a/webapp/e2e/features/login-form.feature +++ b/webapp/e2e/features/login-form.feature @@ -3,4 +3,12 @@ Feature: Login a user on the web page Scenario: The user log in Given Email and password of a user When I click in Iniciar Sesión - Then I should be redirected to the catalog \ No newline at end of file + Then I should be redirected to the catalog +Scenario: User log in blank email + Given Blank Email and password of a user + When I click in Iniciar Sesión + Then Warning message below Email +Scenario: User log in blank password + Given Email and blank password of a user + When I click in Iniciar Sesión + Then Warning message below Password \ No newline at end of file From 1fcfd184837388c1dc77c75b02c1fc303e31fa22 Mon Sep 17 00:00:00 2001 From: UO276900 Date: Sun, 1 May 2022 20:42:23 +0200 Subject: [PATCH 12/13] Orders End2End Test --- webapp/e2e/steps/orders-form.steps.ts | 56 +++++++++++++++++++++++++++ 1 file changed, 56 insertions(+) create mode 100644 webapp/e2e/steps/orders-form.steps.ts diff --git a/webapp/e2e/steps/orders-form.steps.ts b/webapp/e2e/steps/orders-form.steps.ts new file mode 100644 index 0000000..4ac1ff2 --- /dev/null +++ b/webapp/e2e/steps/orders-form.steps.ts @@ -0,0 +1,56 @@ +import { defineFeature, loadFeature } from 'jest-cucumber'; +import puppeteer from "puppeteer"; + +const feature = loadFeature('./features/login.feature'); + +let page: puppeteer.Page; +let browser: puppeteer.Browser; + +defineFeature(feature, test => { + + jest.setTimeout(100000) + beforeAll(async () => { + + browser = process.env.GITHUB_ACTIONS + ? await puppeteer.launch() + : await puppeteer.launch({ headless: true, slowMo:100}); //false to run tests locally + page = await browser.newPage(); + + await page + .goto("http://localhost:3000", { + waitUntil: "networkidle0", + }) + .catch(() => {}); + }); + + test("Orders in profile", ({given,when,then}) => { + let email:string + let password:string + + given("Admin session", () => { + email = "admin@gmail.com" + password = "admin" + }); + + when("I click in Iniciar Sesion", async () => { + await page.setViewport({ width: 1200, height: 1300 }); + await expect(page).toMatch("Sedimentarias"); + await expect(page).toClick("a[href='/login']"); + await expect(page).toFill("input[name='email']", email); + await expect(page).toFill("input[name='password']", password); + await expect(page).toClick('button', { text: 'Iniciar Sesión' }); + await page.waitForNavigation() + await page.waitForTimeout(2000); + await expect(page).toMatch("Yeso"); + await expect(page).toClick("a[href='/orders']"); + + + }); + + then("I should see admin order's history", async () => { + await page.waitForNavigation() + await page.waitForTimeout(2000); + await expect(page).toMatch("Cuarcita"); + }); + }); +}); From 8790deabe1535b5782adb2d5ea96fa3983f9cd16 Mon Sep 17 00:00:00 2001 From: UO276900 Date: Sun, 1 May 2022 20:44:37 +0200 Subject: [PATCH 13/13] Features Orders End2End --- webapp/e2e/features/orders-form.feature | 6 ++++++ 1 file changed, 6 insertions(+) create mode 100644 webapp/e2e/features/orders-form.feature diff --git a/webapp/e2e/features/orders-form.feature b/webapp/e2e/features/orders-form.feature new file mode 100644 index 0000000..d3b0d27 --- /dev/null +++ b/webapp/e2e/features/orders-form.feature @@ -0,0 +1,6 @@ +Feature: Seeing orders history of a user + +Scenario: Orders of user "admin" + Given Registered user admin + When Log In and click on my profile + Then I should see my orders \ No newline at end of file