-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathauth.test.js
114 lines (100 loc) · 2.76 KB
/
auth.test.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
"use strict";
const request = require("supertest");
const app = require("../app");
const {
commonBeforeAll,
commonBeforeEach,
commonAfterEach,
commonAfterAll,
} = require("./_testCommon");
beforeAll(commonBeforeAll);
beforeEach(commonBeforeEach);
afterEach(commonAfterEach);
afterAll(commonAfterAll);
/************************************** POST /auth/token */
describe("POST /auth/token", function () {
test("works", async function () {
const resp = await request(app)
.post("/auth/token")
.send({
username: "u1",
password: "password1",
});
expect(resp.body).toEqual({
"token": expect.any(String),
});
});
test("unauth with non-existent user", async function () {
const resp = await request(app)
.post("/auth/token")
.send({
username: "no-such-user",
password: "password1",
});
expect(resp.statusCode).toEqual(401);
});
test("unauth with wrong password", async function () {
const resp = await request(app)
.post("/auth/token")
.send({
username: "u1",
password: "nope",
});
expect(resp.statusCode).toEqual(401);
});
test("bad request with missing data", async function () {
const resp = await request(app)
.post("/auth/token")
.send({
username: "u1",
});
expect(resp.statusCode).toEqual(400);
});
test("bad request with invalid data", async function () {
const resp = await request(app)
.post("/auth/token")
.send({
username: 42,
password: "above-is-a-number",
});
expect(resp.statusCode).toEqual(400);
});
});
/************************************** POST /auth/register */
describe("POST /auth/register", function () {
test("works for anon", async function () {
const resp = await request(app)
.post("/auth/register")
.send({
username: "new",
firstName: "first",
lastName: "last",
password: "password",
email: "[email protected]",
});
expect(resp.statusCode).toEqual(201);
expect(resp.body).toEqual({
"token": expect.any(String),
});
});
test("bad request with missing fields", async function () {
const resp = await request(app)
.post("/auth/register")
.send({
username: "new",
});
expect(resp.statusCode).toEqual(400);
});
test("bad request with invalid data", async function () {
const resp = await request(app)
.post("/auth/register")
.send({
username: "new",
firstName: "first",
lastName: "last",
password: "password",
email: "not-an-email",
});
expect(resp.statusCode).toEqual(400);
});
});