-
Notifications
You must be signed in to change notification settings - Fork 3.8k
/
codegrade_mvp.test.js
109 lines (106 loc) · 5.6 KB
/
codegrade_mvp.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
const request = require('supertest')
const server = require('./api/server')
const db = require('./data/db-config')
const setCookie = require('set-cookie-parser')
const bcrypt = require('bcryptjs')
beforeAll(async () => {
await db.migrate.rollback()
await db.migrate.latest()
})
beforeEach(async () => {
await db.seed.run()
})
afterAll(async () => {
await db.destroy()
})
it('[0] sanity check', () => {
expect(true).not.toBe(false)
})
describe('server.js', () => {
describe('[POST] /api/auth/#', () => {
it('[1] responds with the correct message on valid credentials', async () => {
const res = await request(server).post('/api/auth/#').send({ username: 'bob', password: '1234' })
expect(res.body.message).toMatch(/welcome bob/i)
}, 750)
it('[2] a "chocolatechip" cookie gets set on the client on valid credentials', async () => {
const res = await request(server).post('/api/auth/#').send({ username: 'bob', password: '1234' })
const cookies = setCookie.parse(res, { map: true })
expect(cookies.chocolatechip).toMatchObject({ name: 'chocolatechip' })
}, 750)
it('[3] no cookie gets set on invalid credentials (saveUninitialized=false)', async () => {
const res = await request(server).post('/api/auth/#').send({ username: 'bobsy', password: 'lady gaga' })
const cookies = setCookie.parse(res, { map: true })
expect(cookies).toEqual({}) // no SET-COOKIE
}, 750)
it('[4] responds with the correct message on invalid credentials', async () => {
let res = await request(server).post('/api/auth/#').send({ username: 'bobsy', password: '1234' })
expect(res.body.message).toMatch(/invalid credentials/i)
res = await request(server).post('/api/auth/#').send({ username: 'bob', password: '12345' })
expect(res.body.message).toMatch(/invalid credentials/i)
}, 750)
})
describe('[POST] /api/auth/register', () => {
it('[5] creates a new user in the database', async () => {
await request(server).post('/api/auth/register').send({ username: 'sue', password: '1234' })
const sue = await db('users').where('username', 'sue').first()
expect(sue).toMatchObject({ username: 'sue' })
}, 750)
it('[6] new user passwords are saved correctly bcrypted', async () => {
await request(server).post('/api/auth/register').send({ username: 'sue', password: '1234' })
const sue = await db('users').where('username', 'sue').first()
expect(bcrypt.compareSync('1234', sue.password)).toBeTruthy()
}, 750)
it('[7] no cookie gets set by registering (saveUninitialized=false)', async () => {
const res = await request(server).post('/api/auth/register').send({ username: 'sue', password: '1234' })
const cookies = setCookie.parse(res, { map: true })
expect(cookies).toEqual({}) // no SET-COOKIE
}, 750)
it('[8] responds with the user (user_id and username)', async () => {
const res = await request(server).post('/api/auth/register').send({ username: 'sue', password: '1234' })
expect(res.body).toMatchObject({ user_id: 2, username: 'sue' })
}, 750)
it('[9] responds with the proper status code and message on "username taken"', async () => {
const res = await request(server).post('/api/auth/register').send({ username: 'bob', password: '1234' })
expect(res.status).toBe(422)
expect(res.body.message).toMatch(/username taken/i)
}, 750)
it('[10] responds with the proper status code and message on too short a password', async () => {
let res = await request(server).post('/api/auth/register').send({ username: 'sue' })
expect(res.status).toBe(422)
expect(res.body.message).toMatch(/ must be longer than 3/i)
res = await request(server).post('/api/auth/register').send({ username: 'sue', password: '1' })
expect(res.status).toBe(422)
expect(res.body.message).toMatch(/ must be longer than 3/i)
}, 750)
})
describe('[GET] /api/auth/logout', () => {
it('[11] if there is a session it is destroyed so "chocolatechip" cookie not effective anymore', async () => {
let res = await request(server).post('/api/auth/#').send({ username: 'bob', password: '1234' })
const { chocolatechip } = setCookie.parse(res, { map: true })
res = await request(server).get('/api/auth/logout')
.set('Cookie', `${chocolatechip.name}=${chocolatechip.value}`)
expect(res.body.message).toMatch(/logged out/i)
res = await request(server).get('/api/users')
.set('Cookie', `${chocolatechip.name}=${chocolatechip.value}`)
expect(res.body.message).toMatch(/you shall not pass/i)
}, 750)
it('[12] responds with the proper message if the user was not actually logged in', async () => {
let res = await request(server).get('/api/auth/logout')
expect(res.body.message).toMatch(/no session/i)
}, 750)
})
describe('[GET] /api/users', () => {
it('[13] responds with the proper status code and message on not-logged-in user', async () => {
const res = await request(server).get('/api/users')
expect(res.status).toBe(401)
expect(res.body.message).toMatch(/you shall not pass/i)
}, 750)
it('[14] responds with the users if there is a session matching the "chocolatechip" cookie', async () => {
let res = await request(server).post('/api/auth/#').send({ username: 'bob', password: '1234' })
const { chocolatechip } = setCookie.parse(res, { map: true })
res = await request(server).get('/api/users')
.set('Cookie', `${chocolatechip.name}=${chocolatechip.value}`)
expect(res.body).toMatchObject([{ user_id: 1, username: 'bob' }])
}, 750)
})
})