1 /* eslint-disable @typescript-eslint/no-unused-expressions,@typescript-eslint/require-await */
10 setAccessTokensToServers,
11 setDefaultVideoChannel,
13 } from '../../../../shared/extra-utils'
14 import { UserRole } from '../../../../shared/models/users'
15 import { HttpStatusCode } from '../../../../shared/core-utils/miscs/http-error-codes'
17 async function testEndpoints (server: ServerInfo, token: string, filter: string, statusCodeExpected: HttpStatusCode) {
19 '/api/v1/video-channels/root_channel/videos',
20 '/api/v1/accounts/root/videos',
22 '/api/v1/search/videos'
25 for (const path of paths) {
26 await makeGetRequest({
38 describe('Test videos filters', function () {
39 let server: ServerInfo
40 let userAccessToken: string
41 let moderatorAccessToken: string
43 // ---------------------------------------------------------------
45 before(async function () {
48 server = await flushAndRunServer(1)
50 await setAccessTokensToServers([ server ])
51 await setDefaultVideoChannel([ server ])
53 const user = { username: 'user1', password: 'my super password' }
54 await createUser({ url: server.url, accessToken: server.accessToken, username: user.username, password: user.password })
55 userAccessToken = await userLogin(server, user)
57 const moderator = { username: 'moderator', password: 'my super password' }
61 accessToken: server.accessToken,
62 username: moderator.username,
63 password: moderator.password,
64 videoQuota: undefined,
65 videoQuotaDaily: undefined,
66 role: UserRole.MODERATOR
69 moderatorAccessToken = await userLogin(server, moderator)
72 describe('When setting a video filter', function () {
74 it('Should fail with a bad filter', async function () {
75 await testEndpoints(server, server.accessToken, 'bad-filter', HttpStatusCode.BAD_REQUEST_400)
78 it('Should succeed with a good filter', async function () {
79 await testEndpoints(server, server.accessToken, 'local', HttpStatusCode.OK_200)
82 it('Should fail to list all-local/all with a simple user', async function () {
83 await testEndpoints(server, userAccessToken, 'all-local', HttpStatusCode.UNAUTHORIZED_401)
84 await testEndpoints(server, userAccessToken, 'all', HttpStatusCode.UNAUTHORIZED_401)
87 it('Should succeed to list all-local/all with a moderator', async function () {
88 await testEndpoints(server, moderatorAccessToken, 'all-local', HttpStatusCode.OK_200)
89 await testEndpoints(server, moderatorAccessToken, 'all', HttpStatusCode.OK_200)
92 it('Should succeed to list all-local/all with an admin', async function () {
93 await testEndpoints(server, server.accessToken, 'all-local', HttpStatusCode.OK_200)
94 await testEndpoints(server, server.accessToken, 'all', HttpStatusCode.OK_200)
97 // Because we cannot authenticate the user on the RSS endpoint
98 it('Should fail on the feeds endpoint with the all-local/all filter', async function () {
99 for (const filter of [ 'all', 'all-local' ]) {
100 await makeGetRequest({
102 path: '/feeds/videos.json',
103 statusCodeExpected: HttpStatusCode.UNAUTHORIZED_401,
111 it('Should succeed on the feeds endpoint with the local filter', async function () {
112 await makeGetRequest({
114 path: '/feeds/videos.json',
115 statusCodeExpected: HttpStatusCode.OK_200,
123 after(async function () {
124 await cleanupTests([ server ])