From ea86dc22ce704c85f5f8e4b600e3395ef7ba3612 Mon Sep 17 00:00:00 2001 From: Julien Dessaux Date: Wed, 4 Jan 2023 18:19:08 +0100 Subject: Added more tests --- tests/games.spec.js | 23 +++++++++++++++++++++++ views/game.ejs | 2 +- 2 files changed, 24 insertions(+), 1 deletion(-) create mode 100644 tests/games.spec.js diff --git a/tests/games.spec.js b/tests/games.spec.js new file mode 100644 index 0000000..00ae1e7 --- /dev/null +++ b/tests/games.spec.js @@ -0,0 +1,23 @@ +import { beforeEach, describe, test } from "vitest"; +import supertest from "supertest"; + +import app from "../main.js"; + +describe.concurrent("Games handlers tests", function() { + describe.concurrent("When not logged in", function() { + test("GET /games", async function() { await supertest(app).get("/games").expect("Content-Type", /text\/plain/).expect(302, /Redirecting to \/login$/); }); + test("GET /games/1", async function() { await supertest(app).get("/games").expect("Content-Type", /text\/plain/).expect(302, /Redirecting to \/login$/); }); + }); + describe.concurrent("With valid credentials", function() { + beforeEach(async function(ctx) { + const authResponse = await supertest(app).post("/login") + .send("username=Alice&password=Alice42!") + .expect("Content-Type", /text\/plain/) + .expect("set-cookie", /JDMSessionId=/) + .expect(302, /Redirecting to \/games$/); + ctx.cookie = authResponse.get("Set-Cookie"); + }); + test("GET /games", async function(ctx) { await supertest(app).get("/games").set("Cookie", ctx.cookie).expect("Content-Type", /text\/html/).expect(200, /Alice vs Bob<\/a><\/td>/); }); + test("GET /games/1", async function(ctx) { await supertest(app).get("/games/1").set("Cookie", ctx.cookie).expect("Content-Type", /text\/html/).expect(200, /

Alice vs Bob<\/h2>/); }); + }); +}); diff --git a/views/game.ejs b/views/game.ejs index 7fae405..acbb95f 100644 --- a/views/game.ejs +++ b/views/game.ejs @@ -1,5 +1,5 @@ <%- include("header") %> -

À vous de jouer

+

<%- data.name %>

-- cgit v1.2.3