Merge branch 'release/v1.0.0' into develop
[oweals/peertube.git] / server / tests / api / videos / videos-filter.ts
1 /* tslint:disable:no-unused-expression */
2
3 import * as chai from 'chai'
4 import 'mocha'
5 import {
6   createUser,
7   doubleFollow,
8   flushAndRunMultipleServers,
9   flushTests,
10   killallServers,
11   makeGetRequest,
12   ServerInfo,
13   setAccessTokensToServers,
14   uploadVideo,
15   userLogin
16 } from '../../utils'
17 import { Video, VideoPrivacy } from '../../../../shared/models/videos'
18 import { UserRole } from '../../../../shared/models/users'
19
20 const expect = chai.expect
21
22 async function getVideosNames (server: ServerInfo, token: string, filter: string, statusCodeExpected = 200) {
23   const paths = [
24     '/api/v1/video-channels/root_channel/videos',
25     '/api/v1/accounts/root/videos',
26     '/api/v1/videos',
27     '/api/v1/search/videos'
28   ]
29
30   const videosResults: Video[][] = []
31
32   for (const path of paths) {
33     const res = await makeGetRequest({
34       url: server.url,
35       path,
36       token,
37       query: {
38         sort: 'createdAt',
39         filter
40       },
41       statusCodeExpected
42     })
43
44     videosResults.push(res.body.data.map(v => v.name))
45   }
46
47   return videosResults
48 }
49
50 describe('Test videos filter validator', function () {
51   let servers: ServerInfo[]
52
53   // ---------------------------------------------------------------
54
55   before(async function () {
56     this.timeout(120000)
57
58     await flushTests()
59
60     servers = await flushAndRunMultipleServers(2)
61
62     await setAccessTokensToServers(servers)
63
64     for (const server of servers) {
65       const moderator = { username: 'moderator', password: 'my super password' }
66       await createUser(
67         server.url,
68         server.accessToken,
69         moderator.username,
70         moderator.password,
71         undefined,
72         undefined,
73         UserRole.MODERATOR
74       )
75       server['moderatorAccessToken'] = await userLogin(server, moderator)
76
77       await uploadVideo(server.url, server.accessToken, { name: 'public ' + server.serverNumber })
78
79       {
80         const attributes = { name: 'unlisted ' + server.serverNumber, privacy: VideoPrivacy.UNLISTED }
81         await uploadVideo(server.url, server.accessToken, attributes)
82       }
83
84       {
85         const attributes = { name: 'private ' + server.serverNumber, privacy: VideoPrivacy.PRIVATE }
86         await uploadVideo(server.url, server.accessToken, attributes)
87       }
88     }
89
90     await doubleFollow(servers[0], servers[1])
91   })
92
93   describe('Check videos filter', function () {
94
95     it('Should display local videos', async function () {
96       for (const server of servers) {
97         const namesResults = await getVideosNames(server, server.accessToken, 'local')
98         for (const names of namesResults) {
99           expect(names).to.have.lengthOf(1)
100           expect(names[ 0 ]).to.equal('public ' + server.serverNumber)
101         }
102       }
103     })
104
105     it('Should display all local videos by the admin or the moderator', async function () {
106       for (const server of servers) {
107         for (const token of [ server.accessToken, server['moderatorAccessToken'] ]) {
108
109           const namesResults = await getVideosNames(server, token, 'all-local')
110           for (const names of namesResults) {
111             expect(names).to.have.lengthOf(3)
112
113             expect(names[ 0 ]).to.equal('public ' + server.serverNumber)
114             expect(names[ 1 ]).to.equal('unlisted ' + server.serverNumber)
115             expect(names[ 2 ]).to.equal('private ' + server.serverNumber)
116           }
117         }
118       }
119     })
120   })
121
122   after(async function () {
123     killallServers(servers)
124
125     // Keep the logs if the test failed
126     if (this['ok']) {
127       await flushTests()
128     }
129   })
130 })