]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blame - server/tests/api/users/users.ts
Introduce follows command
[github/Chocobozzz/PeerTube.git] / server / tests / api / users / users.ts
CommitLineData
a1587156 1/* eslint-disable @typescript-eslint/no-unused-expressions,@typescript-eslint/require-await */
86d13ec2 2
afffe988 3import 'mocha'
4f32032f 4import * as chai from 'chai'
0c1a77e9 5import { HttpStatusCode } from '@shared/core-utils'
0e1dc3e7 6import {
e1c55031 7 addVideoCommentThread,
a890d1e0 8 blockUser,
7c3b7976 9 cleanupTests,
f43db2f4 10 closeAllSequelize,
a890d1e0
C
11 createUser,
12 deleteMe,
7c3b7976 13 flushAndRunServer,
c100a614 14 getAccountRatings,
a890d1e0 15 getBlacklistedVideosList,
e1c55031 16 getCustomConfig,
a890d1e0
C
17 getMyUserInformation,
18 getMyUserVideoQuotaUsed,
19 getMyUserVideoRating,
0c1a77e9 20 getMyVideos,
a890d1e0
C
21 getUserInformation,
22 getUsersList,
23 getUsersListPaginationAndSort,
1f20622f 24 getVideoChannel,
a1587156
C
25 getVideosList,
26 installPlugin,
f43db2f4 27 killallServers,
a890d1e0 28 login,
0c1a77e9 29 logout,
a890d1e0
C
30 makePutBodyRequest,
31 rateVideo,
0c1a77e9 32 refreshToken,
1f20622f 33 registerUserWithChannel,
a890d1e0
C
34 removeUser,
35 removeVideo,
f43db2f4 36 reRunServer,
a890d1e0 37 ServerInfo,
0c1a77e9 38 setAccessTokensToServers,
f43db2f4 39 setTokenField,
a890d1e0
C
40 testImage,
41 unblockUser,
e1c55031 42 updateCustomSubConfig,
a890d1e0
C
43 updateMyAvatar,
44 updateMyUser,
45 updateUser,
46 uploadVideo,
76314386 47 userLogin,
e1c55031 48 waitJobs
0c1a77e9
C
49} from '@shared/extra-utils'
50import { AbuseState, CustomConfig, MyUser, OAuth2ErrorCode, User, UserAdminFlag, UserRole, Video, VideoPlaylistType } from '@shared/models'
0e1dc3e7 51
afffe988
C
52const expect = chai.expect
53
0e1dc3e7
C
54describe('Test users', function () {
55 let server: ServerInfo
56 let accessToken: string
57 let accessTokenUser: string
58 let videoId: number
59 let userId: number
f8b8c36b
C
60 const user = {
61 username: 'user_1',
62 password: 'super password'
63 }
0e1dc3e7
C
64
65 before(async function () {
e212f887 66 this.timeout(30000)
e1c55031
C
67
68 server = await flushAndRunServer(1, {
69 rates_limit: {
70 login: {
71 max: 30
72 }
73 }
74 })
86d13ec2
C
75
76 await setAccessTokensToServers([ server ])
9b474844
C
77
78 await installPlugin({ url: server.url, accessToken: server.accessToken, npmName: 'peertube-theme-background-red' })
0e1dc3e7
C
79 })
80
1eddc9a7
C
81 describe('OAuth client', function () {
82 it('Should create a new client')
0e1dc3e7 83
1eddc9a7 84 it('Should return the first client')
0e1dc3e7 85
1eddc9a7 86 it('Should remove the last client')
0e1dc3e7 87
1eddc9a7
C
88 it('Should not login with an invalid client id', async function () {
89 const client = { id: 'client', secret: server.client.secret }
2d53be02 90 const res = await login(server.url, client, server.user, HttpStatusCode.BAD_REQUEST_400)
0e1dc3e7 91
81628e50 92 expect(res.body.code).to.equal(OAuth2ErrorCode.INVALID_CLIENT)
3866ea02
RK
93 expect(res.body.error).to.contain('client is invalid')
94 expect(res.body.type.startsWith('https://')).to.be.true
81628e50 95 expect(res.body.type).to.contain(OAuth2ErrorCode.INVALID_CLIENT)
1eddc9a7 96 })
0e1dc3e7 97
1eddc9a7
C
98 it('Should not login with an invalid client secret', async function () {
99 const client = { id: server.client.id, secret: 'coucou' }
2d53be02 100 const res = await login(server.url, client, server.user, HttpStatusCode.BAD_REQUEST_400)
0e1dc3e7 101
81628e50 102 expect(res.body.code).to.equal(OAuth2ErrorCode.INVALID_CLIENT)
3866ea02
RK
103 expect(res.body.error).to.contain('client is invalid')
104 expect(res.body.type.startsWith('https://')).to.be.true
81628e50 105 expect(res.body.type).to.contain(OAuth2ErrorCode.INVALID_CLIENT)
1eddc9a7 106 })
0e1dc3e7
C
107 })
108
1eddc9a7 109 describe('Login', function () {
0e1dc3e7 110
1eddc9a7
C
111 it('Should not login with an invalid username', async function () {
112 const user = { username: 'captain crochet', password: server.user.password }
2d53be02 113 const res = await login(server.url, server.client, user, HttpStatusCode.BAD_REQUEST_400)
0e1dc3e7 114
81628e50 115 expect(res.body.code).to.equal(OAuth2ErrorCode.INVALID_GRANT)
3866ea02
RK
116 expect(res.body.error).to.contain('credentials are invalid')
117 expect(res.body.type.startsWith('https://')).to.be.true
81628e50 118 expect(res.body.type).to.contain(OAuth2ErrorCode.INVALID_GRANT)
1eddc9a7 119 })
0e1dc3e7 120
1eddc9a7
C
121 it('Should not login with an invalid password', async function () {
122 const user = { username: server.user.username, password: 'mew_three' }
2d53be02 123 const res = await login(server.url, server.client, user, HttpStatusCode.BAD_REQUEST_400)
0e1dc3e7 124
81628e50 125 expect(res.body.code).to.equal(OAuth2ErrorCode.INVALID_GRANT)
3866ea02
RK
126 expect(res.body.error).to.contain('credentials are invalid')
127 expect(res.body.type.startsWith('https://')).to.be.true
81628e50 128 expect(res.body.type).to.contain(OAuth2ErrorCode.INVALID_GRANT)
1eddc9a7 129 })
0e1dc3e7 130
1eddc9a7
C
131 it('Should not be able to upload a video', async function () {
132 accessToken = 'my_super_token'
0e1dc3e7 133
1eddc9a7 134 const videoAttributes = {}
2d53be02 135 await uploadVideo(server.url, accessToken, videoAttributes, HttpStatusCode.UNAUTHORIZED_401)
1eddc9a7 136 })
0e1dc3e7 137
1eddc9a7
C
138 it('Should not be able to follow', async function () {
139 accessToken = 'my_super_token'
c3d29f69
C
140
141 await server.followsCommand.follow({
142 targets: [ 'http://example.com' ],
143 token: accessToken,
144 expectedStatus: HttpStatusCode.UNAUTHORIZED_401
145 })
1eddc9a7 146 })
0e1dc3e7 147
1eddc9a7 148 it('Should not be able to unfollow')
0e1dc3e7 149
1eddc9a7 150 it('Should be able to login', async function () {
2d53be02 151 const res = await login(server.url, server.client, server.user, HttpStatusCode.OK_200)
0e1dc3e7 152
1eddc9a7
C
153 accessToken = res.body.access_token
154 })
50b4dcce
NB
155
156 it('Should be able to login with an insensitive username', async function () {
157 const user = { username: 'RoOt', password: server.user.password }
2d53be02 158 await login(server.url, server.client, user, HttpStatusCode.OK_200)
50b4dcce
NB
159
160 const user2 = { username: 'rOoT', password: server.user.password }
2d53be02 161 await login(server.url, server.client, user2, HttpStatusCode.OK_200)
50b4dcce
NB
162
163 const user3 = { username: 'ROOt', password: server.user.password }
2d53be02 164 await login(server.url, server.client, user3, HttpStatusCode.OK_200)
50b4dcce 165 })
0e1dc3e7
C
166 })
167
1eddc9a7 168 describe('Upload', function () {
0e1dc3e7 169
1eddc9a7
C
170 it('Should upload the video with the correct token', async function () {
171 const videoAttributes = {}
172 await uploadVideo(server.url, accessToken, videoAttributes)
173 const res = await getVideosList(server.url)
a1587156 174 const video = res.body.data[0]
0e1dc3e7 175
1eddc9a7
C
176 expect(video.account.name).to.equal('root')
177 videoId = video.id
178 })
179
180 it('Should upload the video again with the correct token', async function () {
181 const videoAttributes = {}
182 await uploadVideo(server.url, accessToken, videoAttributes)
183 })
0e1dc3e7
C
184 })
185
1eddc9a7 186 describe('Ratings', function () {
22834691 187
1eddc9a7
C
188 it('Should retrieve a video rating', async function () {
189 await rateVideo(server.url, accessToken, videoId, 'like')
190 const res = await getMyUserVideoRating(server.url, accessToken, videoId)
191 const rating = res.body
c100a614 192
1eddc9a7
C
193 expect(rating.videoId).to.equal(videoId)
194 expect(rating.rating).to.equal('like')
195 })
c100a614 196
1eddc9a7
C
197 it('Should retrieve ratings list', async function () {
198 await rateVideo(server.url, accessToken, videoId, 'like')
22834691 199
2d53be02 200 const res = await getAccountRatings(server.url, server.user.username, server.accessToken, null, HttpStatusCode.OK_200)
22834691 201 const ratings = res.body
0e1dc3e7 202
1eddc9a7 203 expect(ratings.total).to.equal(1)
a1587156
C
204 expect(ratings.data[0].video.id).to.equal(videoId)
205 expect(ratings.data[0].rating).to.equal('like')
1eddc9a7 206 })
0e1dc3e7 207
1eddc9a7
C
208 it('Should retrieve ratings list by rating type', async function () {
209 {
210 const res = await getAccountRatings(server.url, server.user.username, server.accessToken, 'like')
211 const ratings = res.body
212 expect(ratings.data.length).to.equal(1)
213 }
214
215 {
216 const res = await getAccountRatings(server.url, server.user.username, server.accessToken, 'dislike')
217 const ratings = res.body
218 expect(ratings.data.length).to.equal(0)
219 }
220 })
0e1dc3e7
C
221 })
222
1eddc9a7
C
223 describe('Remove video', function () {
224 it('Should not be able to remove the video with an incorrect token', async function () {
2d53be02 225 await removeVideo(server.url, 'bad_token', videoId, HttpStatusCode.UNAUTHORIZED_401)
1eddc9a7 226 })
0e1dc3e7 227
1eddc9a7 228 it('Should not be able to remove the video with the token of another account')
0e1dc3e7 229
1eddc9a7
C
230 it('Should be able to remove the video with the correct token', async function () {
231 await removeVideo(server.url, accessToken, videoId)
232 })
0e1dc3e7
C
233 })
234
1eddc9a7 235 describe('Logout', function () {
7fed6375
C
236 it('Should logout (revoke token)', async function () {
237 await logout(server.url, server.accessToken)
238 })
0e1dc3e7 239
7fed6375 240 it('Should not be able to get the user information', async function () {
2d53be02 241 await getMyUserInformation(server.url, server.accessToken, HttpStatusCode.UNAUTHORIZED_401)
7fed6375 242 })
0e1dc3e7 243
7fed6375 244 it('Should not be able to upload a video', async function () {
2d53be02 245 await uploadVideo(server.url, server.accessToken, { name: 'video' }, HttpStatusCode.UNAUTHORIZED_401)
7fed6375 246 })
0e1dc3e7 247
1eddc9a7
C
248 it('Should not be able to rate a video', async function () {
249 const path = '/api/v1/videos/'
250 const data = {
251 rating: 'likes'
252 }
0e1dc3e7 253
1eddc9a7
C
254 const options = {
255 url: server.url,
256 path: path + videoId,
257 token: 'wrong token',
258 fields: data,
2d53be02 259 statusCodeExpected: HttpStatusCode.UNAUTHORIZED_401
1eddc9a7
C
260 }
261 await makePutBodyRequest(options)
262 })
0e1dc3e7 263
e1c55031 264 it('Should be able to login again', async function () {
f43db2f4
C
265 const res = await login(server.url, server.client, server.user)
266 server.accessToken = res.body.access_token
267 server.refreshToken = res.body.refresh_token
268 })
269
270 it('Should be able to get my user information again', async function () {
271 await getMyUserInformation(server.url, server.accessToken)
272 })
273
274 it('Should have an expired access token', async function () {
275 this.timeout(15000)
276
277 await setTokenField(server.internalServerNumber, server.accessToken, 'accessTokenExpiresAt', new Date().toISOString())
278 await setTokenField(server.internalServerNumber, server.accessToken, 'refreshTokenExpiresAt', new Date().toISOString())
279
280 killallServers([ server ])
281 await reRunServer(server)
282
283 await getMyUserInformation(server.url, server.accessToken, 401)
284 })
285
286 it('Should not be able to refresh an access token with an expired refresh token', async function () {
287 await refreshToken(server, server.refreshToken, 400)
e1c55031 288 })
0e1dc3e7 289
f43db2f4
C
290 it('Should refresh the token', async function () {
291 this.timeout(15000)
292
293 const futureDate = new Date(new Date().getTime() + 1000 * 60).toISOString()
294 await setTokenField(server.internalServerNumber, server.accessToken, 'refreshTokenExpiresAt', futureDate)
0e1dc3e7 295
f43db2f4
C
296 killallServers([ server ])
297 await reRunServer(server)
298
299 const res = await refreshToken(server, server.refreshToken)
300 server.accessToken = res.body.access_token
301 server.refreshToken = res.body.refresh_token
302 })
1eddc9a7 303
e1c55031
C
304 it('Should be able to get my user information again', async function () {
305 await getMyUserInformation(server.url, server.accessToken)
306 })
0e1dc3e7
C
307 })
308
1eddc9a7 309 describe('Creating a user', function () {
ce5496d6 310
1eddc9a7
C
311 it('Should be able to create a new user', async function () {
312 await createUser({
313 url: server.url,
314 accessToken: accessToken,
315 username: user.username,
316 password: user.password,
317 videoQuota: 2 * 1024 * 1024,
3487330d 318 adminFlags: UserAdminFlag.BYPASS_VIDEO_AUTO_BLACKLIST
1eddc9a7
C
319 })
320 })
a76138ff 321
1eddc9a7
C
322 it('Should be able to login with this user', async function () {
323 accessTokenUser = await userLogin(server, user)
324 })
a76138ff 325
1eddc9a7
C
326 it('Should be able to get user information', async function () {
327 const res1 = await getMyUserInformation(server.url, accessTokenUser)
ac0868bc 328 const userMe: MyUser = res1.body
1eddc9a7 329
76314386 330 const res2 = await getUserInformation(server.url, server.accessToken, userMe.id, true)
1eddc9a7
C
331 const userGet: User = res2.body
332
333 for (const user of [ userMe, userGet ]) {
334 expect(user.username).to.equal('user_1')
335 expect(user.email).to.equal('user_1@example.com')
336 expect(user.nsfwPolicy).to.equal('display')
337 expect(user.videoQuota).to.equal(2 * 1024 * 1024)
338 expect(user.roleLabel).to.equal('User')
339 expect(user.id).to.be.a('number')
340 expect(user.account.displayName).to.equal('user_1')
341 expect(user.account.description).to.be.null
342 }
343
344 expect(userMe.adminFlags).to.be.undefined
3487330d 345 expect(userGet.adminFlags).to.equal(UserAdminFlag.BYPASS_VIDEO_AUTO_BLACKLIST)
29128b2f
RK
346
347 expect(userMe.specialPlaylists).to.have.lengthOf(1)
ac0868bc 348 expect(userMe.specialPlaylists[0].type).to.equal(VideoPlaylistType.WATCH_LATER)
76314386
RK
349
350 // Check stats are included with withStats
351 expect(userGet.videosCount).to.be.a('number')
352 expect(userGet.videosCount).to.equal(0)
353 expect(userGet.videoCommentsCount).to.be.a('number')
354 expect(userGet.videoCommentsCount).to.equal(0)
4f32032f
C
355 expect(userGet.abusesCount).to.be.a('number')
356 expect(userGet.abusesCount).to.equal(0)
357 expect(userGet.abusesAcceptedCount).to.be.a('number')
358 expect(userGet.abusesAcceptedCount).to.equal(0)
1eddc9a7 359 })
ce5496d6
C
360 })
361
1eddc9a7 362 describe('My videos & quotas', function () {
11474c3c 363
1eddc9a7 364 it('Should be able to upload a video with this user', async function () {
5600def4 365 this.timeout(10000)
0e1dc3e7 366
1eddc9a7
C
367 const videoAttributes = {
368 name: 'super user video',
369 fixture: 'video_short.webm'
370 }
371 await uploadVideo(server.url, accessTokenUser, videoAttributes)
372 })
afffe988 373
1eddc9a7
C
374 it('Should have video quota updated', async function () {
375 const res = await getMyUserVideoQuotaUsed(server.url, accessTokenUser)
376 const data = res.body
0e1dc3e7 377
1eddc9a7 378 expect(data.videoQuotaUsed).to.equal(218910)
0e1dc3e7 379
1eddc9a7 380 const resUsers = await getUsersList(server.url, server.accessToken)
0e1dc3e7 381
1eddc9a7
C
382 const users: User[] = resUsers.body.data
383 const tmpUser = users.find(u => u.username === user.username)
384 expect(tmpUser.videoQuotaUsed).to.equal(218910)
385 })
0e1dc3e7 386
1eddc9a7
C
387 it('Should be able to list my videos', async function () {
388 const res = await getMyVideos(server.url, accessTokenUser, 0, 5)
389 expect(res.body.total).to.equal(1)
0e1dc3e7 390
1eddc9a7
C
391 const videos = res.body.data
392 expect(videos).to.have.lengthOf(1)
afffe988 393
a1587156 394 const video: Video = videos[0]
a18f275d
C
395 expect(video.name).to.equal('super user video')
396 expect(video.thumbnailPath).to.not.be.null
397 expect(video.previewPath).to.not.be.null
1eddc9a7 398 })
cca1e13b
C
399
400 it('Should be able to search in my videos', async function () {
401 {
402 const res = await getMyVideos(server.url, accessTokenUser, 0, 5, '-createdAt', 'user video')
403 expect(res.body.total).to.equal(1)
404
405 const videos = res.body.data
406 expect(videos).to.have.lengthOf(1)
407 }
408
409 {
410 const res = await getMyVideos(server.url, accessTokenUser, 0, 5, '-createdAt', 'toto')
411 expect(res.body.total).to.equal(0)
412
413 const videos = res.body.data
414 expect(videos).to.have.lengthOf(0)
415 }
416 })
5600def4
C
417
418 it('Should disable webtorrent, enable HLS, and update my quota', async function () {
419 this.timeout(60000)
420
421 {
422 const res = await getCustomConfig(server.url, server.accessToken)
423 const config = res.body as CustomConfig
424 config.transcoding.webtorrent.enabled = false
425 config.transcoding.hls.enabled = true
426 config.transcoding.enabled = true
427 await updateCustomSubConfig(server.url, server.accessToken, config)
428 }
429
430 {
431 const videoAttributes = {
432 name: 'super user video 2',
433 fixture: 'video_short.webm'
434 }
435 await uploadVideo(server.url, accessTokenUser, videoAttributes)
436
437 await waitJobs([ server ])
438 }
439
440 {
441 const res = await getMyUserVideoQuotaUsed(server.url, accessTokenUser)
442 const data = res.body
443
444 expect(data.videoQuotaUsed).to.be.greaterThan(220000)
445 }
446 })
0e1dc3e7
C
447 })
448
1eddc9a7 449 describe('Users listing', function () {
0e1dc3e7 450
1eddc9a7
C
451 it('Should list all the users', async function () {
452 const res = await getUsersList(server.url, server.accessToken)
453 const result = res.body
454 const total = result.total
455 const users = result.data
afffe988 456
1eddc9a7
C
457 expect(total).to.equal(2)
458 expect(users).to.be.an('array')
459 expect(users.length).to.equal(2)
0e1dc3e7 460
a1587156 461 const user = users[0]
1eddc9a7
C
462 expect(user.username).to.equal('user_1')
463 expect(user.email).to.equal('user_1@example.com')
464 expect(user.nsfwPolicy).to.equal('display')
0e1dc3e7 465
a1587156 466 const rootUser = users[1]
1eddc9a7 467 expect(rootUser.username).to.equal('root')
48f07b4a 468 expect(rootUser.email).to.equal('admin' + server.internalServerNumber + '@example.com')
1eddc9a7 469 expect(user.nsfwPolicy).to.equal('display')
afffe988 470
3cc665f4
C
471 expect(rootUser.lastLoginDate).to.exist
472 expect(user.lastLoginDate).to.exist
473
1eddc9a7
C
474 userId = user.id
475 })
0e1dc3e7 476
1eddc9a7
C
477 it('Should list only the first user by username asc', async function () {
478 const res = await getUsersListPaginationAndSort(server.url, server.accessToken, 0, 1, 'username')
0e1dc3e7 479
1eddc9a7
C
480 const result = res.body
481 const total = result.total
482 const users = result.data
a7ba16b6 483
1eddc9a7
C
484 expect(total).to.equal(2)
485 expect(users.length).to.equal(1)
afffe988 486
a1587156 487 const user = users[0]
1eddc9a7 488 expect(user.username).to.equal('root')
48f07b4a 489 expect(user.email).to.equal('admin' + server.internalServerNumber + '@example.com')
1eddc9a7
C
490 expect(user.roleLabel).to.equal('Administrator')
491 expect(user.nsfwPolicy).to.equal('display')
492 })
0e1dc3e7 493
1eddc9a7
C
494 it('Should list only the first user by username desc', async function () {
495 const res = await getUsersListPaginationAndSort(server.url, server.accessToken, 0, 1, '-username')
496 const result = res.body
497 const total = result.total
498 const users = result.data
24b9417c 499
1eddc9a7
C
500 expect(total).to.equal(2)
501 expect(users.length).to.equal(1)
24b9417c 502
a1587156 503 const user = users[0]
1eddc9a7
C
504 expect(user.username).to.equal('user_1')
505 expect(user.email).to.equal('user_1@example.com')
506 expect(user.nsfwPolicy).to.equal('display')
507 })
24b9417c 508
1eddc9a7
C
509 it('Should list only the second user by createdAt desc', async function () {
510 const res = await getUsersListPaginationAndSort(server.url, server.accessToken, 0, 1, '-createdAt')
511 const result = res.body
512 const total = result.total
513 const users = result.data
24b9417c 514
1eddc9a7 515 expect(total).to.equal(2)
24b9417c
C
516 expect(users.length).to.equal(1)
517
a1587156 518 const user = users[0]
1eddc9a7
C
519 expect(user.username).to.equal('user_1')
520 expect(user.email).to.equal('user_1@example.com')
521 expect(user.nsfwPolicy).to.equal('display')
522 })
24b9417c 523
1eddc9a7
C
524 it('Should list all the users by createdAt asc', async function () {
525 const res = await getUsersListPaginationAndSort(server.url, server.accessToken, 0, 2, 'createdAt')
526 const result = res.body
527 const total = result.total
528 const users = result.data
24b9417c 529
1eddc9a7 530 expect(total).to.equal(2)
24b9417c
C
531 expect(users.length).to.equal(2)
532
a1587156
C
533 expect(users[0].username).to.equal('root')
534 expect(users[0].email).to.equal('admin' + server.internalServerNumber + '@example.com')
535 expect(users[0].nsfwPolicy).to.equal('display')
24b9417c 536
a1587156
C
537 expect(users[1].username).to.equal('user_1')
538 expect(users[1].email).to.equal('user_1@example.com')
539 expect(users[1].nsfwPolicy).to.equal('display')
11ba2ab3 540 })
0e1dc3e7 541
1eddc9a7
C
542 it('Should search user by username', async function () {
543 const res = await getUsersListPaginationAndSort(server.url, server.accessToken, 0, 2, 'createdAt', 'oot')
544 const users = res.body.data as User[]
545
546 expect(res.body.total).to.equal(1)
547 expect(users.length).to.equal(1)
0e1dc3e7 548
a1587156 549 expect(users[0].username).to.equal('root')
11ba2ab3 550 })
0e1dc3e7 551
1eddc9a7
C
552 it('Should search user by email', async function () {
553 {
554 const res = await getUsersListPaginationAndSort(server.url, server.accessToken, 0, 2, 'createdAt', 'r_1@exam')
555 const users = res.body.data as User[]
0e1dc3e7 556
1eddc9a7
C
557 expect(res.body.total).to.equal(1)
558 expect(users.length).to.equal(1)
5c98d3bf 559
a1587156
C
560 expect(users[0].username).to.equal('user_1')
561 expect(users[0].email).to.equal('user_1@example.com')
1eddc9a7 562 }
7efe153b 563
1eddc9a7
C
564 {
565 const res = await getUsersListPaginationAndSort(server.url, server.accessToken, 0, 2, 'createdAt', 'example')
566 const users = res.body.data as User[]
7efe153b 567
1eddc9a7
C
568 expect(res.body.total).to.equal(2)
569 expect(users.length).to.equal(2)
7efe153b 570
a1587156
C
571 expect(users[0].username).to.equal('root')
572 expect(users[1].username).to.equal('user_1')
1eddc9a7 573 }
11ba2ab3 574 })
5c98d3bf
C
575 })
576
1eddc9a7
C
577 describe('Update my account', function () {
578 it('Should update my password', async function () {
579 await updateMyUser({
580 url: server.url,
581 accessToken: accessTokenUser,
582 currentPassword: 'super password',
43d0ea7f 583 password: 'new password'
1eddc9a7
C
584 })
585 user.password = 'new password'
c5911fd3 586
2d53be02 587 await userLogin(server, user, HttpStatusCode.OK_200)
c5911fd3
C
588 })
589
1eddc9a7
C
590 it('Should be able to change the NSFW display attribute', async function () {
591 await updateMyUser({
592 url: server.url,
593 accessToken: accessTokenUser,
594 nsfwPolicy: 'do_not_list'
595 })
596
597 const res = await getMyUserInformation(server.url, accessTokenUser)
598 const user = res.body
599
600 expect(user.username).to.equal('user_1')
601 expect(user.email).to.equal('user_1@example.com')
602 expect(user.nsfwPolicy).to.equal('do_not_list')
603 expect(user.videoQuota).to.equal(2 * 1024 * 1024)
604 expect(user.id).to.be.a('number')
605 expect(user.account.displayName).to.equal('user_1')
606 expect(user.account.description).to.be.null
607 })
c5911fd3 608
1eddc9a7
C
609 it('Should be able to change the autoPlayVideo attribute', async function () {
610 await updateMyUser({
611 url: server.url,
612 accessToken: accessTokenUser,
613 autoPlayVideo: false
614 })
c5911fd3 615
1eddc9a7
C
616 const res = await getMyUserInformation(server.url, accessTokenUser)
617 const user = res.body
618
619 expect(user.autoPlayVideo).to.be.false
ed56ad11
C
620 })
621
6aa54148
L
622 it('Should be able to change the autoPlayNextVideo attribute', async function () {
623 await updateMyUser({
624 url: server.url,
625 accessToken: accessTokenUser,
626 autoPlayNextVideo: true
627 })
628
629 const res = await getMyUserInformation(server.url, accessTokenUser)
630 const user = res.body
631
632 expect(user.autoPlayNextVideo).to.be.true
633 })
634
675a8fc7 635 it('Should be able to change the email attribute', async function () {
1eddc9a7
C
636 await updateMyUser({
637 url: server.url,
638 accessToken: accessTokenUser,
675a8fc7 639 currentPassword: 'new password',
1eddc9a7
C
640 email: 'updated@example.com'
641 })
642
643 const res = await getMyUserInformation(server.url, accessTokenUser)
644 const user = res.body
645
646 expect(user.username).to.equal('user_1')
647 expect(user.email).to.equal('updated@example.com')
648 expect(user.nsfwPolicy).to.equal('do_not_list')
649 expect(user.videoQuota).to.equal(2 * 1024 * 1024)
650 expect(user.id).to.be.a('number')
651 expect(user.account.displayName).to.equal('user_1')
652 expect(user.account.description).to.be.null
653 })
ed56ad11 654
f619de0e
C
655 it('Should be able to update my avatar with a gif', async function () {
656 const fixture = 'avatar.gif'
ed56ad11 657
1eddc9a7
C
658 await updateMyAvatar({
659 url: server.url,
660 accessToken: accessTokenUser,
661 fixture
662 })
2422c46b 663
1eddc9a7
C
664 const res = await getMyUserInformation(server.url, accessTokenUser)
665 const user = res.body
2422c46b 666
f619de0e
C
667 await testImage(server.url, 'avatar-resized', user.account.avatar.path, '.gif')
668 })
669
670 it('Should be able to update my avatar with a gif, and then a png', async function () {
671 for (const extension of [ '.png', '.gif' ]) {
672 const fixture = 'avatar' + extension
673
674 await updateMyAvatar({
675 url: server.url,
676 accessToken: accessTokenUser,
677 fixture
678 })
679
680 const res = await getMyUserInformation(server.url, accessTokenUser)
681 const user = res.body
682
683 await testImage(server.url, 'avatar-resized', user.account.avatar.path, extension)
684 }
1eddc9a7
C
685 })
686
687 it('Should be able to update my display name', async function () {
688 await updateMyUser({
689 url: server.url,
690 accessToken: accessTokenUser,
691 displayName: 'new display name'
692 })
693
694 const res = await getMyUserInformation(server.url, accessTokenUser)
695 const user = res.body
696
697 expect(user.username).to.equal('user_1')
698 expect(user.email).to.equal('updated@example.com')
699 expect(user.nsfwPolicy).to.equal('do_not_list')
700 expect(user.videoQuota).to.equal(2 * 1024 * 1024)
701 expect(user.id).to.be.a('number')
702 expect(user.account.displayName).to.equal('new display name')
703 expect(user.account.description).to.be.null
704 })
2422c46b 705
1eddc9a7
C
706 it('Should be able to update my description', async function () {
707 await updateMyUser({
708 url: server.url,
709 accessToken: accessTokenUser,
710 description: 'my super description updated'
711 })
712
713 const res = await getMyUserInformation(server.url, accessTokenUser)
43d0ea7f 714 const user: User = res.body
1eddc9a7
C
715
716 expect(user.username).to.equal('user_1')
717 expect(user.email).to.equal('updated@example.com')
718 expect(user.nsfwPolicy).to.equal('do_not_list')
719 expect(user.videoQuota).to.equal(2 * 1024 * 1024)
720 expect(user.id).to.be.a('number')
721 expect(user.account.displayName).to.equal('new display name')
722 expect(user.account.description).to.equal('my super description updated')
43d0ea7f
C
723 expect(user.noWelcomeModal).to.be.false
724 expect(user.noInstanceConfigWarningModal).to.be.false
1eddc9a7 725 })
9b474844
C
726
727 it('Should be able to update my theme', async function () {
728 for (const theme of [ 'background-red', 'default', 'instance-default' ]) {
729 await updateMyUser({
730 url: server.url,
731 accessToken: accessTokenUser,
732 theme
733 })
734
735 const res = await getMyUserInformation(server.url, accessTokenUser)
736 const body: User = res.body
737
738 expect(body.theme).to.equal(theme)
739 }
740 })
43d0ea7f
C
741
742 it('Should be able to update my modal preferences', async function () {
743 await updateMyUser({
744 url: server.url,
745 accessToken: accessTokenUser,
746 noInstanceConfigWarningModal: true,
747 noWelcomeModal: true
748 })
749
750 const res = await getMyUserInformation(server.url, accessTokenUser)
751 const user: User = res.body
752
753 expect(user.noWelcomeModal).to.be.true
754 expect(user.noInstanceConfigWarningModal).to.be.true
755 })
0e1dc3e7
C
756 })
757
1eddc9a7 758 describe('Updating another user', function () {
1eddc9a7
C
759 it('Should be able to update another user', async function () {
760 await updateUser({
761 url: server.url,
762 userId,
763 accessToken,
764 email: 'updated2@example.com',
765 emailVerified: true,
766 videoQuota: 42,
767 role: UserRole.MODERATOR,
6d989edc
C
768 adminFlags: UserAdminFlag.NONE,
769 pluginAuth: 'toto'
1eddc9a7
C
770 })
771
772 const res = await getUserInformation(server.url, accessToken, userId)
6d989edc 773 const user = res.body as User
1eddc9a7
C
774
775 expect(user.username).to.equal('user_1')
776 expect(user.email).to.equal('updated2@example.com')
777 expect(user.emailVerified).to.be.true
778 expect(user.nsfwPolicy).to.equal('do_not_list')
779 expect(user.videoQuota).to.equal(42)
780 expect(user.roleLabel).to.equal('Moderator')
781 expect(user.id).to.be.a('number')
782 expect(user.adminFlags).to.equal(UserAdminFlag.NONE)
6d989edc
C
783 expect(user.pluginAuth).to.equal('toto')
784 })
785
786 it('Should reset the auth plugin', async function () {
787 await updateUser({ url: server.url, userId, accessToken, pluginAuth: null })
788
789 const res = await getUserInformation(server.url, accessToken, userId)
790 const user = res.body as User
791 expect(user.pluginAuth).to.be.null
1eddc9a7 792 })
f8b8c36b 793
1eddc9a7 794 it('Should have removed the user token', async function () {
2d53be02 795 await getMyUserVideoQuotaUsed(server.url, accessTokenUser, HttpStatusCode.UNAUTHORIZED_401)
f8b8c36b 796
1eddc9a7 797 accessTokenUser = await userLogin(server, user)
b426edd4
C
798 })
799
1eddc9a7
C
800 it('Should be able to update another user password', async function () {
801 await updateUser({
802 url: server.url,
803 userId,
804 accessToken,
805 password: 'password updated'
806 })
b426edd4 807
2d53be02 808 await getMyUserVideoQuotaUsed(server.url, accessTokenUser, HttpStatusCode.UNAUTHORIZED_401)
b426edd4 809
2d53be02 810 await userLogin(server, user, HttpStatusCode.BAD_REQUEST_400)
b426edd4 811
1eddc9a7
C
812 user.password = 'password updated'
813 accessTokenUser = await userLogin(server, user)
814 })
757f0da3
C
815 })
816
1eddc9a7
C
817 describe('Video blacklists', function () {
818 it('Should be able to list video blacklist by a moderator', async function () {
819 await getBlacklistedVideosList({ url: server.url, token: accessTokenUser })
820 })
0e1dc3e7
C
821 })
822
1eddc9a7
C
823 describe('Remove a user', function () {
824 it('Should be able to remove this user', async function () {
825 await removeUser(server.url, userId, accessToken)
826 })
0e1dc3e7 827
1eddc9a7 828 it('Should not be able to login with this user', async function () {
2d53be02 829 await userLogin(server, user, HttpStatusCode.BAD_REQUEST_400)
1eddc9a7 830 })
0e1dc3e7 831
1eddc9a7
C
832 it('Should not have videos of this user', async function () {
833 const res = await getVideosList(server.url)
0e1dc3e7 834
1eddc9a7 835 expect(res.body.total).to.equal(1)
0e1dc3e7 836
a1587156 837 const video = res.body.data[0]
1eddc9a7
C
838 expect(video.account.name).to.equal('root')
839 })
0e1dc3e7
C
840 })
841
1eddc9a7 842 describe('Registering a new user', function () {
76314386
RK
843 let user15AccessToken
844
1eddc9a7 845 it('Should register a new user', async function () {
1f20622f 846 const user = { displayName: 'super user 15', username: 'user_15', password: 'my super password' }
e590b4a5
C
847 const channel = { name: 'my_user_15_channel', displayName: 'my channel rocks' }
848
849 await registerUserWithChannel({ url: server.url, user, channel })
1eddc9a7 850 })
0e1dc3e7 851
1eddc9a7
C
852 it('Should be able to login with this registered user', async function () {
853 const user15 = {
854 username: 'user_15',
855 password: 'my super password'
856 }
5c98d3bf 857
76314386 858 user15AccessToken = await userLogin(server, user15)
1eddc9a7 859 })
5c98d3bf 860
1f20622f 861 it('Should have the correct display name', async function () {
76314386 862 const res = await getMyUserInformation(server.url, user15AccessToken)
1f20622f
C
863 const user: User = res.body
864
865 expect(user.account.displayName).to.equal('super user 15')
866 })
867
1eddc9a7 868 it('Should have the correct video quota', async function () {
76314386 869 const res = await getMyUserInformation(server.url, user15AccessToken)
1eddc9a7 870 const user = res.body
0e1dc3e7 871
1eddc9a7
C
872 expect(user.videoQuota).to.equal(5 * 1024 * 1024)
873 })
92b9d60c 874
e590b4a5
C
875 it('Should have created the channel', async function () {
876 const res = await getVideoChannel(server.url, 'my_user_15_channel')
877
878 expect(res.body.displayName).to.equal('my channel rocks')
879 })
880
1eddc9a7
C
881 it('Should remove me', async function () {
882 {
883 const res = await getUsersList(server.url, server.accessToken)
884 expect(res.body.data.find(u => u.username === 'user_15')).to.not.be.undefined
885 }
92b9d60c 886
76314386 887 await deleteMe(server.url, user15AccessToken)
1eddc9a7
C
888
889 {
890 const res = await getUsersList(server.url, server.accessToken)
891 expect(res.body.data.find(u => u.username === 'user_15')).to.be.undefined
892 }
893 })
92b9d60c
C
894 })
895
1eddc9a7 896 describe('User blocking', function () {
76314386
RK
897 let user16Id
898 let user16AccessToken
8491293b
RK
899 const user16 = {
900 username: 'user_16',
901 password: 'my super password'
902 }
76314386 903
8491293b 904 it('Should block a user', async function () {
1eddc9a7
C
905 const resUser = await createUser({
906 url: server.url,
907 accessToken: server.accessToken,
908 username: user16.username,
909 password: user16.password
910 })
76314386 911 user16Id = resUser.body.user.id
e6921918 912
76314386 913 user16AccessToken = await userLogin(server, user16)
e6921918 914
2d53be02 915 await getMyUserInformation(server.url, user16AccessToken, HttpStatusCode.OK_200)
1eddc9a7 916 await blockUser(server.url, user16Id, server.accessToken)
e6921918 917
2d53be02
RK
918 await getMyUserInformation(server.url, user16AccessToken, HttpStatusCode.UNAUTHORIZED_401)
919 await userLogin(server, user16, HttpStatusCode.BAD_REQUEST_400)
8491293b
RK
920 })
921
922 it('Should search user by banned status', async function () {
923 {
924 const res = await getUsersListPaginationAndSort(server.url, server.accessToken, 0, 2, 'createdAt', undefined, true)
925 const users = res.body.data as User[]
926
927 expect(res.body.total).to.equal(1)
928 expect(users.length).to.equal(1)
929
930 expect(users[0].username).to.equal(user16.username)
931 }
932
933 {
934 const res = await getUsersListPaginationAndSort(server.url, server.accessToken, 0, 2, 'createdAt', undefined, false)
935 const users = res.body.data as User[]
936
937 expect(res.body.total).to.equal(1)
938 expect(users.length).to.equal(1)
939
940 expect(users[0].username).to.not.equal(user16.username)
941 }
942 })
e6921918 943
8491293b 944 it('Should unblock a user', async function () {
1eddc9a7 945 await unblockUser(server.url, user16Id, server.accessToken)
76314386 946 user16AccessToken = await userLogin(server, user16)
2d53be02 947 await getMyUserInformation(server.url, user16AccessToken, HttpStatusCode.OK_200)
76314386
RK
948 })
949 })
950
951 describe('User stats', function () {
952 let user17Id
953 let user17AccessToken
954
955 it('Should report correct initial statistics about a user', async function () {
956 const user17 = {
957 username: 'user_17',
958 password: 'my super password'
959 }
960 const resUser = await createUser({
961 url: server.url,
962 accessToken: server.accessToken,
963 username: user17.username,
964 password: user17.password
965 })
966
967 user17Id = resUser.body.user.id
968 user17AccessToken = await userLogin(server, user17)
969
970 const res = await getUserInformation(server.url, server.accessToken, user17Id, true)
971 const user: User = res.body
972
973 expect(user.videosCount).to.equal(0)
974 expect(user.videoCommentsCount).to.equal(0)
4f32032f
C
975 expect(user.abusesCount).to.equal(0)
976 expect(user.abusesCreatedCount).to.equal(0)
977 expect(user.abusesAcceptedCount).to.equal(0)
76314386
RK
978 })
979
980 it('Should report correct videos count', async function () {
981 const videoAttributes = {
982 name: 'video to test user stats'
983 }
984 await uploadVideo(server.url, user17AccessToken, videoAttributes)
985 const res1 = await getVideosList(server.url)
986 videoId = res1.body.data.find(video => video.name === videoAttributes.name).id
987
988 const res2 = await getUserInformation(server.url, server.accessToken, user17Id, true)
989 const user: User = res2.body
990
991 expect(user.videosCount).to.equal(1)
992 })
993
994 it('Should report correct video comments for user', async function () {
995 const text = 'super comment'
996 await addVideoCommentThread(server.url, user17AccessToken, videoId, text)
997
998 const res = await getUserInformation(server.url, server.accessToken, user17Id, true)
999 const user: User = res.body
1000
1001 expect(user.videoCommentsCount).to.equal(1)
1002 })
1003
4f32032f 1004 it('Should report correct abuses counts', async function () {
76314386 1005 const reason = 'my super bad reason'
0c1a77e9 1006 await server.abusesCommand.report({ token: user17AccessToken, videoId, reason })
76314386 1007
0c1a77e9
C
1008 const body1 = await server.abusesCommand.getAdminList()
1009 const abuseId = body1.data[0].id
76314386
RK
1010
1011 const res2 = await getUserInformation(server.url, server.accessToken, user17Id, true)
1012 const user2: User = res2.body
1013
4f32032f
C
1014 expect(user2.abusesCount).to.equal(1) // number of incriminations
1015 expect(user2.abusesCreatedCount).to.equal(1) // number of reports created
76314386 1016
0c1a77e9 1017 await server.abusesCommand.update({ abuseId, body: { state: AbuseState.ACCEPTED } })
76314386
RK
1018
1019 const res3 = await getUserInformation(server.url, server.accessToken, user17Id, true)
1020 const user3: User = res3.body
1021
4f32032f 1022 expect(user3.abusesAcceptedCount).to.equal(1) // number of reports created accepted
1eddc9a7 1023 })
e6921918
C
1024 })
1025
7c3b7976 1026 after(async function () {
f43db2f4 1027 await closeAllSequelize([ server ])
7c3b7976 1028 await cleanupTests([ server ])
0e1dc3e7
C
1029 })
1030})