diff options
Diffstat (limited to 'server/tests/api')
80 files changed, 4521 insertions, 1347 deletions
diff --git a/server/tests/api/activitypub/client.ts b/server/tests/api/activitypub/client.ts index 6d90d8643..edf588c16 100644 --- a/server/tests/api/activitypub/client.ts +++ b/server/tests/api/activitypub/client.ts | |||
@@ -11,7 +11,7 @@ import { | |||
11 | ServerInfo, | 11 | ServerInfo, |
12 | setAccessTokensToServers, | 12 | setAccessTokensToServers, |
13 | uploadVideo | 13 | uploadVideo |
14 | } from '../../../../shared/utils' | 14 | } from '../../../../shared/extra-utils' |
15 | 15 | ||
16 | const expect = chai.expect | 16 | const expect = chai.expect |
17 | 17 | ||
@@ -22,8 +22,6 @@ describe('Test activitypub', function () { | |||
22 | before(async function () { | 22 | before(async function () { |
23 | this.timeout(30000) | 23 | this.timeout(30000) |
24 | 24 | ||
25 | await flushTests() | ||
26 | |||
27 | servers = await flushAndRunMultipleServers(2) | 25 | servers = await flushAndRunMultipleServers(2) |
28 | 26 | ||
29 | await setAccessTokensToServers(servers) | 27 | await setAccessTokensToServers(servers) |
@@ -61,7 +59,7 @@ describe('Test activitypub', function () { | |||
61 | expect(res.header.location).to.equal('http://localhost:9001/videos/watch/' + videoUUID) | 59 | expect(res.header.location).to.equal('http://localhost:9001/videos/watch/' + videoUUID) |
62 | }) | 60 | }) |
63 | 61 | ||
64 | after(async function () { | 62 | after(function () { |
65 | killallServers(servers) | 63 | killallServers(servers) |
66 | }) | 64 | }) |
67 | }) | 65 | }) |
diff --git a/server/tests/api/activitypub/fetch.ts b/server/tests/api/activitypub/fetch.ts index 03609c1a9..7240bb0fb 100644 --- a/server/tests/api/activitypub/fetch.ts +++ b/server/tests/api/activitypub/fetch.ts | |||
@@ -3,6 +3,7 @@ | |||
3 | import 'mocha' | 3 | import 'mocha' |
4 | 4 | ||
5 | import { | 5 | import { |
6 | closeAllSequelize, | ||
6 | createUser, | 7 | createUser, |
7 | doubleFollow, | 8 | doubleFollow, |
8 | flushAndRunMultipleServers, | 9 | flushAndRunMultipleServers, |
@@ -16,7 +17,7 @@ import { | |||
16 | uploadVideo, | 17 | uploadVideo, |
17 | userLogin, | 18 | userLogin, |
18 | waitJobs | 19 | waitJobs |
19 | } from '../../../../shared/utils' | 20 | } from '../../../../shared/extra-utils' |
20 | import * as chai from 'chai' | 21 | import * as chai from 'chai' |
21 | import { Video } from '../../../../shared/models/videos' | 22 | import { Video } from '../../../../shared/models/videos' |
22 | 23 | ||
@@ -37,7 +38,7 @@ describe('Test ActivityPub fetcher', function () { | |||
37 | 38 | ||
38 | const user = { username: 'user1', password: 'password' } | 39 | const user = { username: 'user1', password: 'password' } |
39 | for (const server of servers) { | 40 | for (const server of servers) { |
40 | await createUser(server.url, server.accessToken, user.username, user.password) | 41 | await createUser({ url: server.url, accessToken: server.accessToken, username: user.username, password: user.password }) |
41 | } | 42 | } |
42 | 43 | ||
43 | const userAccessToken = await userLogin(servers[0], user) | 44 | const userAccessToken = await userLogin(servers[0], user) |
@@ -79,9 +80,6 @@ describe('Test ActivityPub fetcher', function () { | |||
79 | after(async function () { | 80 | after(async function () { |
80 | killallServers(servers) | 81 | killallServers(servers) |
81 | 82 | ||
82 | // Keep the logs if the test failed | 83 | await closeAllSequelize(servers) |
83 | if (this['ok']) { | ||
84 | await flushTests() | ||
85 | } | ||
86 | }) | 84 | }) |
87 | }) | 85 | }) |
diff --git a/server/tests/api/activitypub/helpers.ts b/server/tests/api/activitypub/helpers.ts index ac6e755c3..365d0e1ae 100644 --- a/server/tests/api/activitypub/helpers.ts +++ b/server/tests/api/activitypub/helpers.ts | |||
@@ -2,7 +2,7 @@ | |||
2 | 2 | ||
3 | import 'mocha' | 3 | import 'mocha' |
4 | import { expect } from 'chai' | 4 | import { expect } from 'chai' |
5 | import { buildRequestStub } from '../../../../shared/utils/miscs/stubs' | 5 | import { buildRequestStub } from '../../../../shared/extra-utils/miscs/stubs' |
6 | import { isHTTPSignatureVerified, isJsonLDSignatureVerified, parseHTTPSignature } from '../../../helpers/peertube-crypto' | 6 | import { isHTTPSignatureVerified, isJsonLDSignatureVerified, parseHTTPSignature } from '../../../helpers/peertube-crypto' |
7 | import { cloneDeep } from 'lodash' | 7 | import { cloneDeep } from 'lodash' |
8 | import { buildSignedActivity } from '../../../helpers/activitypub' | 8 | import { buildSignedActivity } from '../../../helpers/activitypub' |
diff --git a/server/tests/api/activitypub/index.ts b/server/tests/api/activitypub/index.ts index 450053309..92bd6f660 100644 --- a/server/tests/api/activitypub/index.ts +++ b/server/tests/api/activitypub/index.ts | |||
@@ -1,5 +1,5 @@ | |||
1 | import './client' | 1 | import './client' |
2 | import './fetch' | 2 | import './fetch' |
3 | import './helpers' | ||
4 | import './refresher' | 3 | import './refresher' |
4 | import './helpers' | ||
5 | import './security' | 5 | import './security' |
diff --git a/server/tests/api/activitypub/refresher.ts b/server/tests/api/activitypub/refresher.ts index 62ad8a0b5..9be9aa495 100644 --- a/server/tests/api/activitypub/refresher.ts +++ b/server/tests/api/activitypub/refresher.ts | |||
@@ -2,92 +2,158 @@ | |||
2 | 2 | ||
3 | import 'mocha' | 3 | import 'mocha' |
4 | import { | 4 | import { |
5 | createVideoPlaylist, | ||
5 | doubleFollow, | 6 | doubleFollow, |
6 | flushAndRunMultipleServers, | 7 | flushAndRunMultipleServers, |
8 | generateUserAccessToken, | ||
7 | getVideo, | 9 | getVideo, |
8 | killallServers, | 10 | getVideoPlaylist, |
11 | killallServers, rateVideo, | ||
9 | reRunServer, | 12 | reRunServer, |
10 | ServerInfo, | 13 | ServerInfo, |
11 | setAccessTokensToServers, | 14 | setAccessTokensToServers, |
15 | setActorField, | ||
16 | setDefaultVideoChannel, | ||
17 | setPlaylistField, | ||
18 | setVideoField, | ||
12 | uploadVideo, | 19 | uploadVideo, |
20 | uploadVideoAndGetId, | ||
13 | wait, | 21 | wait, |
14 | setVideoField, | ||
15 | waitJobs | 22 | waitJobs |
16 | } from '../../../../shared/utils' | 23 | } from '../../../../shared/extra-utils' |
24 | import { getAccount } from '../../../../shared/extra-utils/users/accounts' | ||
25 | import { VideoPlaylistPrivacy } from '../../../../shared/models/videos' | ||
17 | 26 | ||
18 | describe('Test AP refresher', function () { | 27 | describe('Test AP refresher', function () { |
19 | let servers: ServerInfo[] = [] | 28 | let servers: ServerInfo[] = [] |
20 | let videoUUID1: string | 29 | let videoUUID1: string |
21 | let videoUUID2: string | 30 | let videoUUID2: string |
22 | let videoUUID3: string | 31 | let videoUUID3: string |
32 | let playlistUUID1: string | ||
33 | let playlistUUID2: string | ||
23 | 34 | ||
24 | before(async function () { | 35 | before(async function () { |
25 | this.timeout(60000) | 36 | this.timeout(60000) |
26 | 37 | ||
27 | servers = await flushAndRunMultipleServers(2) | 38 | servers = await flushAndRunMultipleServers(2, { transcoding: { enabled: false } }) |
28 | 39 | ||
29 | // Get the access tokens | 40 | // Get the access tokens |
30 | await setAccessTokensToServers(servers) | 41 | await setAccessTokensToServers(servers) |
42 | await setDefaultVideoChannel(servers) | ||
43 | |||
44 | { | ||
45 | videoUUID1 = (await uploadVideoAndGetId({ server: servers[ 1 ], videoName: 'video1' })).uuid | ||
46 | videoUUID2 = (await uploadVideoAndGetId({ server: servers[ 1 ], videoName: 'video2' })).uuid | ||
47 | videoUUID3 = (await uploadVideoAndGetId({ server: servers[ 1 ], videoName: 'video3' })).uuid | ||
48 | } | ||
31 | 49 | ||
32 | { | 50 | { |
33 | const res = await uploadVideo(servers[1].url, servers[1].accessToken, { name: 'video1' }) | 51 | const a1 = await generateUserAccessToken(servers[1], 'user1') |
34 | videoUUID1 = res.body.video.uuid | 52 | await uploadVideo(servers[1].url, a1, { name: 'video4' }) |
53 | |||
54 | const a2 = await generateUserAccessToken(servers[1], 'user2') | ||
55 | await uploadVideo(servers[1].url, a2, { name: 'video5' }) | ||
35 | } | 56 | } |
36 | 57 | ||
37 | { | 58 | { |
38 | const res = await uploadVideo(servers[1].url, servers[1].accessToken, { name: 'video2' }) | 59 | const playlistAttrs = { displayName: 'playlist1', privacy: VideoPlaylistPrivacy.PUBLIC, videoChannelId: servers[1].videoChannel.id } |
39 | videoUUID2 = res.body.video.uuid | 60 | const res = await createVideoPlaylist({ url: servers[1].url, token: servers[1].accessToken, playlistAttrs }) |
61 | playlistUUID1 = res.body.videoPlaylist.uuid | ||
40 | } | 62 | } |
41 | 63 | ||
42 | { | 64 | { |
43 | const res = await uploadVideo(servers[1].url, servers[1].accessToken, { name: 'video3' }) | 65 | const playlistAttrs = { displayName: 'playlist2', privacy: VideoPlaylistPrivacy.PUBLIC, videoChannelId: servers[1].videoChannel.id } |
44 | videoUUID3 = res.body.video.uuid | 66 | const res = await createVideoPlaylist({ url: servers[1].url, token: servers[1].accessToken, playlistAttrs }) |
67 | playlistUUID2 = res.body.videoPlaylist.uuid | ||
45 | } | 68 | } |
46 | 69 | ||
47 | await doubleFollow(servers[0], servers[1]) | 70 | await doubleFollow(servers[0], servers[1]) |
48 | }) | 71 | }) |
49 | 72 | ||
50 | it('Should remove a deleted remote video', async function () { | 73 | describe('Videos refresher', function () { |
51 | this.timeout(60000) | 74 | |
75 | it('Should remove a deleted remote video', async function () { | ||
76 | this.timeout(60000) | ||
77 | |||
78 | await wait(10000) | ||
79 | |||
80 | // Change UUID so the remote server returns a 404 | ||
81 | await setVideoField(2, videoUUID1, 'uuid', '304afe4f-39f9-4d49-8ed7-ac57b86b174f') | ||
82 | |||
83 | await getVideo(servers[ 0 ].url, videoUUID1) | ||
84 | await getVideo(servers[ 0 ].url, videoUUID2) | ||
85 | |||
86 | await waitJobs(servers) | ||
52 | 87 | ||
53 | await wait(10000) | 88 | await getVideo(servers[ 0 ].url, videoUUID1, 404) |
89 | await getVideo(servers[ 0 ].url, videoUUID2, 200) | ||
90 | }) | ||
54 | 91 | ||
55 | // Change UUID so the remote server returns a 404 | 92 | it('Should not update a remote video if the remote instance is down', async function () { |
56 | await setVideoField(2, videoUUID1, 'uuid', '304afe4f-39f9-4d49-8ed7-ac57b86b174f') | 93 | this.timeout(60000) |
57 | 94 | ||
58 | await getVideo(servers[0].url, videoUUID1) | 95 | killallServers([ servers[ 1 ] ]) |
59 | await getVideo(servers[0].url, videoUUID2) | ||
60 | 96 | ||
61 | await waitJobs(servers) | 97 | await setVideoField(2, videoUUID3, 'uuid', '304afe4f-39f9-4d49-8ed7-ac57b86b174e') |
62 | 98 | ||
63 | await getVideo(servers[0].url, videoUUID1, 404) | 99 | // Video will need a refresh |
64 | await getVideo(servers[0].url, videoUUID2, 200) | 100 | await wait(10000) |
101 | |||
102 | await getVideo(servers[ 0 ].url, videoUUID3) | ||
103 | // The refresh should fail | ||
104 | await waitJobs([ servers[ 0 ] ]) | ||
105 | |||
106 | await reRunServer(servers[ 1 ]) | ||
107 | |||
108 | // Should not refresh the video, even if the last refresh failed (to avoir a loop on dead instances) | ||
109 | await getVideo(servers[ 0 ].url, videoUUID3) | ||
110 | await waitJobs(servers) | ||
111 | |||
112 | await getVideo(servers[ 0 ].url, videoUUID3, 200) | ||
113 | }) | ||
65 | }) | 114 | }) |
66 | 115 | ||
67 | it('Should not update a remote video if the remote instance is down', async function () { | 116 | describe('Actors refresher', function () { |
68 | this.timeout(60000) | 117 | |
118 | it('Should remove a deleted actor', async function () { | ||
119 | this.timeout(60000) | ||
120 | |||
121 | await wait(10000) | ||
122 | |||
123 | // Change actor name so the remote server returns a 404 | ||
124 | await setActorField(2, 'http://localhost:9002/accounts/user2', 'preferredUsername', 'toto') | ||
125 | |||
126 | await getAccount(servers[ 0 ].url, 'user1@localhost:9002') | ||
127 | await getAccount(servers[ 0 ].url, 'user2@localhost:9002') | ||
128 | |||
129 | await waitJobs(servers) | ||
130 | |||
131 | await getAccount(servers[ 0 ].url, 'user1@localhost:9002', 200) | ||
132 | await getAccount(servers[ 0 ].url, 'user2@localhost:9002', 404) | ||
133 | }) | ||
134 | }) | ||
69 | 135 | ||
70 | killallServers([ servers[1] ]) | 136 | describe('Playlist refresher', function () { |
71 | 137 | ||
72 | await setVideoField(2, videoUUID3, 'uuid', '304afe4f-39f9-4d49-8ed7-ac57b86b174e') | 138 | it('Should remove a deleted playlist', async function () { |
139 | this.timeout(60000) | ||
73 | 140 | ||
74 | // Video will need a refresh | 141 | await wait(10000) |
75 | await wait(10000) | ||
76 | 142 | ||
77 | await getVideo(servers[0].url, videoUUID3) | 143 | // Change UUID so the remote server returns a 404 |
78 | // The refresh should fail | 144 | await setPlaylistField(2, playlistUUID2, 'uuid', '304afe4f-39f9-4d49-8ed7-ac57b86b178e') |
79 | await waitJobs([ servers[0] ]) | ||
80 | 145 | ||
81 | await reRunServer(servers[1]) | 146 | await getVideoPlaylist(servers[ 0 ].url, playlistUUID1) |
147 | await getVideoPlaylist(servers[ 0 ].url, playlistUUID2) | ||
82 | 148 | ||
83 | // Should not refresh the video, even if the last refresh failed (to avoir a loop on dead instances) | 149 | await waitJobs(servers) |
84 | await getVideo(servers[0].url, videoUUID3) | ||
85 | await waitJobs(servers) | ||
86 | 150 | ||
87 | await getVideo(servers[0].url, videoUUID3, 200) | 151 | await getVideoPlaylist(servers[ 0 ].url, playlistUUID1, 200) |
152 | await getVideoPlaylist(servers[ 0 ].url, playlistUUID2, 404) | ||
153 | }) | ||
88 | }) | 154 | }) |
89 | 155 | ||
90 | after(async function () { | 156 | after(function () { |
91 | killallServers(servers) | 157 | killallServers(servers) |
92 | }) | 158 | }) |
93 | }) | 159 | }) |
diff --git a/server/tests/api/activitypub/security.ts b/server/tests/api/activitypub/security.ts index 342ae0fa1..11e6859bf 100644 --- a/server/tests/api/activitypub/security.ts +++ b/server/tests/api/activitypub/security.ts | |||
@@ -3,18 +3,18 @@ | |||
3 | import 'mocha' | 3 | import 'mocha' |
4 | 4 | ||
5 | import { | 5 | import { |
6 | closeAllSequelize, | ||
6 | flushAndRunMultipleServers, | 7 | flushAndRunMultipleServers, |
7 | flushTests, | 8 | flushTests, |
8 | killallServers, | 9 | killallServers, |
9 | makeFollowRequest, | ||
10 | makePOSTAPRequest, | ||
11 | ServerInfo, | 10 | ServerInfo, |
12 | setActorField | 11 | setActorField |
13 | } from '../../../../shared/utils' | 12 | } from '../../../../shared/extra-utils' |
14 | import { HTTP_SIGNATURE } from '../../../initializers' | 13 | import { HTTP_SIGNATURE } from '../../../initializers/constants' |
15 | import { buildDigest, buildGlobalHeaders } from '../../../lib/job-queue/handlers/utils/activitypub-http-utils' | 14 | import { buildDigest, buildGlobalHeaders } from '../../../lib/job-queue/handlers/utils/activitypub-http-utils' |
16 | import * as chai from 'chai' | 15 | import * as chai from 'chai' |
17 | import { activityPubContextify, buildSignedActivity } from '../../../helpers/activitypub' | 16 | import { activityPubContextify, buildSignedActivity } from '../../../helpers/activitypub' |
17 | import { makeFollowRequest, makePOSTAPRequest } from '../../../../shared/extra-utils/requests/activitypub' | ||
18 | 18 | ||
19 | const expect = chai.expect | 19 | const expect = chai.expect |
20 | 20 | ||
@@ -179,9 +179,6 @@ describe('Test ActivityPub security', function () { | |||
179 | after(async function () { | 179 | after(async function () { |
180 | killallServers(servers) | 180 | killallServers(servers) |
181 | 181 | ||
182 | // Keep the logs if the test failed | 182 | await closeAllSequelize(servers) |
183 | if (this['ok']) { | ||
184 | await flushTests() | ||
185 | } | ||
186 | }) | 183 | }) |
187 | }) | 184 | }) |
diff --git a/server/tests/api/check-params/accounts.ts b/server/tests/api/check-params/accounts.ts index 68f9519c6..4f79685bd 100644 --- a/server/tests/api/check-params/accounts.ts +++ b/server/tests/api/check-params/accounts.ts | |||
@@ -2,13 +2,13 @@ | |||
2 | 2 | ||
3 | import 'mocha' | 3 | import 'mocha' |
4 | 4 | ||
5 | import { flushTests, killallServers, runServer, ServerInfo } from '../../../../shared/utils' | 5 | import { cleanupTests, flushAndRunServer, ServerInfo } from '../../../../shared/extra-utils' |
6 | import { | 6 | import { |
7 | checkBadCountPagination, | 7 | checkBadCountPagination, |
8 | checkBadSortPagination, | 8 | checkBadSortPagination, |
9 | checkBadStartPagination | 9 | checkBadStartPagination |
10 | } from '../../../../shared/utils/requests/check-api-params' | 10 | } from '../../../../shared/extra-utils/requests/check-api-params' |
11 | import { getAccount } from '../../../../shared/utils/users/accounts' | 11 | import { getAccount } from '../../../../shared/extra-utils/users/accounts' |
12 | 12 | ||
13 | describe('Test accounts API validators', function () { | 13 | describe('Test accounts API validators', function () { |
14 | const path = '/api/v1/accounts/' | 14 | const path = '/api/v1/accounts/' |
@@ -19,9 +19,7 @@ describe('Test accounts API validators', function () { | |||
19 | before(async function () { | 19 | before(async function () { |
20 | this.timeout(30000) | 20 | this.timeout(30000) |
21 | 21 | ||
22 | await flushTests() | 22 | server = await flushAndRunServer(1) |
23 | |||
24 | server = await runServer(1) | ||
25 | }) | 23 | }) |
26 | 24 | ||
27 | describe('When listing accounts', function () { | 25 | describe('When listing accounts', function () { |
@@ -45,11 +43,6 @@ describe('Test accounts API validators', function () { | |||
45 | }) | 43 | }) |
46 | 44 | ||
47 | after(async function () { | 45 | after(async function () { |
48 | killallServers([ server ]) | 46 | await cleanupTests([ server ]) |
49 | |||
50 | // Keep the logs if the test failed | ||
51 | if (this['ok']) { | ||
52 | await flushTests() | ||
53 | } | ||
54 | }) | 47 | }) |
55 | }) | 48 | }) |
diff --git a/server/tests/api/check-params/blocklist.ts b/server/tests/api/check-params/blocklist.ts index c20453c16..0661676ce 100644 --- a/server/tests/api/check-params/blocklist.ts +++ b/server/tests/api/check-params/blocklist.ts | |||
@@ -3,22 +3,22 @@ | |||
3 | import 'mocha' | 3 | import 'mocha' |
4 | 4 | ||
5 | import { | 5 | import { |
6 | cleanupTests, | ||
6 | createUser, | 7 | createUser, |
7 | doubleFollow, | 8 | doubleFollow, |
8 | flushAndRunMultipleServers, | 9 | flushAndRunMultipleServers, |
9 | flushTests, | ||
10 | killallServers, | ||
11 | makeDeleteRequest, | 10 | makeDeleteRequest, |
12 | makeGetRequest, | 11 | makeGetRequest, |
13 | makePostBodyRequest, | 12 | makePostBodyRequest, |
14 | ServerInfo, | 13 | ServerInfo, |
15 | setAccessTokensToServers, userLogin | 14 | setAccessTokensToServers, |
16 | } from '../../../../shared/utils' | 15 | userLogin |
16 | } from '../../../../shared/extra-utils' | ||
17 | import { | 17 | import { |
18 | checkBadCountPagination, | 18 | checkBadCountPagination, |
19 | checkBadSortPagination, | 19 | checkBadSortPagination, |
20 | checkBadStartPagination | 20 | checkBadStartPagination |
21 | } from '../../../../shared/utils/requests/check-api-params' | 21 | } from '../../../../shared/extra-utils/requests/check-api-params' |
22 | 22 | ||
23 | describe('Test blocklist API validators', function () { | 23 | describe('Test blocklist API validators', function () { |
24 | let servers: ServerInfo[] | 24 | let servers: ServerInfo[] |
@@ -28,15 +28,13 @@ describe('Test blocklist API validators', function () { | |||
28 | before(async function () { | 28 | before(async function () { |
29 | this.timeout(60000) | 29 | this.timeout(60000) |
30 | 30 | ||
31 | await flushTests() | ||
32 | |||
33 | servers = await flushAndRunMultipleServers(2) | 31 | servers = await flushAndRunMultipleServers(2) |
34 | await setAccessTokensToServers(servers) | 32 | await setAccessTokensToServers(servers) |
35 | 33 | ||
36 | server = servers[0] | 34 | server = servers[0] |
37 | 35 | ||
38 | const user = { username: 'user1', password: 'password' } | 36 | const user = { username: 'user1', password: 'password' } |
39 | await createUser(server.url, server.accessToken, user.username, user.password) | 37 | await createUser({ url: server.url, accessToken: server.accessToken, username: user.username, password: user.password }) |
40 | 38 | ||
41 | userAccessToken = await userLogin(server, user) | 39 | userAccessToken = await userLogin(server, user) |
42 | 40 | ||
@@ -192,7 +190,7 @@ describe('Test blocklist API validators', function () { | |||
192 | url: server.url, | 190 | url: server.url, |
193 | token: server.accessToken, | 191 | token: server.accessToken, |
194 | path, | 192 | path, |
195 | fields: { host: 'localhost:9001' }, | 193 | fields: { host: 'localhost:' + server.port }, |
196 | statusCodeExpected: 409 | 194 | statusCodeExpected: 409 |
197 | }) | 195 | }) |
198 | }) | 196 | }) |
@@ -202,7 +200,7 @@ describe('Test blocklist API validators', function () { | |||
202 | url: server.url, | 200 | url: server.url, |
203 | token: server.accessToken, | 201 | token: server.accessToken, |
204 | path, | 202 | path, |
205 | fields: { host: 'localhost:9002' }, | 203 | fields: { host: 'localhost:' + servers[1].port }, |
206 | statusCodeExpected: 204 | 204 | statusCodeExpected: 204 |
207 | }) | 205 | }) |
208 | }) | 206 | }) |
@@ -212,7 +210,7 @@ describe('Test blocklist API validators', function () { | |||
212 | it('Should fail with an unauthenticated user', async function () { | 210 | it('Should fail with an unauthenticated user', async function () { |
213 | await makeDeleteRequest({ | 211 | await makeDeleteRequest({ |
214 | url: server.url, | 212 | url: server.url, |
215 | path: path + '/localhost:9002', | 213 | path: path + '/localhost:' + servers[1].port, |
216 | statusCodeExpected: 401 | 214 | statusCodeExpected: 401 |
217 | }) | 215 | }) |
218 | }) | 216 | }) |
@@ -229,7 +227,7 @@ describe('Test blocklist API validators', function () { | |||
229 | it('Should succeed with the correct params', async function () { | 227 | it('Should succeed with the correct params', async function () { |
230 | await makeDeleteRequest({ | 228 | await makeDeleteRequest({ |
231 | url: server.url, | 229 | url: server.url, |
232 | path: path + '/localhost:9002', | 230 | path: path + '/localhost:' + servers[1].port, |
233 | token: server.accessToken, | 231 | token: server.accessToken, |
234 | statusCodeExpected: 204 | 232 | statusCodeExpected: 204 |
235 | }) | 233 | }) |
@@ -402,7 +400,7 @@ describe('Test blocklist API validators', function () { | |||
402 | await makePostBodyRequest({ | 400 | await makePostBodyRequest({ |
403 | url: server.url, | 401 | url: server.url, |
404 | path, | 402 | path, |
405 | fields: { host: 'localhost:9002' }, | 403 | fields: { host: 'localhost:' + servers[1].port }, |
406 | statusCodeExpected: 401 | 404 | statusCodeExpected: 401 |
407 | }) | 405 | }) |
408 | }) | 406 | }) |
@@ -412,7 +410,7 @@ describe('Test blocklist API validators', function () { | |||
412 | url: server.url, | 410 | url: server.url, |
413 | token: userAccessToken, | 411 | token: userAccessToken, |
414 | path, | 412 | path, |
415 | fields: { host: 'localhost:9002' }, | 413 | fields: { host: 'localhost:' + servers[1].port }, |
416 | statusCodeExpected: 403 | 414 | statusCodeExpected: 403 |
417 | }) | 415 | }) |
418 | }) | 416 | }) |
@@ -432,7 +430,7 @@ describe('Test blocklist API validators', function () { | |||
432 | url: server.url, | 430 | url: server.url, |
433 | token: server.accessToken, | 431 | token: server.accessToken, |
434 | path, | 432 | path, |
435 | fields: { host: 'localhost:9001' }, | 433 | fields: { host: 'localhost:' + server.port }, |
436 | statusCodeExpected: 409 | 434 | statusCodeExpected: 409 |
437 | }) | 435 | }) |
438 | }) | 436 | }) |
@@ -442,7 +440,7 @@ describe('Test blocklist API validators', function () { | |||
442 | url: server.url, | 440 | url: server.url, |
443 | token: server.accessToken, | 441 | token: server.accessToken, |
444 | path, | 442 | path, |
445 | fields: { host: 'localhost:9002' }, | 443 | fields: { host: 'localhost:' + servers[1].port }, |
446 | statusCodeExpected: 204 | 444 | statusCodeExpected: 204 |
447 | }) | 445 | }) |
448 | }) | 446 | }) |
@@ -452,7 +450,7 @@ describe('Test blocklist API validators', function () { | |||
452 | it('Should fail with an unauthenticated user', async function () { | 450 | it('Should fail with an unauthenticated user', async function () { |
453 | await makeDeleteRequest({ | 451 | await makeDeleteRequest({ |
454 | url: server.url, | 452 | url: server.url, |
455 | path: path + '/localhost:9002', | 453 | path: path + '/localhost:' + servers[1].port, |
456 | statusCodeExpected: 401 | 454 | statusCodeExpected: 401 |
457 | }) | 455 | }) |
458 | }) | 456 | }) |
@@ -460,7 +458,7 @@ describe('Test blocklist API validators', function () { | |||
460 | it('Should fail with a user without the appropriate rights', async function () { | 458 | it('Should fail with a user without the appropriate rights', async function () { |
461 | await makeDeleteRequest({ | 459 | await makeDeleteRequest({ |
462 | url: server.url, | 460 | url: server.url, |
463 | path: path + '/localhost:9002', | 461 | path: path + '/localhost:' + servers[1].port, |
464 | token: userAccessToken, | 462 | token: userAccessToken, |
465 | statusCodeExpected: 403 | 463 | statusCodeExpected: 403 |
466 | }) | 464 | }) |
@@ -478,7 +476,7 @@ describe('Test blocklist API validators', function () { | |||
478 | it('Should succeed with the correct params', async function () { | 476 | it('Should succeed with the correct params', async function () { |
479 | await makeDeleteRequest({ | 477 | await makeDeleteRequest({ |
480 | url: server.url, | 478 | url: server.url, |
481 | path: path + '/localhost:9002', | 479 | path: path + '/localhost:' + servers[1].port, |
482 | token: server.accessToken, | 480 | token: server.accessToken, |
483 | statusCodeExpected: 204 | 481 | statusCodeExpected: 204 |
484 | }) | 482 | }) |
@@ -488,11 +486,6 @@ describe('Test blocklist API validators', function () { | |||
488 | }) | 486 | }) |
489 | 487 | ||
490 | after(async function () { | 488 | after(async function () { |
491 | killallServers(servers) | 489 | await cleanupTests(servers) |
492 | |||
493 | // Keep the logs if the test failed | ||
494 | if (this['ok']) { | ||
495 | await flushTests() | ||
496 | } | ||
497 | }) | 490 | }) |
498 | }) | 491 | }) |
diff --git a/server/tests/api/check-params/config.ts b/server/tests/api/check-params/config.ts index 4038ecbf0..2a2ec606a 100644 --- a/server/tests/api/check-params/config.ts +++ b/server/tests/api/check-params/config.ts | |||
@@ -5,9 +5,9 @@ import 'mocha' | |||
5 | import { CustomConfig } from '../../../../shared/models/server/custom-config.model' | 5 | import { CustomConfig } from '../../../../shared/models/server/custom-config.model' |
6 | 6 | ||
7 | import { | 7 | import { |
8 | createUser, flushTests, killallServers, makeDeleteRequest, makeGetRequest, makePutBodyRequest, runServer, ServerInfo, | 8 | createUser, flushTests, killallServers, makeDeleteRequest, makeGetRequest, makePutBodyRequest, flushAndRunServer, ServerInfo, |
9 | setAccessTokensToServers, userLogin, immutableAssign | 9 | setAccessTokensToServers, userLogin, immutableAssign, cleanupTests |
10 | } from '../../../../shared/utils' | 10 | } from '../../../../shared/extra-utils' |
11 | 11 | ||
12 | describe('Test config API validators', function () { | 12 | describe('Test config API validators', function () { |
13 | const path = '/api/v1/config/custom' | 13 | const path = '/api/v1/config/custom' |
@@ -19,6 +19,7 @@ describe('Test config API validators', function () { | |||
19 | shortDescription: 'my short description', | 19 | shortDescription: 'my short description', |
20 | description: 'my super description', | 20 | description: 'my super description', |
21 | terms: 'my super terms', | 21 | terms: 'my super terms', |
22 | isNSFW: true, | ||
22 | defaultClientRoute: '/videos/recently-added', | 23 | defaultClientRoute: '/videos/recently-added', |
23 | defaultNSFWPolicy: 'blur', | 24 | defaultNSFWPolicy: 'blur', |
24 | customizations: { | 25 | customizations: { |
@@ -65,6 +66,9 @@ describe('Test config API validators', function () { | |||
65 | '480p': true, | 66 | '480p': true, |
66 | '720p': false, | 67 | '720p': false, |
67 | '1080p': false | 68 | '1080p': false |
69 | }, | ||
70 | hls: { | ||
71 | enabled: false | ||
68 | } | 72 | } |
69 | }, | 73 | }, |
70 | import: { | 74 | import: { |
@@ -76,6 +80,19 @@ describe('Test config API validators', function () { | |||
76 | enabled: false | 80 | enabled: false |
77 | } | 81 | } |
78 | } | 82 | } |
83 | }, | ||
84 | autoBlacklist: { | ||
85 | videos: { | ||
86 | ofUsers: { | ||
87 | enabled: false | ||
88 | } | ||
89 | } | ||
90 | }, | ||
91 | followers: { | ||
92 | instance: { | ||
93 | enabled: false, | ||
94 | manualApproval: true | ||
95 | } | ||
79 | } | 96 | } |
80 | } | 97 | } |
81 | 98 | ||
@@ -84,8 +101,7 @@ describe('Test config API validators', function () { | |||
84 | before(async function () { | 101 | before(async function () { |
85 | this.timeout(30000) | 102 | this.timeout(30000) |
86 | 103 | ||
87 | await flushTests() | 104 | server = await flushAndRunServer(1) |
88 | server = await runServer(1) | ||
89 | 105 | ||
90 | await setAccessTokensToServers([ server ]) | 106 | await setAccessTokensToServers([ server ]) |
91 | 107 | ||
@@ -93,7 +109,7 @@ describe('Test config API validators', function () { | |||
93 | username: 'user1', | 109 | username: 'user1', |
94 | password: 'password' | 110 | password: 'password' |
95 | } | 111 | } |
96 | await createUser(server.url, server.accessToken, user.username, user.password) | 112 | await createUser({ url: server.url, accessToken: server.accessToken, username: user.username, password: user.password }) |
97 | userAccessToken = await userLogin(server, user) | 113 | userAccessToken = await userLogin(server, user) |
98 | }) | 114 | }) |
99 | 115 | ||
@@ -164,6 +180,25 @@ describe('Test config API validators', function () { | |||
164 | }) | 180 | }) |
165 | }) | 181 | }) |
166 | 182 | ||
183 | it('Should fail if email disabled and signup requires email verification', async function () { | ||
184 | // opposite scenario - success when enable enabled - covered via tests/api/users/user-verification.ts | ||
185 | const newUpdateParams = immutableAssign(updateParams, { | ||
186 | signup: { | ||
187 | enabled: true, | ||
188 | limit: 5, | ||
189 | requiresEmailVerification: true | ||
190 | } | ||
191 | }) | ||
192 | |||
193 | await makePutBodyRequest({ | ||
194 | url: server.url, | ||
195 | path, | ||
196 | fields: newUpdateParams, | ||
197 | token: server.accessToken, | ||
198 | statusCodeExpected: 400 | ||
199 | }) | ||
200 | }) | ||
201 | |||
167 | it('Should success with the correct parameters', async function () { | 202 | it('Should success with the correct parameters', async function () { |
168 | await makePutBodyRequest({ | 203 | await makePutBodyRequest({ |
169 | url: server.url, | 204 | url: server.url, |
@@ -195,11 +230,6 @@ describe('Test config API validators', function () { | |||
195 | }) | 230 | }) |
196 | 231 | ||
197 | after(async function () { | 232 | after(async function () { |
198 | killallServers([ server ]) | 233 | await cleanupTests([ server ]) |
199 | |||
200 | // Keep the logs if the test failed | ||
201 | if (this['ok']) { | ||
202 | await flushTests() | ||
203 | } | ||
204 | }) | 234 | }) |
205 | }) | 235 | }) |
diff --git a/server/tests/api/check-params/contact-form.ts b/server/tests/api/check-params/contact-form.ts index c7e014b1f..dbdd3a8a6 100644 --- a/server/tests/api/check-params/contact-form.ts +++ b/server/tests/api/check-params/contact-form.ts | |||
@@ -7,18 +7,18 @@ import { | |||
7 | immutableAssign, | 7 | immutableAssign, |
8 | killallServers, | 8 | killallServers, |
9 | reRunServer, | 9 | reRunServer, |
10 | runServer, | 10 | flushAndRunServer, |
11 | ServerInfo, | 11 | ServerInfo, |
12 | setAccessTokensToServers | 12 | setAccessTokensToServers, cleanupTests |
13 | } from '../../../../shared/utils' | 13 | } from '../../../../shared/extra-utils' |
14 | import { | 14 | import { |
15 | checkBadCountPagination, | 15 | checkBadCountPagination, |
16 | checkBadSortPagination, | 16 | checkBadSortPagination, |
17 | checkBadStartPagination | 17 | checkBadStartPagination |
18 | } from '../../../../shared/utils/requests/check-api-params' | 18 | } from '../../../../shared/extra-utils/requests/check-api-params' |
19 | import { getAccount } from '../../../../shared/utils/users/accounts' | 19 | import { getAccount } from '../../../../shared/extra-utils/users/accounts' |
20 | import { sendContactForm } from '../../../../shared/utils/server/contact-form' | 20 | import { sendContactForm } from '../../../../shared/extra-utils/server/contact-form' |
21 | import { MockSmtpServer } from '../../../../shared/utils/miscs/email' | 21 | import { MockSmtpServer } from '../../../../shared/extra-utils/miscs/email' |
22 | 22 | ||
23 | describe('Test contact form API validators', function () { | 23 | describe('Test contact form API validators', function () { |
24 | let server: ServerInfo | 24 | let server: ServerInfo |
@@ -28,17 +28,17 @@ describe('Test contact form API validators', function () { | |||
28 | fromEmail: 'toto@example.com', | 28 | fromEmail: 'toto@example.com', |
29 | body: 'Hello, how are you?' | 29 | body: 'Hello, how are you?' |
30 | } | 30 | } |
31 | let emailPort: number | ||
31 | 32 | ||
32 | // --------------------------------------------------------------- | 33 | // --------------------------------------------------------------- |
33 | 34 | ||
34 | before(async function () { | 35 | before(async function () { |
35 | this.timeout(60000) | 36 | this.timeout(60000) |
36 | 37 | ||
37 | await flushTests() | 38 | emailPort = await MockSmtpServer.Instance.collectEmails(emails) |
38 | await MockSmtpServer.Instance.collectEmails(emails) | ||
39 | 39 | ||
40 | // Email is disabled | 40 | // Email is disabled |
41 | server = await runServer(1) | 41 | server = await flushAndRunServer(1) |
42 | }) | 42 | }) |
43 | 43 | ||
44 | it('Should not accept a contact form if emails are disabled', async function () { | 44 | it('Should not accept a contact form if emails are disabled', async function () { |
@@ -51,7 +51,7 @@ describe('Test contact form API validators', function () { | |||
51 | killallServers([ server ]) | 51 | killallServers([ server ]) |
52 | 52 | ||
53 | // Contact form is disabled | 53 | // Contact form is disabled |
54 | await reRunServer(server, { smtp: { hostname: 'localhost' }, contact_form: { enabled: false } }) | 54 | await reRunServer(server, { smtp: { hostname: 'localhost', port: emailPort }, contact_form: { enabled: false } }) |
55 | await sendContactForm(immutableAssign(defaultBody, { url: server.url, expectedStatus: 409 })) | 55 | await sendContactForm(immutableAssign(defaultBody, { url: server.url, expectedStatus: 409 })) |
56 | }) | 56 | }) |
57 | 57 | ||
@@ -61,7 +61,7 @@ describe('Test contact form API validators', function () { | |||
61 | killallServers([ server ]) | 61 | killallServers([ server ]) |
62 | 62 | ||
63 | // Email & contact form enabled | 63 | // Email & contact form enabled |
64 | await reRunServer(server, { smtp: { hostname: 'localhost' } }) | 64 | await reRunServer(server, { smtp: { hostname: 'localhost', port: emailPort } }) |
65 | 65 | ||
66 | await sendContactForm(immutableAssign(defaultBody, { url: server.url, expectedStatus: 400, fromEmail: 'badEmail' })) | 66 | await sendContactForm(immutableAssign(defaultBody, { url: server.url, expectedStatus: 400, fromEmail: 'badEmail' })) |
67 | await sendContactForm(immutableAssign(defaultBody, { url: server.url, expectedStatus: 400, fromEmail: 'badEmail@' })) | 67 | await sendContactForm(immutableAssign(defaultBody, { url: server.url, expectedStatus: 400, fromEmail: 'badEmail@' })) |
@@ -86,11 +86,7 @@ describe('Test contact form API validators', function () { | |||
86 | 86 | ||
87 | after(async function () { | 87 | after(async function () { |
88 | MockSmtpServer.Instance.kill() | 88 | MockSmtpServer.Instance.kill() |
89 | killallServers([ server ]) | ||
90 | 89 | ||
91 | // Keep the logs if the test failed | 90 | await cleanupTests([ server ]) |
92 | if (this['ok']) { | ||
93 | await flushTests() | ||
94 | } | ||
95 | }) | 91 | }) |
96 | }) | 92 | }) |
diff --git a/server/tests/api/check-params/debug.ts b/server/tests/api/check-params/debug.ts new file mode 100644 index 000000000..8dad26723 --- /dev/null +++ b/server/tests/api/check-params/debug.ts | |||
@@ -0,0 +1,71 @@ | |||
1 | /* tslint:disable:no-unused-expression */ | ||
2 | |||
3 | import 'mocha' | ||
4 | |||
5 | import { | ||
6 | createUser, | ||
7 | flushTests, | ||
8 | killallServers, | ||
9 | flushAndRunServer, | ||
10 | ServerInfo, | ||
11 | setAccessTokensToServers, | ||
12 | userLogin, cleanupTests | ||
13 | } from '../../../../shared/extra-utils' | ||
14 | import { makeGetRequest } from '../../../../shared/extra-utils/requests/requests' | ||
15 | |||
16 | describe('Test debug API validators', function () { | ||
17 | const path = '/api/v1/server/debug' | ||
18 | let server: ServerInfo | ||
19 | let userAccessToken = '' | ||
20 | |||
21 | // --------------------------------------------------------------- | ||
22 | |||
23 | before(async function () { | ||
24 | this.timeout(120000) | ||
25 | |||
26 | server = await flushAndRunServer(1) | ||
27 | |||
28 | await setAccessTokensToServers([ server ]) | ||
29 | |||
30 | const user = { | ||
31 | username: 'user1', | ||
32 | password: 'my super password' | ||
33 | } | ||
34 | await createUser({ url: server.url, accessToken: server.accessToken, username: user.username, password: user.password }) | ||
35 | userAccessToken = await userLogin(server, user) | ||
36 | }) | ||
37 | |||
38 | describe('When getting debug endpoint', function () { | ||
39 | |||
40 | it('Should fail with a non authenticated user', async function () { | ||
41 | await makeGetRequest({ | ||
42 | url: server.url, | ||
43 | path, | ||
44 | statusCodeExpected: 401 | ||
45 | }) | ||
46 | }) | ||
47 | |||
48 | it('Should fail with a non admin user', async function () { | ||
49 | await makeGetRequest({ | ||
50 | url: server.url, | ||
51 | path, | ||
52 | token: userAccessToken, | ||
53 | statusCodeExpected: 403 | ||
54 | }) | ||
55 | }) | ||
56 | |||
57 | it('Should succeed with the correct params', async function () { | ||
58 | await makeGetRequest({ | ||
59 | url: server.url, | ||
60 | path, | ||
61 | token: server.accessToken, | ||
62 | query: { startDate: new Date().toISOString() }, | ||
63 | statusCodeExpected: 200 | ||
64 | }) | ||
65 | }) | ||
66 | }) | ||
67 | |||
68 | after(async function () { | ||
69 | await cleanupTests([ server ]) | ||
70 | }) | ||
71 | }) | ||
diff --git a/server/tests/api/check-params/follows.ts b/server/tests/api/check-params/follows.ts index 2ad1575a3..2eb54cb0a 100644 --- a/server/tests/api/check-params/follows.ts +++ b/server/tests/api/check-params/follows.ts | |||
@@ -3,14 +3,20 @@ | |||
3 | import 'mocha' | 3 | import 'mocha' |
4 | 4 | ||
5 | import { | 5 | import { |
6 | createUser, flushTests, killallServers, makeDeleteRequest, makePostBodyRequest, runServer, ServerInfo, setAccessTokensToServers, | 6 | cleanupTests, |
7 | createUser, | ||
8 | flushAndRunServer, | ||
9 | makeDeleteRequest, | ||
10 | makePostBodyRequest, | ||
11 | ServerInfo, | ||
12 | setAccessTokensToServers, | ||
7 | userLogin | 13 | userLogin |
8 | } from '../../../../shared/utils' | 14 | } from '../../../../shared/extra-utils' |
9 | import { | 15 | import { |
10 | checkBadCountPagination, | 16 | checkBadCountPagination, |
11 | checkBadSortPagination, | 17 | checkBadSortPagination, |
12 | checkBadStartPagination | 18 | checkBadStartPagination |
13 | } from '../../../../shared/utils/requests/check-api-params' | 19 | } from '../../../../shared/extra-utils/requests/check-api-params' |
14 | 20 | ||
15 | describe('Test server follows API validators', function () { | 21 | describe('Test server follows API validators', function () { |
16 | let server: ServerInfo | 22 | let server: ServerInfo |
@@ -20,8 +26,7 @@ describe('Test server follows API validators', function () { | |||
20 | before(async function () { | 26 | before(async function () { |
21 | this.timeout(30000) | 27 | this.timeout(30000) |
22 | 28 | ||
23 | await flushTests() | 29 | server = await flushAndRunServer(1) |
24 | server = await runServer(1) | ||
25 | 30 | ||
26 | await setAccessTokensToServers([ server ]) | 31 | await setAccessTokensToServers([ server ]) |
27 | }) | 32 | }) |
@@ -35,7 +40,7 @@ describe('Test server follows API validators', function () { | |||
35 | password: 'password' | 40 | password: 'password' |
36 | } | 41 | } |
37 | 42 | ||
38 | await createUser(server.url, server.accessToken, user.username, user.password) | 43 | await createUser({ url: server.url, accessToken: server.accessToken, username: user.username, password: user.password }) |
39 | userAccessToken = await userLogin(server, user) | 44 | userAccessToken = await userLogin(server, user) |
40 | }) | 45 | }) |
41 | 46 | ||
@@ -144,6 +149,126 @@ describe('Test server follows API validators', function () { | |||
144 | }) | 149 | }) |
145 | }) | 150 | }) |
146 | 151 | ||
152 | describe('When removing a follower', function () { | ||
153 | const path = '/api/v1/server/followers' | ||
154 | |||
155 | it('Should fail with an invalid token', async function () { | ||
156 | await makeDeleteRequest({ | ||
157 | url: server.url, | ||
158 | path: path + '/toto@localhost:9002', | ||
159 | token: 'fake_token', | ||
160 | statusCodeExpected: 401 | ||
161 | }) | ||
162 | }) | ||
163 | |||
164 | it('Should fail if the user is not an administrator', async function () { | ||
165 | await makeDeleteRequest({ | ||
166 | url: server.url, | ||
167 | path: path + '/toto@localhost:9002', | ||
168 | token: userAccessToken, | ||
169 | statusCodeExpected: 403 | ||
170 | }) | ||
171 | }) | ||
172 | |||
173 | it('Should fail with an invalid follower', async function () { | ||
174 | await makeDeleteRequest({ | ||
175 | url: server.url, | ||
176 | path: path + '/toto', | ||
177 | token: server.accessToken, | ||
178 | statusCodeExpected: 400 | ||
179 | }) | ||
180 | }) | ||
181 | |||
182 | it('Should fail with an unknown follower', async function () { | ||
183 | await makeDeleteRequest({ | ||
184 | url: server.url, | ||
185 | path: path + '/toto@localhost:9003', | ||
186 | token: server.accessToken, | ||
187 | statusCodeExpected: 404 | ||
188 | }) | ||
189 | }) | ||
190 | }) | ||
191 | |||
192 | describe('When accepting a follower', function () { | ||
193 | const path = '/api/v1/server/followers' | ||
194 | |||
195 | it('Should fail with an invalid token', async function () { | ||
196 | await makePostBodyRequest({ | ||
197 | url: server.url, | ||
198 | path: path + '/toto@localhost:9002/accept', | ||
199 | token: 'fake_token', | ||
200 | statusCodeExpected: 401 | ||
201 | }) | ||
202 | }) | ||
203 | |||
204 | it('Should fail if the user is not an administrator', async function () { | ||
205 | await makePostBodyRequest({ | ||
206 | url: server.url, | ||
207 | path: path + '/toto@localhost:9002/accept', | ||
208 | token: userAccessToken, | ||
209 | statusCodeExpected: 403 | ||
210 | }) | ||
211 | }) | ||
212 | |||
213 | it('Should fail with an invalid follower', async function () { | ||
214 | await makePostBodyRequest({ | ||
215 | url: server.url, | ||
216 | path: path + '/toto/accept', | ||
217 | token: server.accessToken, | ||
218 | statusCodeExpected: 400 | ||
219 | }) | ||
220 | }) | ||
221 | |||
222 | it('Should fail with an unknown follower', async function () { | ||
223 | await makePostBodyRequest({ | ||
224 | url: server.url, | ||
225 | path: path + '/toto@localhost:9003/accept', | ||
226 | token: server.accessToken, | ||
227 | statusCodeExpected: 404 | ||
228 | }) | ||
229 | }) | ||
230 | }) | ||
231 | |||
232 | describe('When rejecting a follower', function () { | ||
233 | const path = '/api/v1/server/followers' | ||
234 | |||
235 | it('Should fail with an invalid token', async function () { | ||
236 | await makePostBodyRequest({ | ||
237 | url: server.url, | ||
238 | path: path + '/toto@localhost:9002/reject', | ||
239 | token: 'fake_token', | ||
240 | statusCodeExpected: 401 | ||
241 | }) | ||
242 | }) | ||
243 | |||
244 | it('Should fail if the user is not an administrator', async function () { | ||
245 | await makePostBodyRequest({ | ||
246 | url: server.url, | ||
247 | path: path + '/toto@localhost:9002/reject', | ||
248 | token: userAccessToken, | ||
249 | statusCodeExpected: 403 | ||
250 | }) | ||
251 | }) | ||
252 | |||
253 | it('Should fail with an invalid follower', async function () { | ||
254 | await makePostBodyRequest({ | ||
255 | url: server.url, | ||
256 | path: path + '/toto/reject', | ||
257 | token: server.accessToken, | ||
258 | statusCodeExpected: 400 | ||
259 | }) | ||
260 | }) | ||
261 | |||
262 | it('Should fail with an unknown follower', async function () { | ||
263 | await makePostBodyRequest({ | ||
264 | url: server.url, | ||
265 | path: path + '/toto@localhost:9003/reject', | ||
266 | token: server.accessToken, | ||
267 | statusCodeExpected: 404 | ||
268 | }) | ||
269 | }) | ||
270 | }) | ||
271 | |||
147 | describe('When removing following', function () { | 272 | describe('When removing following', function () { |
148 | const path = '/api/v1/server/following' | 273 | const path = '/api/v1/server/following' |
149 | 274 | ||
@@ -177,11 +302,6 @@ describe('Test server follows API validators', function () { | |||
177 | }) | 302 | }) |
178 | 303 | ||
179 | after(async function () { | 304 | after(async function () { |
180 | killallServers([ server ]) | 305 | await cleanupTests([ server ]) |
181 | |||
182 | // Keep the logs if the test failed | ||
183 | if (this['ok']) { | ||
184 | await flushTests() | ||
185 | } | ||
186 | }) | 306 | }) |
187 | }) | 307 | }) |
diff --git a/server/tests/api/check-params/index.ts b/server/tests/api/check-params/index.ts index 77c17036a..844fa31c5 100644 --- a/server/tests/api/check-params/index.ts +++ b/server/tests/api/check-params/index.ts | |||
@@ -2,8 +2,10 @@ import './accounts' | |||
2 | import './blocklist' | 2 | import './blocklist' |
3 | import './config' | 3 | import './config' |
4 | import './contact-form' | 4 | import './contact-form' |
5 | import './debug' | ||
5 | import './follows' | 6 | import './follows' |
6 | import './jobs' | 7 | import './jobs' |
8 | import './logs' | ||
7 | import './redundancy' | 9 | import './redundancy' |
8 | import './search' | 10 | import './search' |
9 | import './services' | 11 | import './services' |
@@ -16,6 +18,7 @@ import './video-captions' | |||
16 | import './video-channels' | 18 | import './video-channels' |
17 | import './video-comments' | 19 | import './video-comments' |
18 | import './video-imports' | 20 | import './video-imports' |
21 | import './video-playlists' | ||
19 | import './videos' | 22 | import './videos' |
20 | import './videos-filter' | 23 | import './videos-filter' |
21 | import './videos-history' | 24 | import './videos-history' |
diff --git a/server/tests/api/check-params/jobs.ts b/server/tests/api/check-params/jobs.ts index 89760ff98..c70139514 100644 --- a/server/tests/api/check-params/jobs.ts +++ b/server/tests/api/check-params/jobs.ts | |||
@@ -6,17 +6,18 @@ import { | |||
6 | createUser, | 6 | createUser, |
7 | flushTests, | 7 | flushTests, |
8 | killallServers, | 8 | killallServers, |
9 | runServer, | 9 | flushAndRunServer, |
10 | ServerInfo, | 10 | ServerInfo, |
11 | setAccessTokensToServers, | 11 | setAccessTokensToServers, |
12 | userLogin | 12 | userLogin, |
13 | } from '../../../../shared/utils' | 13 | cleanupTests |
14 | } from '../../../../shared/extra-utils' | ||
14 | import { | 15 | import { |
15 | checkBadCountPagination, | 16 | checkBadCountPagination, |
16 | checkBadSortPagination, | 17 | checkBadSortPagination, |
17 | checkBadStartPagination | 18 | checkBadStartPagination |
18 | } from '../../../../shared/utils/requests/check-api-params' | 19 | } from '../../../../shared/extra-utils/requests/check-api-params' |
19 | import { makeGetRequest } from '../../../../shared/utils/requests/requests' | 20 | import { makeGetRequest } from '../../../../shared/extra-utils/requests/requests' |
20 | 21 | ||
21 | describe('Test jobs API validators', function () { | 22 | describe('Test jobs API validators', function () { |
22 | const path = '/api/v1/jobs/failed' | 23 | const path = '/api/v1/jobs/failed' |
@@ -28,9 +29,7 @@ describe('Test jobs API validators', function () { | |||
28 | before(async function () { | 29 | before(async function () { |
29 | this.timeout(120000) | 30 | this.timeout(120000) |
30 | 31 | ||
31 | await flushTests() | 32 | server = await flushAndRunServer(1) |
32 | |||
33 | server = await runServer(1) | ||
34 | 33 | ||
35 | await setAccessTokensToServers([ server ]) | 34 | await setAccessTokensToServers([ server ]) |
36 | 35 | ||
@@ -38,7 +37,7 @@ describe('Test jobs API validators', function () { | |||
38 | username: 'user1', | 37 | username: 'user1', |
39 | password: 'my super password' | 38 | password: 'my super password' |
40 | } | 39 | } |
41 | await createUser(server.url, server.accessToken, user.username, user.password) | 40 | await createUser({ url: server.url, accessToken: server.accessToken, username: user.username, password: user.password }) |
42 | userAccessToken = await userLogin(server, user) | 41 | userAccessToken = await userLogin(server, user) |
43 | }) | 42 | }) |
44 | 43 | ||
@@ -83,11 +82,6 @@ describe('Test jobs API validators', function () { | |||
83 | }) | 82 | }) |
84 | 83 | ||
85 | after(async function () { | 84 | after(async function () { |
86 | killallServers([ server ]) | 85 | await cleanupTests([ server ]) |
87 | |||
88 | // Keep the logs if the test failed | ||
89 | if (this['ok']) { | ||
90 | await flushTests() | ||
91 | } | ||
92 | }) | 86 | }) |
93 | }) | 87 | }) |
diff --git a/server/tests/api/check-params/logs.ts b/server/tests/api/check-params/logs.ts new file mode 100644 index 000000000..f9d96bcc0 --- /dev/null +++ b/server/tests/api/check-params/logs.ts | |||
@@ -0,0 +1,111 @@ | |||
1 | /* tslint:disable:no-unused-expression */ | ||
2 | |||
3 | import 'mocha' | ||
4 | |||
5 | import { | ||
6 | createUser, | ||
7 | flushTests, | ||
8 | killallServers, | ||
9 | flushAndRunServer, | ||
10 | ServerInfo, | ||
11 | setAccessTokensToServers, | ||
12 | userLogin, | ||
13 | cleanupTests | ||
14 | } from '../../../../shared/extra-utils' | ||
15 | import { makeGetRequest } from '../../../../shared/extra-utils/requests/requests' | ||
16 | |||
17 | describe('Test logs API validators', function () { | ||
18 | const path = '/api/v1/server/logs' | ||
19 | let server: ServerInfo | ||
20 | let userAccessToken = '' | ||
21 | |||
22 | // --------------------------------------------------------------- | ||
23 | |||
24 | before(async function () { | ||
25 | this.timeout(120000) | ||
26 | |||
27 | server = await flushAndRunServer(1) | ||
28 | |||
29 | await setAccessTokensToServers([ server ]) | ||
30 | |||
31 | const user = { | ||
32 | username: 'user1', | ||
33 | password: 'my super password' | ||
34 | } | ||
35 | await createUser({ url: server.url, accessToken: server.accessToken, username: user.username, password: user.password }) | ||
36 | userAccessToken = await userLogin(server, user) | ||
37 | }) | ||
38 | |||
39 | describe('When getting logs', function () { | ||
40 | |||
41 | it('Should fail with a non authenticated user', async function () { | ||
42 | await makeGetRequest({ | ||
43 | url: server.url, | ||
44 | path, | ||
45 | statusCodeExpected: 401 | ||
46 | }) | ||
47 | }) | ||
48 | |||
49 | it('Should fail with a non admin user', async function () { | ||
50 | await makeGetRequest({ | ||
51 | url: server.url, | ||
52 | path, | ||
53 | token: userAccessToken, | ||
54 | statusCodeExpected: 403 | ||
55 | }) | ||
56 | }) | ||
57 | |||
58 | it('Should fail with a missing startDate query', async function () { | ||
59 | await makeGetRequest({ | ||
60 | url: server.url, | ||
61 | path, | ||
62 | token: server.accessToken, | ||
63 | statusCodeExpected: 400 | ||
64 | }) | ||
65 | }) | ||
66 | |||
67 | it('Should fail with a bad startDate query', async function () { | ||
68 | await makeGetRequest({ | ||
69 | url: server.url, | ||
70 | path, | ||
71 | token: server.accessToken, | ||
72 | query: { startDate: 'toto' }, | ||
73 | statusCodeExpected: 400 | ||
74 | }) | ||
75 | }) | ||
76 | |||
77 | it('Should fail with a bad endDate query', async function () { | ||
78 | await makeGetRequest({ | ||
79 | url: server.url, | ||
80 | path, | ||
81 | token: server.accessToken, | ||
82 | query: { startDate: new Date().toISOString(), endDate: 'toto' }, | ||
83 | statusCodeExpected: 400 | ||
84 | }) | ||
85 | }) | ||
86 | |||
87 | it('Should fail with a bad level parameter', async function () { | ||
88 | await makeGetRequest({ | ||
89 | url: server.url, | ||
90 | path, | ||
91 | token: server.accessToken, | ||
92 | query: { startDate: new Date().toISOString(), level: 'toto' }, | ||
93 | statusCodeExpected: 400 | ||
94 | }) | ||
95 | }) | ||
96 | |||
97 | it('Should succeed with the correct params', async function () { | ||
98 | await makeGetRequest({ | ||
99 | url: server.url, | ||
100 | path, | ||
101 | token: server.accessToken, | ||
102 | query: { startDate: new Date().toISOString() }, | ||
103 | statusCodeExpected: 200 | ||
104 | }) | ||
105 | }) | ||
106 | }) | ||
107 | |||
108 | after(async function () { | ||
109 | await cleanupTests([ server ]) | ||
110 | }) | ||
111 | }) | ||
diff --git a/server/tests/api/check-params/redundancy.ts b/server/tests/api/check-params/redundancy.ts index ff4726ceb..6471da840 100644 --- a/server/tests/api/check-params/redundancy.ts +++ b/server/tests/api/check-params/redundancy.ts | |||
@@ -3,6 +3,7 @@ | |||
3 | import 'mocha' | 3 | import 'mocha' |
4 | 4 | ||
5 | import { | 5 | import { |
6 | cleanupTests, | ||
6 | createUser, | 7 | createUser, |
7 | doubleFollow, | 8 | doubleFollow, |
8 | flushAndRunMultipleServers, | 9 | flushAndRunMultipleServers, |
@@ -12,7 +13,7 @@ import { | |||
12 | ServerInfo, | 13 | ServerInfo, |
13 | setAccessTokensToServers, | 14 | setAccessTokensToServers, |
14 | userLogin | 15 | userLogin |
15 | } from '../../../../shared/utils' | 16 | } from '../../../../shared/extra-utils' |
16 | 17 | ||
17 | describe('Test server redundancy API validators', function () { | 18 | describe('Test server redundancy API validators', function () { |
18 | let servers: ServerInfo[] | 19 | let servers: ServerInfo[] |
@@ -23,7 +24,6 @@ describe('Test server redundancy API validators', function () { | |||
23 | before(async function () { | 24 | before(async function () { |
24 | this.timeout(30000) | 25 | this.timeout(30000) |
25 | 26 | ||
26 | await flushTests() | ||
27 | servers = await flushAndRunMultipleServers(2) | 27 | servers = await flushAndRunMultipleServers(2) |
28 | 28 | ||
29 | await setAccessTokensToServers(servers) | 29 | await setAccessTokensToServers(servers) |
@@ -34,7 +34,7 @@ describe('Test server redundancy API validators', function () { | |||
34 | password: 'password' | 34 | password: 'password' |
35 | } | 35 | } |
36 | 36 | ||
37 | await createUser(servers[0].url, servers[0].accessToken, user.username, user.password) | 37 | await createUser({ url: servers[ 0 ].url, accessToken: servers[ 0 ].accessToken, username: user.username, password: user.password }) |
38 | userAccessToken = await userLogin(servers[0], user) | 38 | userAccessToken = await userLogin(servers[0], user) |
39 | }) | 39 | }) |
40 | 40 | ||
@@ -44,7 +44,7 @@ describe('Test server redundancy API validators', function () { | |||
44 | it('Should fail with an invalid token', async function () { | 44 | it('Should fail with an invalid token', async function () { |
45 | await makePutBodyRequest({ | 45 | await makePutBodyRequest({ |
46 | url: servers[0].url, | 46 | url: servers[0].url, |
47 | path: path + '/localhost:9002', | 47 | path: path + '/localhost:' + servers[1].port, |
48 | fields: { redundancyAllowed: true }, | 48 | fields: { redundancyAllowed: true }, |
49 | token: 'fake_token', | 49 | token: 'fake_token', |
50 | statusCodeExpected: 401 | 50 | statusCodeExpected: 401 |
@@ -54,7 +54,7 @@ describe('Test server redundancy API validators', function () { | |||
54 | it('Should fail if the user is not an administrator', async function () { | 54 | it('Should fail if the user is not an administrator', async function () { |
55 | await makePutBodyRequest({ | 55 | await makePutBodyRequest({ |
56 | url: servers[0].url, | 56 | url: servers[0].url, |
57 | path: path + '/localhost:9002', | 57 | path: path + '/localhost:' + servers[1].port, |
58 | fields: { redundancyAllowed: true }, | 58 | fields: { redundancyAllowed: true }, |
59 | token: userAccessToken, | 59 | token: userAccessToken, |
60 | statusCodeExpected: 403 | 60 | statusCodeExpected: 403 |
@@ -74,7 +74,7 @@ describe('Test server redundancy API validators', function () { | |||
74 | it('Should fail without de redundancyAllowed param', async function () { | 74 | it('Should fail without de redundancyAllowed param', async function () { |
75 | await makePutBodyRequest({ | 75 | await makePutBodyRequest({ |
76 | url: servers[0].url, | 76 | url: servers[0].url, |
77 | path: path + '/localhost:9002', | 77 | path: path + '/localhost:' + servers[1].port, |
78 | fields: { blabla: true }, | 78 | fields: { blabla: true }, |
79 | token: servers[0].accessToken, | 79 | token: servers[0].accessToken, |
80 | statusCodeExpected: 400 | 80 | statusCodeExpected: 400 |
@@ -84,7 +84,7 @@ describe('Test server redundancy API validators', function () { | |||
84 | it('Should succeed with the correct parameters', async function () { | 84 | it('Should succeed with the correct parameters', async function () { |
85 | await makePutBodyRequest({ | 85 | await makePutBodyRequest({ |
86 | url: servers[0].url, | 86 | url: servers[0].url, |
87 | path: path + '/localhost:9002', | 87 | path: path + '/localhost:' + servers[1].port, |
88 | fields: { redundancyAllowed: true }, | 88 | fields: { redundancyAllowed: true }, |
89 | token: servers[0].accessToken, | 89 | token: servers[0].accessToken, |
90 | statusCodeExpected: 204 | 90 | statusCodeExpected: 204 |
@@ -93,11 +93,6 @@ describe('Test server redundancy API validators', function () { | |||
93 | }) | 93 | }) |
94 | 94 | ||
95 | after(async function () { | 95 | after(async function () { |
96 | killallServers(servers) | 96 | await cleanupTests(servers) |
97 | |||
98 | // Keep the logs if the test failed | ||
99 | if (this['ok']) { | ||
100 | await flushTests() | ||
101 | } | ||
102 | }) | 97 | }) |
103 | }) | 98 | }) |
diff --git a/server/tests/api/check-params/search.ts b/server/tests/api/check-params/search.ts index aa81965f3..8ad9d98bf 100644 --- a/server/tests/api/check-params/search.ts +++ b/server/tests/api/check-params/search.ts | |||
@@ -2,12 +2,12 @@ | |||
2 | 2 | ||
3 | import 'mocha' | 3 | import 'mocha' |
4 | 4 | ||
5 | import { flushTests, immutableAssign, killallServers, makeGetRequest, runServer, ServerInfo } from '../../../../shared/utils' | 5 | import { cleanupTests, flushAndRunServer, immutableAssign, makeGetRequest, ServerInfo } from '../../../../shared/extra-utils' |
6 | import { | 6 | import { |
7 | checkBadCountPagination, | 7 | checkBadCountPagination, |
8 | checkBadSortPagination, | 8 | checkBadSortPagination, |
9 | checkBadStartPagination | 9 | checkBadStartPagination |
10 | } from '../../../../shared/utils/requests/check-api-params' | 10 | } from '../../../../shared/extra-utils/requests/check-api-params' |
11 | 11 | ||
12 | describe('Test videos API validator', function () { | 12 | describe('Test videos API validator', function () { |
13 | let server: ServerInfo | 13 | let server: ServerInfo |
@@ -17,9 +17,7 @@ describe('Test videos API validator', function () { | |||
17 | before(async function () { | 17 | before(async function () { |
18 | this.timeout(30000) | 18 | this.timeout(30000) |
19 | 19 | ||
20 | await flushTests() | 20 | server = await flushAndRunServer(1) |
21 | |||
22 | server = await runServer(1) | ||
23 | }) | 21 | }) |
24 | 22 | ||
25 | describe('When searching videos', function () { | 23 | describe('When searching videos', function () { |
@@ -113,6 +111,12 @@ describe('Test videos API validator', function () { | |||
113 | 111 | ||
114 | const customQuery2 = immutableAssign(query, { endDate: 'hello' }) | 112 | const customQuery2 = immutableAssign(query, { endDate: 'hello' }) |
115 | await makeGetRequest({ url: server.url, path, query: customQuery2, statusCodeExpected: 400 }) | 113 | await makeGetRequest({ url: server.url, path, query: customQuery2, statusCodeExpected: 400 }) |
114 | |||
115 | const customQuery3 = immutableAssign(query, { originallyPublishedStartDate: 'hello' }) | ||
116 | await makeGetRequest({ url: server.url, path, query: customQuery3, statusCodeExpected: 400 }) | ||
117 | |||
118 | const customQuery4 = immutableAssign(query, { originallyPublishedEndDate: 'hello' }) | ||
119 | await makeGetRequest({ url: server.url, path, query: customQuery4, statusCodeExpected: 400 }) | ||
116 | }) | 120 | }) |
117 | }) | 121 | }) |
118 | 122 | ||
@@ -141,11 +145,6 @@ describe('Test videos API validator', function () { | |||
141 | }) | 145 | }) |
142 | 146 | ||
143 | after(async function () { | 147 | after(async function () { |
144 | killallServers([ server ]) | 148 | await cleanupTests([ server ]) |
145 | |||
146 | // Keep the logs if the test failed | ||
147 | if (this['ok']) { | ||
148 | await flushTests() | ||
149 | } | ||
150 | }) | 149 | }) |
151 | }) | 150 | }) |
diff --git a/server/tests/api/check-params/services.ts b/server/tests/api/check-params/services.ts index 28591af9d..d15753aed 100644 --- a/server/tests/api/check-params/services.ts +++ b/server/tests/api/check-params/services.ts | |||
@@ -3,14 +3,13 @@ | |||
3 | import 'mocha' | 3 | import 'mocha' |
4 | 4 | ||
5 | import { | 5 | import { |
6 | flushTests, | 6 | cleanupTests, |
7 | killallServers, | 7 | flushAndRunServer, |
8 | makeGetRequest, | 8 | makeGetRequest, |
9 | runServer, | ||
10 | ServerInfo, | 9 | ServerInfo, |
11 | setAccessTokensToServers, | 10 | setAccessTokensToServers, |
12 | uploadVideo | 11 | uploadVideo |
13 | } from '../../../../shared/utils' | 12 | } from '../../../../shared/extra-utils' |
14 | 13 | ||
15 | describe('Test services API validators', function () { | 14 | describe('Test services API validators', function () { |
16 | let server: ServerInfo | 15 | let server: ServerInfo |
@@ -20,9 +19,7 @@ describe('Test services API validators', function () { | |||
20 | before(async function () { | 19 | before(async function () { |
21 | this.timeout(60000) | 20 | this.timeout(60000) |
22 | 21 | ||
23 | await flushTests() | 22 | server = await flushAndRunServer(1) |
24 | |||
25 | server = await runServer(1) | ||
26 | await setAccessTokensToServers([ server ]) | 23 | await setAccessTokensToServers([ server ]) |
27 | 24 | ||
28 | const res = await uploadVideo(server.url, server.accessToken, { name: 'my super name' }) | 25 | const res = await uploadVideo(server.url, server.accessToken, { name: 'my super name' }) |
@@ -42,47 +39,47 @@ describe('Test services API validators', function () { | |||
42 | }) | 39 | }) |
43 | 40 | ||
44 | it('Should fail with an invalid video id', async function () { | 41 | it('Should fail with an invalid video id', async function () { |
45 | const embedUrl = 'http://localhost:9001/videos/watch/blabla' | 42 | const embedUrl = `http://localhost:${server.port}/videos/watch/blabla` |
46 | await checkParamEmbed(server, embedUrl) | 43 | await checkParamEmbed(server, embedUrl) |
47 | }) | 44 | }) |
48 | 45 | ||
49 | it('Should fail with an unknown video', async function () { | 46 | it('Should fail with an unknown video', async function () { |
50 | const embedUrl = 'http://localhost:9001/videos/watch/88fc0165-d1f0-4a35-a51a-3b47f668689c' | 47 | const embedUrl = `http://localhost:${server.port}/videos/watch/88fc0165-d1f0-4a35-a51a-3b47f668689c` |
51 | await checkParamEmbed(server, embedUrl, 404) | 48 | await checkParamEmbed(server, embedUrl, 404) |
52 | }) | 49 | }) |
53 | 50 | ||
54 | it('Should fail with an invalid path', async function () { | 51 | it('Should fail with an invalid path', async function () { |
55 | const embedUrl = 'http://localhost:9001/videos/watchs/' + server.video.uuid | 52 | const embedUrl = `http://localhost:${server.port}/videos/watchs/${server.video.uuid}` |
56 | 53 | ||
57 | await checkParamEmbed(server, embedUrl) | 54 | await checkParamEmbed(server, embedUrl) |
58 | }) | 55 | }) |
59 | 56 | ||
60 | it('Should fail with an invalid max height', async function () { | 57 | it('Should fail with an invalid max height', async function () { |
61 | const embedUrl = 'http://localhost:9001/videos/watch/' + server.video.uuid | 58 | const embedUrl = `http://localhost:${server.port}/videos/watch/${server.video.uuid}` |
62 | 59 | ||
63 | await checkParamEmbed(server, embedUrl, 400, { maxheight: 'hello' }) | 60 | await checkParamEmbed(server, embedUrl, 400, { maxheight: 'hello' }) |
64 | }) | 61 | }) |
65 | 62 | ||
66 | it('Should fail with an invalid max width', async function () { | 63 | it('Should fail with an invalid max width', async function () { |
67 | const embedUrl = 'http://localhost:9001/videos/watch/' + server.video.uuid | 64 | const embedUrl = `http://localhost:${server.port}/videos/watch/${server.video.uuid}` |
68 | 65 | ||
69 | await checkParamEmbed(server, embedUrl, 400, { maxwidth: 'hello' }) | 66 | await checkParamEmbed(server, embedUrl, 400, { maxwidth: 'hello' }) |
70 | }) | 67 | }) |
71 | 68 | ||
72 | it('Should fail with an invalid format', async function () { | 69 | it('Should fail with an invalid format', async function () { |
73 | const embedUrl = 'http://localhost:9001/videos/watch/' + server.video.uuid | 70 | const embedUrl = `http://localhost:${server.port}/videos/watch/${server.video.uuid}` |
74 | 71 | ||
75 | await checkParamEmbed(server, embedUrl, 400, { format: 'blabla' }) | 72 | await checkParamEmbed(server, embedUrl, 400, { format: 'blabla' }) |
76 | }) | 73 | }) |
77 | 74 | ||
78 | it('Should fail with a non supported format', async function () { | 75 | it('Should fail with a non supported format', async function () { |
79 | const embedUrl = 'http://localhost:9001/videos/watch/' + server.video.uuid | 76 | const embedUrl = `http://localhost:${server.port}/videos/watch/${server.video.uuid}` |
80 | 77 | ||
81 | await checkParamEmbed(server, embedUrl, 501, { format: 'xml' }) | 78 | await checkParamEmbed(server, embedUrl, 501, { format: 'xml' }) |
82 | }) | 79 | }) |
83 | 80 | ||
84 | it('Should succeed with the correct params', async function () { | 81 | it('Should succeed with the correct params', async function () { |
85 | const embedUrl = 'http://localhost:9001/videos/watch/' + server.video.uuid | 82 | const embedUrl = `http://localhost:${server.port}/videos/watch/${server.video.uuid}` |
86 | const query = { | 83 | const query = { |
87 | format: 'json', | 84 | format: 'json', |
88 | maxheight: 400, | 85 | maxheight: 400, |
@@ -94,12 +91,7 @@ describe('Test services API validators', function () { | |||
94 | }) | 91 | }) |
95 | 92 | ||
96 | after(async function () { | 93 | after(async function () { |
97 | killallServers([ server ]) | 94 | await cleanupTests([ server ]) |
98 | |||
99 | // Keep the logs if the test failed | ||
100 | if (this['ok']) { | ||
101 | await flushTests() | ||
102 | } | ||
103 | }) | 95 | }) |
104 | }) | 96 | }) |
105 | 97 | ||
diff --git a/server/tests/api/check-params/user-notifications.ts b/server/tests/api/check-params/user-notifications.ts index 714f481e9..14ee20d45 100644 --- a/server/tests/api/check-params/user-notifications.ts +++ b/server/tests/api/check-params/user-notifications.ts | |||
@@ -4,22 +4,21 @@ import 'mocha' | |||
4 | import * as io from 'socket.io-client' | 4 | import * as io from 'socket.io-client' |
5 | 5 | ||
6 | import { | 6 | import { |
7 | flushTests, | 7 | cleanupTests, |
8 | flushAndRunServer, | ||
8 | immutableAssign, | 9 | immutableAssign, |
9 | killallServers, | ||
10 | makeGetRequest, | 10 | makeGetRequest, |
11 | makePostBodyRequest, | 11 | makePostBodyRequest, |
12 | makePutBodyRequest, | 12 | makePutBodyRequest, |
13 | runServer, | ||
14 | ServerInfo, | 13 | ServerInfo, |
15 | setAccessTokensToServers, | 14 | setAccessTokensToServers, |
16 | wait | 15 | wait |
17 | } from '../../../../shared/utils' | 16 | } from '../../../../shared/extra-utils' |
18 | import { | 17 | import { |
19 | checkBadCountPagination, | 18 | checkBadCountPagination, |
20 | checkBadSortPagination, | 19 | checkBadSortPagination, |
21 | checkBadStartPagination | 20 | checkBadStartPagination |
22 | } from '../../../../shared/utils/requests/check-api-params' | 21 | } from '../../../../shared/extra-utils/requests/check-api-params' |
23 | import { UserNotificationSetting, UserNotificationSettingValue } from '../../../../shared/models/users' | 22 | import { UserNotificationSetting, UserNotificationSettingValue } from '../../../../shared/models/users' |
24 | 23 | ||
25 | describe('Test user notifications API validators', function () { | 24 | describe('Test user notifications API validators', function () { |
@@ -30,9 +29,7 @@ describe('Test user notifications API validators', function () { | |||
30 | before(async function () { | 29 | before(async function () { |
31 | this.timeout(30000) | 30 | this.timeout(30000) |
32 | 31 | ||
33 | await flushTests() | 32 | server = await flushAndRunServer(1) |
34 | |||
35 | server = await runServer(1) | ||
36 | 33 | ||
37 | await setAccessTokensToServers([ server ]) | 34 | await setAccessTokensToServers([ server ]) |
38 | }) | 35 | }) |
@@ -168,12 +165,14 @@ describe('Test user notifications API validators', function () { | |||
168 | newVideoFromSubscription: UserNotificationSettingValue.WEB, | 165 | newVideoFromSubscription: UserNotificationSettingValue.WEB, |
169 | newCommentOnMyVideo: UserNotificationSettingValue.WEB, | 166 | newCommentOnMyVideo: UserNotificationSettingValue.WEB, |
170 | videoAbuseAsModerator: UserNotificationSettingValue.WEB, | 167 | videoAbuseAsModerator: UserNotificationSettingValue.WEB, |
168 | videoAutoBlacklistAsModerator: UserNotificationSettingValue.WEB, | ||
171 | blacklistOnMyVideo: UserNotificationSettingValue.WEB, | 169 | blacklistOnMyVideo: UserNotificationSettingValue.WEB, |
172 | myVideoImportFinished: UserNotificationSettingValue.WEB, | 170 | myVideoImportFinished: UserNotificationSettingValue.WEB, |
173 | myVideoPublished: UserNotificationSettingValue.WEB, | 171 | myVideoPublished: UserNotificationSettingValue.WEB, |
174 | commentMention: UserNotificationSettingValue.WEB, | 172 | commentMention: UserNotificationSettingValue.WEB, |
175 | newFollow: UserNotificationSettingValue.WEB, | 173 | newFollow: UserNotificationSettingValue.WEB, |
176 | newUserRegistration: UserNotificationSettingValue.WEB | 174 | newUserRegistration: UserNotificationSettingValue.WEB, |
175 | newInstanceFollower: UserNotificationSettingValue.WEB | ||
177 | } | 176 | } |
178 | 177 | ||
179 | it('Should fail with missing fields', async function () { | 178 | it('Should fail with missing fields', async function () { |
@@ -234,7 +233,7 @@ describe('Test user notifications API validators', function () { | |||
234 | 233 | ||
235 | describe('When connecting to my notification socket', function () { | 234 | describe('When connecting to my notification socket', function () { |
236 | it('Should fail with no token', function (next) { | 235 | it('Should fail with no token', function (next) { |
237 | const socket = io('http://localhost:9001/user-notifications', { reconnection: false }) | 236 | const socket = io(`http://localhost:${server.port}/user-notifications`, { reconnection: false }) |
238 | 237 | ||
239 | socket.on('error', () => { | 238 | socket.on('error', () => { |
240 | socket.removeListener('error', this) | 239 | socket.removeListener('error', this) |
@@ -249,7 +248,7 @@ describe('Test user notifications API validators', function () { | |||
249 | }) | 248 | }) |
250 | 249 | ||
251 | it('Should fail with an invalid token', function (next) { | 250 | it('Should fail with an invalid token', function (next) { |
252 | const socket = io('http://localhost:9001/user-notifications', { | 251 | const socket = io(`http://localhost:${server.port}/user-notifications`, { |
253 | query: { accessToken: 'bad_access_token' }, | 252 | query: { accessToken: 'bad_access_token' }, |
254 | reconnection: false | 253 | reconnection: false |
255 | }) | 254 | }) |
@@ -267,7 +266,7 @@ describe('Test user notifications API validators', function () { | |||
267 | }) | 266 | }) |
268 | 267 | ||
269 | it('Should success with the correct token', function (next) { | 268 | it('Should success with the correct token', function (next) { |
270 | const socket = io('http://localhost:9001/user-notifications', { | 269 | const socket = io(`http://localhost:${server.port}/user-notifications`, { |
271 | query: { accessToken: server.accessToken }, | 270 | query: { accessToken: server.accessToken }, |
272 | reconnection: false | 271 | reconnection: false |
273 | }) | 272 | }) |
@@ -287,11 +286,6 @@ describe('Test user notifications API validators', function () { | |||
287 | }) | 286 | }) |
288 | 287 | ||
289 | after(async function () { | 288 | after(async function () { |
290 | killallServers([ server ]) | 289 | await cleanupTests([ server ]) |
291 | |||
292 | // Keep the logs if the test failed | ||
293 | if (this['ok']) { | ||
294 | await flushTests() | ||
295 | } | ||
296 | }) | 290 | }) |
297 | }) | 291 | }) |
diff --git a/server/tests/api/check-params/user-subscriptions.ts b/server/tests/api/check-params/user-subscriptions.ts index 8a9ced7c1..fa36c4078 100644 --- a/server/tests/api/check-params/user-subscriptions.ts +++ b/server/tests/api/check-params/user-subscriptions.ts | |||
@@ -3,24 +3,23 @@ | |||
3 | import 'mocha' | 3 | import 'mocha' |
4 | 4 | ||
5 | import { | 5 | import { |
6 | cleanupTests, | ||
6 | createUser, | 7 | createUser, |
7 | flushTests, | 8 | flushAndRunServer, |
8 | killallServers, | ||
9 | makeDeleteRequest, | 9 | makeDeleteRequest, |
10 | makeGetRequest, | 10 | makeGetRequest, |
11 | makePostBodyRequest, | 11 | makePostBodyRequest, |
12 | runServer, | ||
13 | ServerInfo, | 12 | ServerInfo, |
14 | setAccessTokensToServers, | 13 | setAccessTokensToServers, |
15 | userLogin | 14 | userLogin |
16 | } from '../../../../shared/utils' | 15 | } from '../../../../shared/extra-utils' |
17 | 16 | ||
18 | import { | 17 | import { |
19 | checkBadCountPagination, | 18 | checkBadCountPagination, |
20 | checkBadSortPagination, | 19 | checkBadSortPagination, |
21 | checkBadStartPagination | 20 | checkBadStartPagination |
22 | } from '../../../../shared/utils/requests/check-api-params' | 21 | } from '../../../../shared/extra-utils/requests/check-api-params' |
23 | import { waitJobs } from '../../../../shared/utils/server/jobs' | 22 | import { waitJobs } from '../../../../shared/extra-utils/server/jobs' |
24 | 23 | ||
25 | describe('Test user subscriptions API validators', function () { | 24 | describe('Test user subscriptions API validators', function () { |
26 | const path = '/api/v1/users/me/subscriptions' | 25 | const path = '/api/v1/users/me/subscriptions' |
@@ -32,9 +31,7 @@ describe('Test user subscriptions API validators', function () { | |||
32 | before(async function () { | 31 | before(async function () { |
33 | this.timeout(30000) | 32 | this.timeout(30000) |
34 | 33 | ||
35 | await flushTests() | 34 | server = await flushAndRunServer(1) |
36 | |||
37 | server = await runServer(1) | ||
38 | 35 | ||
39 | await setAccessTokensToServers([ server ]) | 36 | await setAccessTokensToServers([ server ]) |
40 | 37 | ||
@@ -42,7 +39,7 @@ describe('Test user subscriptions API validators', function () { | |||
42 | username: 'user1', | 39 | username: 'user1', |
43 | password: 'my super password' | 40 | password: 'my super password' |
44 | } | 41 | } |
45 | await createUser(server.url, server.accessToken, user.username, user.password) | 42 | await createUser({ url: server.url, accessToken: server.accessToken, username: user.username, password: user.password }) |
46 | userAccessToken = await userLogin(server, user) | 43 | userAccessToken = await userLogin(server, user) |
47 | }) | 44 | }) |
48 | 45 | ||
@@ -115,7 +112,7 @@ describe('Test user subscriptions API validators', function () { | |||
115 | await makePostBodyRequest({ | 112 | await makePostBodyRequest({ |
116 | url: server.url, | 113 | url: server.url, |
117 | path, | 114 | path, |
118 | fields: { uri: 'user1_channel@localhost:9001' }, | 115 | fields: { uri: 'user1_channel@localhost:' + server.port }, |
119 | statusCodeExpected: 401 | 116 | statusCodeExpected: 401 |
120 | }) | 117 | }) |
121 | }) | 118 | }) |
@@ -153,7 +150,7 @@ describe('Test user subscriptions API validators', function () { | |||
153 | url: server.url, | 150 | url: server.url, |
154 | path, | 151 | path, |
155 | token: server.accessToken, | 152 | token: server.accessToken, |
156 | fields: { uri: 'user1_channel@localhost:9001' }, | 153 | fields: { uri: 'user1_channel@localhost:' + server.port }, |
157 | statusCodeExpected: 204 | 154 | statusCodeExpected: 204 |
158 | }) | 155 | }) |
159 | 156 | ||
@@ -165,7 +162,7 @@ describe('Test user subscriptions API validators', function () { | |||
165 | it('Should fail with a non authenticated user', async function () { | 162 | it('Should fail with a non authenticated user', async function () { |
166 | await makeGetRequest({ | 163 | await makeGetRequest({ |
167 | url: server.url, | 164 | url: server.url, |
168 | path: path + '/user1_channel@localhost:9001', | 165 | path: path + '/user1_channel@localhost:' + server.port, |
169 | statusCodeExpected: 401 | 166 | statusCodeExpected: 401 |
170 | }) | 167 | }) |
171 | }) | 168 | }) |
@@ -196,7 +193,7 @@ describe('Test user subscriptions API validators', function () { | |||
196 | it('Should fail with an unknown subscription', async function () { | 193 | it('Should fail with an unknown subscription', async function () { |
197 | await makeGetRequest({ | 194 | await makeGetRequest({ |
198 | url: server.url, | 195 | url: server.url, |
199 | path: path + '/root1@localhost:9001', | 196 | path: path + '/root1@localhost:' + server.port, |
200 | token: server.accessToken, | 197 | token: server.accessToken, |
201 | statusCodeExpected: 404 | 198 | statusCodeExpected: 404 |
202 | }) | 199 | }) |
@@ -205,14 +202,14 @@ describe('Test user subscriptions API validators', function () { | |||
205 | it('Should succeed with the correct parameters', async function () { | 202 | it('Should succeed with the correct parameters', async function () { |
206 | await makeGetRequest({ | 203 | await makeGetRequest({ |
207 | url: server.url, | 204 | url: server.url, |
208 | path: path + '/user1_channel@localhost:9001', | 205 | path: path + '/user1_channel@localhost:' + server.port, |
209 | token: server.accessToken, | 206 | token: server.accessToken, |
210 | statusCodeExpected: 200 | 207 | statusCodeExpected: 200 |
211 | }) | 208 | }) |
212 | }) | 209 | }) |
213 | }) | 210 | }) |
214 | 211 | ||
215 | describe('When checking if subscriptions exist', async function () { | 212 | describe('When checking if subscriptions exist', function () { |
216 | const existPath = path + '/exist' | 213 | const existPath = path + '/exist' |
217 | 214 | ||
218 | it('Should fail with a non authenticated user', async function () { | 215 | it('Should fail with a non authenticated user', async function () { |
@@ -245,7 +242,7 @@ describe('Test user subscriptions API validators', function () { | |||
245 | await makeGetRequest({ | 242 | await makeGetRequest({ |
246 | url: server.url, | 243 | url: server.url, |
247 | path: existPath, | 244 | path: existPath, |
248 | query: { 'uris[]': 'coucou@localhost:9001' }, | 245 | query: { 'uris[]': 'coucou@localhost:' + server.port }, |
249 | token: server.accessToken, | 246 | token: server.accessToken, |
250 | statusCodeExpected: 200 | 247 | statusCodeExpected: 200 |
251 | }) | 248 | }) |
@@ -256,7 +253,7 @@ describe('Test user subscriptions API validators', function () { | |||
256 | it('Should fail with a non authenticated user', async function () { | 253 | it('Should fail with a non authenticated user', async function () { |
257 | await makeDeleteRequest({ | 254 | await makeDeleteRequest({ |
258 | url: server.url, | 255 | url: server.url, |
259 | path: path + '/user1_channel@localhost:9001', | 256 | path: path + '/user1_channel@localhost:' + server.port, |
260 | statusCodeExpected: 401 | 257 | statusCodeExpected: 401 |
261 | }) | 258 | }) |
262 | }) | 259 | }) |
@@ -287,7 +284,7 @@ describe('Test user subscriptions API validators', function () { | |||
287 | it('Should fail with an unknown subscription', async function () { | 284 | it('Should fail with an unknown subscription', async function () { |
288 | await makeDeleteRequest({ | 285 | await makeDeleteRequest({ |
289 | url: server.url, | 286 | url: server.url, |
290 | path: path + '/root1@localhost:9001', | 287 | path: path + '/root1@localhost:' + server.port, |
291 | token: server.accessToken, | 288 | token: server.accessToken, |
292 | statusCodeExpected: 404 | 289 | statusCodeExpected: 404 |
293 | }) | 290 | }) |
@@ -296,7 +293,7 @@ describe('Test user subscriptions API validators', function () { | |||
296 | it('Should succeed with the correct parameters', async function () { | 293 | it('Should succeed with the correct parameters', async function () { |
297 | await makeDeleteRequest({ | 294 | await makeDeleteRequest({ |
298 | url: server.url, | 295 | url: server.url, |
299 | path: path + '/user1_channel@localhost:9001', | 296 | path: path + '/user1_channel@localhost:' + server.port, |
300 | token: server.accessToken, | 297 | token: server.accessToken, |
301 | statusCodeExpected: 204 | 298 | statusCodeExpected: 204 |
302 | }) | 299 | }) |
@@ -304,11 +301,6 @@ describe('Test user subscriptions API validators', function () { | |||
304 | }) | 301 | }) |
305 | 302 | ||
306 | after(async function () { | 303 | after(async function () { |
307 | killallServers([ server ]) | 304 | await cleanupTests([ server ]) |
308 | |||
309 | // Keep the logs if the test failed | ||
310 | if (this['ok']) { | ||
311 | await flushTests() | ||
312 | } | ||
313 | }) | 305 | }) |
314 | }) | 306 | }) |
diff --git a/server/tests/api/check-params/users.ts b/server/tests/api/check-params/users.ts index a3e8e2e9c..5935104a5 100644 --- a/server/tests/api/check-params/users.ts +++ b/server/tests/api/check-params/users.ts | |||
@@ -6,19 +6,38 @@ import { join } from 'path' | |||
6 | import { UserRole, VideoImport, VideoImportState } from '../../../../shared' | 6 | import { UserRole, VideoImport, VideoImportState } from '../../../../shared' |
7 | 7 | ||
8 | import { | 8 | import { |
9 | createUser, flushTests, getMyUserInformation, getMyUserVideoRating, getUsersList, immutableAssign, killallServers, makeGetRequest, | 9 | blockUser, |
10 | makePostBodyRequest, makeUploadRequest, makePutBodyRequest, registerUser, removeUser, runServer, ServerInfo, setAccessTokensToServers, | 10 | cleanupTests, |
11 | updateUser, uploadVideo, userLogin, deleteMe, unblockUser, blockUser | 11 | createUser, |
12 | } from '../../../../shared/utils' | 12 | deleteMe, |
13 | flushAndRunServer, | ||
14 | getMyUserInformation, | ||
15 | getMyUserVideoRating, | ||
16 | getUsersList, | ||
17 | immutableAssign, | ||
18 | makeGetRequest, | ||
19 | makePostBodyRequest, | ||
20 | makePutBodyRequest, | ||
21 | makeUploadRequest, | ||
22 | registerUser, | ||
23 | removeUser, | ||
24 | ServerInfo, | ||
25 | setAccessTokensToServers, | ||
26 | unblockUser, | ||
27 | updateUser, | ||
28 | uploadVideo, | ||
29 | userLogin | ||
30 | } from '../../../../shared/extra-utils' | ||
13 | import { | 31 | import { |
14 | checkBadCountPagination, | 32 | checkBadCountPagination, |
15 | checkBadSortPagination, | 33 | checkBadSortPagination, |
16 | checkBadStartPagination | 34 | checkBadStartPagination |
17 | } from '../../../../shared/utils/requests/check-api-params' | 35 | } from '../../../../shared/extra-utils/requests/check-api-params' |
18 | import { getMagnetURI, getMyVideoImports, getYoutubeVideoUrl, importVideo } from '../../../../shared/utils/videos/video-imports' | 36 | import { getMagnetURI, getMyVideoImports, getYoutubeVideoUrl, importVideo } from '../../../../shared/extra-utils/videos/video-imports' |
19 | import { VideoPrivacy } from '../../../../shared/models/videos' | 37 | import { VideoPrivacy } from '../../../../shared/models/videos' |
20 | import { waitJobs } from '../../../../shared/utils/server/jobs' | 38 | import { waitJobs } from '../../../../shared/extra-utils/server/jobs' |
21 | import { expect } from 'chai' | 39 | import { expect } from 'chai' |
40 | import { UserAdminFlag } from '../../../../shared/models/users/user-flag.model' | ||
22 | 41 | ||
23 | describe('Test users API validators', function () { | 42 | describe('Test users API validators', function () { |
24 | const path = '/api/v1/users/' | 43 | const path = '/api/v1/users/' |
@@ -39,15 +58,19 @@ describe('Test users API validators', function () { | |||
39 | before(async function () { | 58 | before(async function () { |
40 | this.timeout(30000) | 59 | this.timeout(30000) |
41 | 60 | ||
42 | await flushTests() | 61 | server = await flushAndRunServer(1) |
43 | 62 | serverWithRegistrationDisabled = await flushAndRunServer(2) | |
44 | server = await runServer(1) | ||
45 | serverWithRegistrationDisabled = await runServer(2) | ||
46 | 63 | ||
47 | await setAccessTokensToServers([ server ]) | 64 | await setAccessTokensToServers([ server ]) |
48 | 65 | ||
49 | const videoQuota = 42000000 | 66 | const videoQuota = 42000000 |
50 | await createUser(server.url, server.accessToken, user.username, user.password, videoQuota) | 67 | await createUser({ |
68 | url: server.url, | ||
69 | accessToken: server.accessToken, | ||
70 | username: user.username, | ||
71 | password: user.password, | ||
72 | videoQuota: videoQuota | ||
73 | }) | ||
51 | userAccessToken = await userLogin(server, user) | 74 | userAccessToken = await userLogin(server, user) |
52 | 75 | ||
53 | { | 76 | { |
@@ -99,7 +122,8 @@ describe('Test users API validators', function () { | |||
99 | password: 'my super password', | 122 | password: 'my super password', |
100 | videoQuota: -1, | 123 | videoQuota: -1, |
101 | videoQuotaDaily: -1, | 124 | videoQuotaDaily: -1, |
102 | role: UserRole.USER | 125 | role: UserRole.USER, |
126 | adminFlags: UserAdminFlag.BY_PASS_VIDEO_AUTO_BLACKLIST | ||
103 | } | 127 | } |
104 | 128 | ||
105 | it('Should fail with a too small username', async function () { | 129 | it('Should fail with a too small username', async function () { |
@@ -150,6 +174,12 @@ describe('Test users API validators', function () { | |||
150 | await makePostBodyRequest({ url: server.url, path, token: server.accessToken, fields }) | 174 | await makePostBodyRequest({ url: server.url, path, token: server.accessToken, fields }) |
151 | }) | 175 | }) |
152 | 176 | ||
177 | it('Should fail with invalid admin flags', async function () { | ||
178 | const fields = immutableAssign(baseCorrectParams, { adminFlags: 'toto' }) | ||
179 | |||
180 | await makePostBodyRequest({ url: server.url, path, token: server.accessToken, fields }) | ||
181 | }) | ||
182 | |||
153 | it('Should fail with an non authenticated user', async function () { | 183 | it('Should fail with an non authenticated user', async function () { |
154 | await makePostBodyRequest({ | 184 | await makePostBodyRequest({ |
155 | url: server.url, | 185 | url: server.url, |
@@ -464,6 +494,24 @@ describe('Test users API validators', function () { | |||
464 | await makePutBodyRequest({ url: server.url, path: path + userId, token: server.accessToken, fields }) | 494 | await makePutBodyRequest({ url: server.url, path: path + userId, token: server.accessToken, fields }) |
465 | }) | 495 | }) |
466 | 496 | ||
497 | it('Should fail with a too small password', async function () { | ||
498 | const fields = { | ||
499 | currentPassword: 'my super password', | ||
500 | password: 'bla' | ||
501 | } | ||
502 | |||
503 | await makePutBodyRequest({ url: server.url, path: path + userId, token: server.accessToken, fields }) | ||
504 | }) | ||
505 | |||
506 | it('Should fail with a too long password', async function () { | ||
507 | const fields = { | ||
508 | currentPassword: 'my super password', | ||
509 | password: 'super'.repeat(61) | ||
510 | } | ||
511 | |||
512 | await makePutBodyRequest({ url: server.url, path: path + userId, token: server.accessToken, fields }) | ||
513 | }) | ||
514 | |||
467 | it('Should fail with an non authenticated user', async function () { | 515 | it('Should fail with an non authenticated user', async function () { |
468 | const fields = { | 516 | const fields = { |
469 | videoQuota: 42 | 517 | videoQuota: 42 |
@@ -480,6 +528,12 @@ describe('Test users API validators', function () { | |||
480 | await makePutBodyRequest({ url: server.url, path: path + rootId, token: server.accessToken, fields }) | 528 | await makePutBodyRequest({ url: server.url, path: path + rootId, token: server.accessToken, fields }) |
481 | }) | 529 | }) |
482 | 530 | ||
531 | it('Should fail with invalid admin flags', async function () { | ||
532 | const fields = { adminFlags: 'toto' } | ||
533 | |||
534 | await makePostBodyRequest({ url: server.url, path, token: server.accessToken, fields }) | ||
535 | }) | ||
536 | |||
483 | it('Should succeed with the correct params', async function () { | 537 | it('Should succeed with the correct params', async function () { |
484 | const fields = { | 538 | const fields = { |
485 | email: 'email@example.com', | 539 | email: 'email@example.com', |
@@ -520,6 +574,38 @@ describe('Test users API validators', function () { | |||
520 | }) | 574 | }) |
521 | }) | 575 | }) |
522 | 576 | ||
577 | describe('When retrieving my global ratings', function () { | ||
578 | const path = '/api/v1/accounts/user1/ratings' | ||
579 | |||
580 | it('Should fail with a bad start pagination', async function () { | ||
581 | await checkBadStartPagination(server.url, path, userAccessToken) | ||
582 | }) | ||
583 | |||
584 | it('Should fail with a bad count pagination', async function () { | ||
585 | await checkBadCountPagination(server.url, path, userAccessToken) | ||
586 | }) | ||
587 | |||
588 | it('Should fail with an incorrect sort', async function () { | ||
589 | await checkBadSortPagination(server.url, path, userAccessToken) | ||
590 | }) | ||
591 | |||
592 | it('Should fail with a unauthenticated user', async function () { | ||
593 | await makeGetRequest({ url: server.url, path, statusCodeExpected: 401 }) | ||
594 | }) | ||
595 | |||
596 | it('Should fail with a another user', async function () { | ||
597 | await makeGetRequest({ url: server.url, path, token: server.accessToken, statusCodeExpected: 403 }) | ||
598 | }) | ||
599 | |||
600 | it('Should fail with a bad type', async function () { | ||
601 | await makeGetRequest({ url: server.url, path, token: userAccessToken, query: { rating: 'toto ' }, statusCodeExpected: 400 }) | ||
602 | }) | ||
603 | |||
604 | it('Should succeed with the correct params', async function () { | ||
605 | await makeGetRequest({ url: server.url, path, token: userAccessToken, statusCodeExpected: 200 }) | ||
606 | }) | ||
607 | }) | ||
608 | |||
523 | describe('When blocking/unblocking/removing user', function () { | 609 | describe('When blocking/unblocking/removing user', function () { |
524 | it('Should fail with an incorrect id', async function () { | 610 | it('Should fail with an incorrect id', async function () { |
525 | await removeUser(server.url, 'blabla', server.accessToken, 400) | 611 | await removeUser(server.url, 'blabla', server.accessToken, 400) |
@@ -627,7 +713,7 @@ describe('Test users API validators', function () { | |||
627 | }) | 713 | }) |
628 | 714 | ||
629 | it('Should fail if we register a user with the same email', async function () { | 715 | it('Should fail if we register a user with the same email', async function () { |
630 | const fields = immutableAssign(baseCorrectParams, { email: 'admin1@example.com' }) | 716 | const fields = immutableAssign(baseCorrectParams, { email: 'admin' + server.internalServerNumber + '@example.com' }) |
631 | 717 | ||
632 | await makePostBodyRequest({ | 718 | await makePostBodyRequest({ |
633 | url: server.url, | 719 | url: server.url, |
@@ -812,11 +898,6 @@ describe('Test users API validators', function () { | |||
812 | }) | 898 | }) |
813 | 899 | ||
814 | after(async function () { | 900 | after(async function () { |
815 | killallServers([ server, serverWithRegistrationDisabled ]) | 901 | await cleanupTests([ server, serverWithRegistrationDisabled ]) |
816 | |||
817 | // Keep the logs if the test failed | ||
818 | if (this['ok']) { | ||
819 | await flushTests() | ||
820 | } | ||
821 | }) | 902 | }) |
822 | }) | 903 | }) |
diff --git a/server/tests/api/check-params/video-abuses.ts b/server/tests/api/check-params/video-abuses.ts index 3b8f5f14d..bf29f8d4d 100644 --- a/server/tests/api/check-params/video-abuses.ts +++ b/server/tests/api/check-params/video-abuses.ts | |||
@@ -3,24 +3,23 @@ | |||
3 | import 'mocha' | 3 | import 'mocha' |
4 | 4 | ||
5 | import { | 5 | import { |
6 | cleanupTests, | ||
6 | createUser, | 7 | createUser, |
7 | deleteVideoAbuse, | 8 | deleteVideoAbuse, |
8 | flushTests, | 9 | flushAndRunServer, |
9 | killallServers, | ||
10 | makeGetRequest, | 10 | makeGetRequest, |
11 | makePostBodyRequest, | 11 | makePostBodyRequest, |
12 | runServer, | ||
13 | ServerInfo, | 12 | ServerInfo, |
14 | setAccessTokensToServers, | 13 | setAccessTokensToServers, |
15 | updateVideoAbuse, | 14 | updateVideoAbuse, |
16 | uploadVideo, | 15 | uploadVideo, |
17 | userLogin | 16 | userLogin |
18 | } from '../../../../shared/utils' | 17 | } from '../../../../shared/extra-utils' |
19 | import { | 18 | import { |
20 | checkBadCountPagination, | 19 | checkBadCountPagination, |
21 | checkBadSortPagination, | 20 | checkBadSortPagination, |
22 | checkBadStartPagination | 21 | checkBadStartPagination |
23 | } from '../../../../shared/utils/requests/check-api-params' | 22 | } from '../../../../shared/extra-utils/requests/check-api-params' |
24 | import { VideoAbuseState } from '../../../../shared/models/videos' | 23 | import { VideoAbuseState } from '../../../../shared/models/videos' |
25 | 24 | ||
26 | describe('Test video abuses API validators', function () { | 25 | describe('Test video abuses API validators', function () { |
@@ -33,15 +32,13 @@ describe('Test video abuses API validators', function () { | |||
33 | before(async function () { | 32 | before(async function () { |
34 | this.timeout(30000) | 33 | this.timeout(30000) |
35 | 34 | ||
36 | await flushTests() | 35 | server = await flushAndRunServer(1) |
37 | |||
38 | server = await runServer(1) | ||
39 | 36 | ||
40 | await setAccessTokensToServers([ server ]) | 37 | await setAccessTokensToServers([ server ]) |
41 | 38 | ||
42 | const username = 'user1' | 39 | const username = 'user1' |
43 | const password = 'my super password' | 40 | const password = 'my super password' |
44 | await createUser(server.url, server.accessToken, username, password) | 41 | await createUser({ url: server.url, accessToken: server.accessToken, username: username, password: password }) |
45 | userAccessToken = await userLogin(server, { username, password }) | 42 | userAccessToken = await userLogin(server, { username, password }) |
46 | 43 | ||
47 | const res = await uploadVideo(server.url, server.accessToken, {}) | 44 | const res = await uploadVideo(server.url, server.accessToken, {}) |
@@ -191,11 +188,6 @@ describe('Test video abuses API validators', function () { | |||
191 | }) | 188 | }) |
192 | 189 | ||
193 | after(async function () { | 190 | after(async function () { |
194 | killallServers([ server ]) | 191 | await cleanupTests([ server ]) |
195 | |||
196 | // Keep the logs if the test failed | ||
197 | if (this['ok']) { | ||
198 | await flushTests() | ||
199 | } | ||
200 | }) | 192 | }) |
201 | }) | 193 | }) |
diff --git a/server/tests/api/check-params/video-blacklist.ts b/server/tests/api/check-params/video-blacklist.ts index 6b82643f4..6466888fb 100644 --- a/server/tests/api/check-params/video-blacklist.ts +++ b/server/tests/api/check-params/video-blacklist.ts | |||
@@ -3,6 +3,7 @@ | |||
3 | import 'mocha' | 3 | import 'mocha' |
4 | 4 | ||
5 | import { | 5 | import { |
6 | cleanupTests, | ||
6 | createUser, | 7 | createUser, |
7 | doubleFollow, | 8 | doubleFollow, |
8 | flushAndRunMultipleServers, | 9 | flushAndRunMultipleServers, |
@@ -18,13 +19,13 @@ import { | |||
18 | setAccessTokensToServers, | 19 | setAccessTokensToServers, |
19 | uploadVideo, | 20 | uploadVideo, |
20 | userLogin, waitJobs | 21 | userLogin, waitJobs |
21 | } from '../../../../shared/utils' | 22 | } from '../../../../shared/extra-utils' |
22 | import { | 23 | import { |
23 | checkBadCountPagination, | 24 | checkBadCountPagination, |
24 | checkBadSortPagination, | 25 | checkBadSortPagination, |
25 | checkBadStartPagination | 26 | checkBadStartPagination |
26 | } from '../../../../shared/utils/requests/check-api-params' | 27 | } from '../../../../shared/extra-utils/requests/check-api-params' |
27 | import { VideoDetails } from '../../../../shared/models/videos' | 28 | import { VideoDetails, VideoBlacklistType } from '../../../../shared/models/videos' |
28 | import { expect } from 'chai' | 29 | import { expect } from 'chai' |
29 | 30 | ||
30 | describe('Test video blacklist API validators', function () { | 31 | describe('Test video blacklist API validators', function () { |
@@ -39,7 +40,6 @@ describe('Test video blacklist API validators', function () { | |||
39 | before(async function () { | 40 | before(async function () { |
40 | this.timeout(120000) | 41 | this.timeout(120000) |
41 | 42 | ||
42 | await flushTests() | ||
43 | servers = await flushAndRunMultipleServers(2) | 43 | servers = await flushAndRunMultipleServers(2) |
44 | 44 | ||
45 | await setAccessTokensToServers(servers) | 45 | await setAccessTokensToServers(servers) |
@@ -48,14 +48,14 @@ describe('Test video blacklist API validators', function () { | |||
48 | { | 48 | { |
49 | const username = 'user1' | 49 | const username = 'user1' |
50 | const password = 'my super password' | 50 | const password = 'my super password' |
51 | await createUser(servers[0].url, servers[0].accessToken, username, password) | 51 | await createUser({ url: servers[ 0 ].url, accessToken: servers[ 0 ].accessToken, username: username, password: password }) |
52 | userAccessToken1 = await userLogin(servers[0], { username, password }) | 52 | userAccessToken1 = await userLogin(servers[0], { username, password }) |
53 | } | 53 | } |
54 | 54 | ||
55 | { | 55 | { |
56 | const username = 'user2' | 56 | const username = 'user2' |
57 | const password = 'my super password' | 57 | const password = 'my super password' |
58 | await createUser(servers[0].url, servers[0].accessToken, username, password) | 58 | await createUser({ url: servers[ 0 ].url, accessToken: servers[ 0 ].accessToken, username: username, password: password }) |
59 | userAccessToken2 = await userLogin(servers[0], { username, password }) | 59 | userAccessToken2 = await userLogin(servers[0], { username, password }) |
60 | } | 60 | } |
61 | 61 | ||
@@ -220,11 +220,11 @@ describe('Test video blacklist API validators', function () { | |||
220 | const basePath = '/api/v1/videos/blacklist/' | 220 | const basePath = '/api/v1/videos/blacklist/' |
221 | 221 | ||
222 | it('Should fail with a non authenticated user', async function () { | 222 | it('Should fail with a non authenticated user', async function () { |
223 | await getBlacklistedVideosList(servers[0].url, 'fake token', 401) | 223 | await getBlacklistedVideosList({ url: servers[0].url, token: 'fake token', specialStatus: 401 }) |
224 | }) | 224 | }) |
225 | 225 | ||
226 | it('Should fail with a non admin user', async function () { | 226 | it('Should fail with a non admin user', async function () { |
227 | await getBlacklistedVideosList(servers[0].url, userAccessToken2, 403) | 227 | await getBlacklistedVideosList({ url: servers[0].url, token: userAccessToken2, specialStatus: 403 }) |
228 | }) | 228 | }) |
229 | 229 | ||
230 | it('Should fail with a bad start pagination', async function () { | 230 | it('Should fail with a bad start pagination', async function () { |
@@ -238,14 +238,17 @@ describe('Test video blacklist API validators', function () { | |||
238 | it('Should fail with an incorrect sort', async function () { | 238 | it('Should fail with an incorrect sort', async function () { |
239 | await checkBadSortPagination(servers[0].url, basePath, servers[0].accessToken) | 239 | await checkBadSortPagination(servers[0].url, basePath, servers[0].accessToken) |
240 | }) | 240 | }) |
241 | |||
242 | it('Should fail with an invalid type', async function () { | ||
243 | await getBlacklistedVideosList({ url: servers[0].url, token: servers[0].accessToken, type: 0, specialStatus: 400 }) | ||
244 | }) | ||
245 | |||
246 | it('Should succeed with the correct parameters', async function () { | ||
247 | await getBlacklistedVideosList({ url: servers[0].url, token: servers[0].accessToken, type: VideoBlacklistType.MANUAL }) | ||
248 | }) | ||
241 | }) | 249 | }) |
242 | 250 | ||
243 | after(async function () { | 251 | after(async function () { |
244 | killallServers(servers) | 252 | await cleanupTests(servers) |
245 | |||
246 | // Keep the logs if the test failed | ||
247 | if (this['ok']) { | ||
248 | await flushTests() | ||
249 | } | ||
250 | }) | 253 | }) |
251 | }) | 254 | }) |
diff --git a/server/tests/api/check-params/video-captions.ts b/server/tests/api/check-params/video-captions.ts index e4d36fd4f..4a373d43d 100644 --- a/server/tests/api/check-params/video-captions.ts +++ b/server/tests/api/check-params/video-captions.ts | |||
@@ -2,20 +2,19 @@ | |||
2 | 2 | ||
3 | import 'mocha' | 3 | import 'mocha' |
4 | import { | 4 | import { |
5 | cleanupTests, | ||
5 | createUser, | 6 | createUser, |
6 | flushTests, | 7 | flushAndRunServer, |
7 | killallServers, | ||
8 | makeDeleteRequest, | 8 | makeDeleteRequest, |
9 | makeGetRequest, | 9 | makeGetRequest, |
10 | makeUploadRequest, | 10 | makeUploadRequest, |
11 | runServer, | ||
12 | ServerInfo, | 11 | ServerInfo, |
13 | setAccessTokensToServers, | 12 | setAccessTokensToServers, |
14 | uploadVideo, | 13 | uploadVideo, |
15 | userLogin | 14 | userLogin |
16 | } from '../../../../shared/utils' | 15 | } from '../../../../shared/extra-utils' |
17 | import { join } from 'path' | 16 | import { join } from 'path' |
18 | import { createVideoCaption } from '../../../../shared/utils/videos/video-captions' | 17 | import { createVideoCaption } from '../../../../shared/extra-utils/videos/video-captions' |
19 | 18 | ||
20 | describe('Test video captions API validator', function () { | 19 | describe('Test video captions API validator', function () { |
21 | const path = '/api/v1/videos/' | 20 | const path = '/api/v1/videos/' |
@@ -29,9 +28,7 @@ describe('Test video captions API validator', function () { | |||
29 | before(async function () { | 28 | before(async function () { |
30 | this.timeout(30000) | 29 | this.timeout(30000) |
31 | 30 | ||
32 | await flushTests() | 31 | server = await flushAndRunServer(1) |
33 | |||
34 | server = await runServer(1) | ||
35 | 32 | ||
36 | await setAccessTokensToServers([ server ]) | 33 | await setAccessTokensToServers([ server ]) |
37 | 34 | ||
@@ -45,7 +42,7 @@ describe('Test video captions API validator', function () { | |||
45 | username: 'user1', | 42 | username: 'user1', |
46 | password: 'my super password' | 43 | password: 'my super password' |
47 | } | 44 | } |
48 | await createUser(server.url, server.accessToken, user.username, user.password) | 45 | await createUser({ url: server.url, accessToken: server.accessToken, username: user.username, password: user.password }) |
49 | userAccessToken = await userLogin(server, user) | 46 | userAccessToken = await userLogin(server, user) |
50 | } | 47 | } |
51 | }) | 48 | }) |
@@ -272,11 +269,6 @@ describe('Test video captions API validator', function () { | |||
272 | }) | 269 | }) |
273 | 270 | ||
274 | after(async function () { | 271 | after(async function () { |
275 | killallServers([ server ]) | 272 | await cleanupTests([ server ]) |
276 | |||
277 | // Keep the logs if the test failed | ||
278 | if (this['ok']) { | ||
279 | await flushTests() | ||
280 | } | ||
281 | }) | 273 | }) |
282 | }) | 274 | }) |
diff --git a/server/tests/api/check-params/video-channels.ts b/server/tests/api/check-params/video-channels.ts index 14e4deaf7..65bc20613 100644 --- a/server/tests/api/check-params/video-channels.ts +++ b/server/tests/api/check-params/video-channels.ts | |||
@@ -4,29 +4,25 @@ import * as chai from 'chai' | |||
4 | import { omit } from 'lodash' | 4 | import { omit } from 'lodash' |
5 | import 'mocha' | 5 | import 'mocha' |
6 | import { | 6 | import { |
7 | cleanupTests, | ||
7 | createUser, | 8 | createUser, |
8 | deleteVideoChannel, | 9 | deleteVideoChannel, |
9 | flushTests, | 10 | flushAndRunServer, |
10 | getAccountVideoChannelsList, | 11 | getAccountVideoChannelsList, |
11 | getMyUserInformation, | ||
12 | getVideoChannelsList, | ||
13 | immutableAssign, | 12 | immutableAssign, |
14 | killallServers, | ||
15 | makeGetRequest, | 13 | makeGetRequest, |
16 | makePostBodyRequest, | 14 | makePostBodyRequest, |
17 | makePutBodyRequest, | 15 | makePutBodyRequest, |
18 | makeUploadRequest, | 16 | makeUploadRequest, |
19 | runServer, | ||
20 | ServerInfo, | 17 | ServerInfo, |
21 | setAccessTokensToServers, | 18 | setAccessTokensToServers, |
22 | userLogin | 19 | userLogin |
23 | } from '../../../../shared/utils' | 20 | } from '../../../../shared/extra-utils' |
24 | import { | 21 | import { |
25 | checkBadCountPagination, | 22 | checkBadCountPagination, |
26 | checkBadSortPagination, | 23 | checkBadSortPagination, |
27 | checkBadStartPagination | 24 | checkBadStartPagination |
28 | } from '../../../../shared/utils/requests/check-api-params' | 25 | } from '../../../../shared/extra-utils/requests/check-api-params' |
29 | import { User } from '../../../../shared/models/users' | ||
30 | import { join } from 'path' | 26 | import { join } from 'path' |
31 | 27 | ||
32 | const expect = chai.expect | 28 | const expect = chai.expect |
@@ -41,9 +37,7 @@ describe('Test video channels API validator', function () { | |||
41 | before(async function () { | 37 | before(async function () { |
42 | this.timeout(30000) | 38 | this.timeout(30000) |
43 | 39 | ||
44 | await flushTests() | 40 | server = await flushAndRunServer(1) |
45 | |||
46 | server = await runServer(1) | ||
47 | 41 | ||
48 | await setAccessTokensToServers([ server ]) | 42 | await setAccessTokensToServers([ server ]) |
49 | 43 | ||
@@ -53,7 +47,7 @@ describe('Test video channels API validator', function () { | |||
53 | } | 47 | } |
54 | 48 | ||
55 | { | 49 | { |
56 | await createUser(server.url, server.accessToken, user.username, user.password) | 50 | await createUser({ url: server.url, accessToken: server.accessToken, username: user.username, password: user.password }) |
57 | accessTokenUser = await userLogin(server, user) | 51 | accessTokenUser = await userLogin(server, user) |
58 | } | 52 | } |
59 | }) | 53 | }) |
@@ -313,11 +307,6 @@ describe('Test video channels API validator', function () { | |||
313 | }) | 307 | }) |
314 | 308 | ||
315 | after(async function () { | 309 | after(async function () { |
316 | killallServers([ server ]) | 310 | await cleanupTests([ server ]) |
317 | |||
318 | // Keep the logs if the test failed | ||
319 | if (this['ok']) { | ||
320 | await flushTests() | ||
321 | } | ||
322 | }) | 311 | }) |
323 | }) | 312 | }) |
diff --git a/server/tests/api/check-params/video-comments.ts b/server/tests/api/check-params/video-comments.ts index 5981780ed..5cf90bacc 100644 --- a/server/tests/api/check-params/video-comments.ts +++ b/server/tests/api/check-params/video-comments.ts | |||
@@ -3,16 +3,23 @@ | |||
3 | import * as chai from 'chai' | 3 | import * as chai from 'chai' |
4 | import 'mocha' | 4 | import 'mocha' |
5 | import { | 5 | import { |
6 | cleanupTests, | ||
6 | createUser, | 7 | createUser, |
7 | flushTests, killallServers, makeDeleteRequest, makeGetRequest, makePostBodyRequest, runServer, ServerInfo, setAccessTokensToServers, | 8 | flushAndRunServer, |
8 | uploadVideo, userLogin | 9 | makeDeleteRequest, |
9 | } from '../../../../shared/utils' | 10 | makeGetRequest, |
11 | makePostBodyRequest, | ||
12 | ServerInfo, | ||
13 | setAccessTokensToServers, | ||
14 | uploadVideo, | ||
15 | userLogin | ||
16 | } from '../../../../shared/extra-utils' | ||
10 | import { | 17 | import { |
11 | checkBadCountPagination, | 18 | checkBadCountPagination, |
12 | checkBadSortPagination, | 19 | checkBadSortPagination, |
13 | checkBadStartPagination | 20 | checkBadStartPagination |
14 | } from '../../../../shared/utils/requests/check-api-params' | 21 | } from '../../../../shared/extra-utils/requests/check-api-params' |
15 | import { addVideoCommentThread } from '../../../../shared/utils/videos/video-comments' | 22 | import { addVideoCommentThread } from '../../../../shared/extra-utils/videos/video-comments' |
16 | 23 | ||
17 | const expect = chai.expect | 24 | const expect = chai.expect |
18 | 25 | ||
@@ -29,9 +36,7 @@ describe('Test video comments API validator', function () { | |||
29 | before(async function () { | 36 | before(async function () { |
30 | this.timeout(30000) | 37 | this.timeout(30000) |
31 | 38 | ||
32 | await flushTests() | 39 | server = await flushAndRunServer(1) |
33 | |||
34 | server = await runServer(1) | ||
35 | 40 | ||
36 | await setAccessTokensToServers([ server ]) | 41 | await setAccessTokensToServers([ server ]) |
37 | 42 | ||
@@ -52,7 +57,7 @@ describe('Test video comments API validator', function () { | |||
52 | username: 'user1', | 57 | username: 'user1', |
53 | password: 'my super password' | 58 | password: 'my super password' |
54 | } | 59 | } |
55 | await createUser(server.url, server.accessToken, user.username, user.password) | 60 | await createUser({ url: server.url, accessToken: server.accessToken, username: user.username, password: user.password }) |
56 | userAccessToken = await userLogin(server, user) | 61 | userAccessToken = await userLogin(server, user) |
57 | } | 62 | } |
58 | }) | 63 | }) |
@@ -254,11 +259,6 @@ describe('Test video comments API validator', function () { | |||
254 | }) | 259 | }) |
255 | 260 | ||
256 | after(async function () { | 261 | after(async function () { |
257 | killallServers([ server ]) | 262 | await cleanupTests([ server ]) |
258 | |||
259 | // Keep the logs if the test failed | ||
260 | if (this['ok']) { | ||
261 | await flushTests() | ||
262 | } | ||
263 | }) | 263 | }) |
264 | }) | 264 | }) |
diff --git a/server/tests/api/check-params/video-imports.ts b/server/tests/api/check-params/video-imports.ts index 7bf187007..8ff115e7b 100644 --- a/server/tests/api/check-params/video-imports.ts +++ b/server/tests/api/check-params/video-imports.ts | |||
@@ -5,26 +5,25 @@ import 'mocha' | |||
5 | import { join } from 'path' | 5 | import { join } from 'path' |
6 | import { VideoPrivacy } from '../../../../shared/models/videos/video-privacy.enum' | 6 | import { VideoPrivacy } from '../../../../shared/models/videos/video-privacy.enum' |
7 | import { | 7 | import { |
8 | cleanupTests, | ||
8 | createUser, | 9 | createUser, |
9 | flushTests, | 10 | flushAndRunServer, |
10 | getMyUserInformation, | 11 | getMyUserInformation, |
11 | immutableAssign, | 12 | immutableAssign, |
12 | killallServers, | ||
13 | makeGetRequest, | 13 | makeGetRequest, |
14 | makePostBodyRequest, | 14 | makePostBodyRequest, |
15 | makeUploadRequest, | 15 | makeUploadRequest, |
16 | runServer, | ||
17 | ServerInfo, | 16 | ServerInfo, |
18 | setAccessTokensToServers, | 17 | setAccessTokensToServers, |
19 | updateCustomSubConfig, | 18 | updateCustomSubConfig, |
20 | userLogin | 19 | userLogin |
21 | } from '../../../../shared/utils' | 20 | } from '../../../../shared/extra-utils' |
22 | import { | 21 | import { |
23 | checkBadCountPagination, | 22 | checkBadCountPagination, |
24 | checkBadSortPagination, | 23 | checkBadSortPagination, |
25 | checkBadStartPagination | 24 | checkBadStartPagination |
26 | } from '../../../../shared/utils/requests/check-api-params' | 25 | } from '../../../../shared/extra-utils/requests/check-api-params' |
27 | import { getMagnetURI, getYoutubeVideoUrl } from '../../../../shared/utils/videos/video-imports' | 26 | import { getMagnetURI, getYoutubeVideoUrl } from '../../../../shared/extra-utils/videos/video-imports' |
28 | 27 | ||
29 | describe('Test video imports API validator', function () { | 28 | describe('Test video imports API validator', function () { |
30 | const path = '/api/v1/videos/imports' | 29 | const path = '/api/v1/videos/imports' |
@@ -38,15 +37,13 @@ describe('Test video imports API validator', function () { | |||
38 | before(async function () { | 37 | before(async function () { |
39 | this.timeout(30000) | 38 | this.timeout(30000) |
40 | 39 | ||
41 | await flushTests() | 40 | server = await flushAndRunServer(1) |
42 | |||
43 | server = await runServer(1) | ||
44 | 41 | ||
45 | await setAccessTokensToServers([ server ]) | 42 | await setAccessTokensToServers([ server ]) |
46 | 43 | ||
47 | const username = 'user1' | 44 | const username = 'user1' |
48 | const password = 'my super password' | 45 | const password = 'my super password' |
49 | await createUser(server.url, server.accessToken, username, password) | 46 | await createUser({ url: server.url, accessToken: server.accessToken, username: username, password: password }) |
50 | userAccessToken = await userLogin(server, { username, password }) | 47 | userAccessToken = await userLogin(server, { username, password }) |
51 | 48 | ||
52 | { | 49 | { |
@@ -88,6 +85,7 @@ describe('Test video imports API validator', function () { | |||
88 | language: 'pt', | 85 | language: 'pt', |
89 | nsfw: false, | 86 | nsfw: false, |
90 | commentsEnabled: true, | 87 | commentsEnabled: true, |
88 | downloadEnabled: true, | ||
91 | waitTranscoding: true, | 89 | waitTranscoding: true, |
92 | description: 'my super description', | 90 | description: 'my super description', |
93 | support: 'my super support text', | 91 | support: 'my super support text', |
@@ -166,7 +164,7 @@ describe('Test video imports API validator', function () { | |||
166 | username: 'fake', | 164 | username: 'fake', |
167 | password: 'fake_password' | 165 | password: 'fake_password' |
168 | } | 166 | } |
169 | await createUser(server.url, server.accessToken, user.username, user.password) | 167 | await createUser({ url: server.url, accessToken: server.accessToken, username: user.username, password: user.password }) |
170 | 168 | ||
171 | const accessTokenUser = await userLogin(server, user) | 169 | const accessTokenUser = await userLogin(server, user) |
172 | const res = await getMyUserInformation(server.url, accessTokenUser) | 170 | const res = await getMyUserInformation(server.url, accessTokenUser) |
@@ -313,11 +311,6 @@ describe('Test video imports API validator', function () { | |||
313 | }) | 311 | }) |
314 | 312 | ||
315 | after(async function () { | 313 | after(async function () { |
316 | killallServers([ server ]) | 314 | await cleanupTests([ server ]) |
317 | |||
318 | // Keep the logs if the test failed | ||
319 | if (this['ok']) { | ||
320 | await flushTests() | ||
321 | } | ||
322 | }) | 315 | }) |
323 | }) | 316 | }) |
diff --git a/server/tests/api/check-params/video-playlists.ts b/server/tests/api/check-params/video-playlists.ts new file mode 100644 index 000000000..b7b94c035 --- /dev/null +++ b/server/tests/api/check-params/video-playlists.ts | |||
@@ -0,0 +1,674 @@ | |||
1 | /* tslint:disable:no-unused-expression */ | ||
2 | |||
3 | import 'mocha' | ||
4 | import { | ||
5 | addVideoInPlaylist, | ||
6 | cleanupTests, | ||
7 | createVideoPlaylist, | ||
8 | deleteVideoPlaylist, | ||
9 | flushAndRunServer, | ||
10 | generateUserAccessToken, | ||
11 | getAccountPlaylistsListWithToken, | ||
12 | getVideoPlaylist, | ||
13 | immutableAssign, | ||
14 | makeGetRequest, | ||
15 | removeVideoFromPlaylist, | ||
16 | reorderVideosPlaylist, | ||
17 | ServerInfo, | ||
18 | setAccessTokensToServers, | ||
19 | setDefaultVideoChannel, | ||
20 | updateVideoPlaylist, | ||
21 | updateVideoPlaylistElement, | ||
22 | uploadVideoAndGetId | ||
23 | } from '../../../../shared/extra-utils' | ||
24 | import { | ||
25 | checkBadCountPagination, | ||
26 | checkBadSortPagination, | ||
27 | checkBadStartPagination | ||
28 | } from '../../../../shared/extra-utils/requests/check-api-params' | ||
29 | import { VideoPlaylistPrivacy } from '../../../../shared/models/videos/playlist/video-playlist-privacy.model' | ||
30 | import { VideoPlaylistType } from '../../../../shared/models/videos/playlist/video-playlist-type.model' | ||
31 | |||
32 | describe('Test video playlists API validator', function () { | ||
33 | let server: ServerInfo | ||
34 | let userAccessToken: string | ||
35 | let playlistUUID: string | ||
36 | let privatePlaylistUUID: string | ||
37 | let watchLaterPlaylistId: number | ||
38 | let videoId: number | ||
39 | let videoId2: number | ||
40 | |||
41 | // --------------------------------------------------------------- | ||
42 | |||
43 | before(async function () { | ||
44 | this.timeout(30000) | ||
45 | |||
46 | server = await flushAndRunServer(1) | ||
47 | |||
48 | await setAccessTokensToServers([ server ]) | ||
49 | await setDefaultVideoChannel([ server ]) | ||
50 | |||
51 | userAccessToken = await generateUserAccessToken(server, 'user1') | ||
52 | videoId = (await uploadVideoAndGetId({ server, videoName: 'video 1' })).id | ||
53 | videoId2 = (await uploadVideoAndGetId({ server, videoName: 'video 2' })).id | ||
54 | |||
55 | { | ||
56 | const res = await getAccountPlaylistsListWithToken(server.url, server.accessToken, 'root',0, 5, VideoPlaylistType.WATCH_LATER) | ||
57 | watchLaterPlaylistId = res.body.data[0].id | ||
58 | } | ||
59 | |||
60 | { | ||
61 | const res = await createVideoPlaylist({ | ||
62 | url: server.url, | ||
63 | token: server.accessToken, | ||
64 | playlistAttrs: { | ||
65 | displayName: 'super playlist', | ||
66 | privacy: VideoPlaylistPrivacy.PUBLIC, | ||
67 | videoChannelId: server.videoChannel.id | ||
68 | } | ||
69 | }) | ||
70 | playlistUUID = res.body.videoPlaylist.uuid | ||
71 | } | ||
72 | |||
73 | { | ||
74 | const res = await createVideoPlaylist({ | ||
75 | url: server.url, | ||
76 | token: server.accessToken, | ||
77 | playlistAttrs: { | ||
78 | displayName: 'private', | ||
79 | privacy: VideoPlaylistPrivacy.PRIVATE | ||
80 | } | ||
81 | }) | ||
82 | privatePlaylistUUID = res.body.videoPlaylist.uuid | ||
83 | } | ||
84 | }) | ||
85 | |||
86 | describe('When listing playlists', function () { | ||
87 | const globalPath = '/api/v1/video-playlists' | ||
88 | const accountPath = '/api/v1/accounts/root/video-playlists' | ||
89 | const videoChannelPath = '/api/v1/video-channels/root_channel/video-playlists' | ||
90 | |||
91 | it('Should fail with a bad start pagination', async function () { | ||
92 | await checkBadStartPagination(server.url, globalPath, server.accessToken) | ||
93 | await checkBadStartPagination(server.url, accountPath, server.accessToken) | ||
94 | await checkBadStartPagination(server.url, videoChannelPath, server.accessToken) | ||
95 | }) | ||
96 | |||
97 | it('Should fail with a bad count pagination', async function () { | ||
98 | await checkBadCountPagination(server.url, globalPath, server.accessToken) | ||
99 | await checkBadCountPagination(server.url, accountPath, server.accessToken) | ||
100 | await checkBadCountPagination(server.url, videoChannelPath, server.accessToken) | ||
101 | }) | ||
102 | |||
103 | it('Should fail with an incorrect sort', async function () { | ||
104 | await checkBadSortPagination(server.url, globalPath, server.accessToken) | ||
105 | await checkBadSortPagination(server.url, accountPath, server.accessToken) | ||
106 | await checkBadSortPagination(server.url, videoChannelPath, server.accessToken) | ||
107 | }) | ||
108 | |||
109 | it('Should fail with a bad playlist type', async function () { | ||
110 | await makeGetRequest({ url: server.url, path: globalPath, query: { playlistType: 3 } }) | ||
111 | await makeGetRequest({ url: server.url, path: accountPath, query: { playlistType: 3 } }) | ||
112 | await makeGetRequest({ url: server.url, path: videoChannelPath, query: { playlistType: 3 } }) | ||
113 | }) | ||
114 | |||
115 | it('Should fail with a bad account parameter', async function () { | ||
116 | const accountPath = '/api/v1/accounts/root2/video-playlists' | ||
117 | |||
118 | await makeGetRequest({ url: server.url, path: accountPath, statusCodeExpected: 404, token: server.accessToken }) | ||
119 | }) | ||
120 | |||
121 | it('Should fail with a bad video channel parameter', async function () { | ||
122 | const accountPath = '/api/v1/video-channels/bad_channel/video-playlists' | ||
123 | |||
124 | await makeGetRequest({ url: server.url, path: accountPath, statusCodeExpected: 404, token: server.accessToken }) | ||
125 | }) | ||
126 | |||
127 | it('Should success with the correct parameters', async function () { | ||
128 | await makeGetRequest({ url: server.url, path: globalPath, statusCodeExpected: 200, token: server.accessToken }) | ||
129 | await makeGetRequest({ url: server.url, path: accountPath, statusCodeExpected: 200, token: server.accessToken }) | ||
130 | await makeGetRequest({ url: server.url, path: videoChannelPath, statusCodeExpected: 200, token: server.accessToken }) | ||
131 | }) | ||
132 | }) | ||
133 | |||
134 | describe('When listing videos of a playlist', function () { | ||
135 | const path = '/api/v1/video-playlists' | ||
136 | |||
137 | it('Should fail with a bad start pagination', async function () { | ||
138 | await checkBadStartPagination(server.url, path, server.accessToken) | ||
139 | }) | ||
140 | |||
141 | it('Should fail with a bad count pagination', async function () { | ||
142 | await checkBadCountPagination(server.url, path, server.accessToken) | ||
143 | }) | ||
144 | |||
145 | it('Should fail with a bad filter', async function () { | ||
146 | await checkBadSortPagination(server.url, path, server.accessToken) | ||
147 | }) | ||
148 | }) | ||
149 | |||
150 | describe('When getting a video playlist', function () { | ||
151 | it('Should fail with a bad id or uuid', async function () { | ||
152 | await getVideoPlaylist(server.url, 'toto', 400) | ||
153 | }) | ||
154 | |||
155 | it('Should fail with an unknown playlist', async function () { | ||
156 | await getVideoPlaylist(server.url, 42, 404) | ||
157 | }) | ||
158 | |||
159 | it('Should fail to get an unlisted playlist with the number id', async function () { | ||
160 | const res = await createVideoPlaylist({ | ||
161 | url: server.url, | ||
162 | token: server.accessToken, | ||
163 | playlistAttrs: { | ||
164 | displayName: 'super playlist', | ||
165 | privacy: VideoPlaylistPrivacy.UNLISTED | ||
166 | } | ||
167 | }) | ||
168 | const playlist = res.body.videoPlaylist | ||
169 | |||
170 | await getVideoPlaylist(server.url, playlist.id, 404) | ||
171 | await getVideoPlaylist(server.url, playlist.uuid, 200) | ||
172 | }) | ||
173 | |||
174 | it('Should succeed with the correct params', async function () { | ||
175 | await getVideoPlaylist(server.url, playlistUUID, 200) | ||
176 | }) | ||
177 | }) | ||
178 | |||
179 | describe('When creating/updating a video playlist', function () { | ||
180 | const getBase = (playlistAttrs: any = {}, wrapper: any = {}) => { | ||
181 | return Object.assign({ | ||
182 | expectedStatus: 400, | ||
183 | url: server.url, | ||
184 | token: server.accessToken, | ||
185 | playlistAttrs: Object.assign({ | ||
186 | displayName: 'display name', | ||
187 | privacy: VideoPlaylistPrivacy.UNLISTED, | ||
188 | thumbnailfile: 'thumbnail.jpg', | ||
189 | videoChannelId: server.videoChannel.id | ||
190 | }, playlistAttrs) | ||
191 | }, wrapper) | ||
192 | } | ||
193 | const getUpdate = (params: any, playlistId: number | string) => { | ||
194 | return immutableAssign(params, { playlistId: playlistId }) | ||
195 | } | ||
196 | |||
197 | it('Should fail with an unauthenticated user', async function () { | ||
198 | const params = getBase({}, { token: null, expectedStatus: 401 }) | ||
199 | |||
200 | await createVideoPlaylist(params) | ||
201 | await updateVideoPlaylist(getUpdate(params, playlistUUID)) | ||
202 | }) | ||
203 | |||
204 | it('Should fail without displayName', async function () { | ||
205 | const params = getBase({ displayName: undefined }) | ||
206 | |||
207 | await createVideoPlaylist(params) | ||
208 | await updateVideoPlaylist(getUpdate(params, playlistUUID)) | ||
209 | }) | ||
210 | |||
211 | it('Should fail with an incorrect display name', async function () { | ||
212 | const params = getBase({ displayName: 's'.repeat(300) }) | ||
213 | |||
214 | await createVideoPlaylist(params) | ||
215 | await updateVideoPlaylist(getUpdate(params, playlistUUID)) | ||
216 | }) | ||
217 | |||
218 | it('Should fail with an incorrect description', async function () { | ||
219 | const params = getBase({ description: 't' }) | ||
220 | |||
221 | await createVideoPlaylist(params) | ||
222 | await updateVideoPlaylist(getUpdate(params, playlistUUID)) | ||
223 | }) | ||
224 | |||
225 | it('Should fail with an incorrect privacy', async function () { | ||
226 | const params = getBase({ privacy: 45 }) | ||
227 | |||
228 | await createVideoPlaylist(params) | ||
229 | await updateVideoPlaylist(getUpdate(params, playlistUUID)) | ||
230 | }) | ||
231 | |||
232 | it('Should fail with an unknown video channel id', async function () { | ||
233 | const params = getBase({ videoChannelId: 42 }, { expectedStatus: 404 }) | ||
234 | |||
235 | await createVideoPlaylist(params) | ||
236 | await updateVideoPlaylist(getUpdate(params, playlistUUID)) | ||
237 | }) | ||
238 | |||
239 | it('Should fail with an incorrect thumbnail file', async function () { | ||
240 | const params = getBase({ thumbnailfile: 'avatar.png' }) | ||
241 | |||
242 | await createVideoPlaylist(params) | ||
243 | await updateVideoPlaylist(getUpdate(params, playlistUUID)) | ||
244 | }) | ||
245 | |||
246 | it('Should fail to set "public" a playlist not assigned to a channel', async function () { | ||
247 | const params = getBase({ privacy: VideoPlaylistPrivacy.PUBLIC, videoChannelId: undefined }) | ||
248 | const params2 = getBase({ privacy: VideoPlaylistPrivacy.PUBLIC, videoChannelId: 'null' }) | ||
249 | const params3 = getBase({ privacy: undefined, videoChannelId: 'null' }) | ||
250 | |||
251 | await createVideoPlaylist(params) | ||
252 | await createVideoPlaylist(params2) | ||
253 | await updateVideoPlaylist(getUpdate(params, privatePlaylistUUID)) | ||
254 | await updateVideoPlaylist(getUpdate(params2, playlistUUID)) | ||
255 | await updateVideoPlaylist(getUpdate(params3, playlistUUID)) | ||
256 | }) | ||
257 | |||
258 | it('Should fail with an unknown playlist to update', async function () { | ||
259 | await updateVideoPlaylist(getUpdate( | ||
260 | getBase({}, { expectedStatus: 404 }), | ||
261 | 42 | ||
262 | )) | ||
263 | }) | ||
264 | |||
265 | it('Should fail to update a playlist of another user', async function () { | ||
266 | await updateVideoPlaylist(getUpdate( | ||
267 | getBase({}, { token: userAccessToken, expectedStatus: 403 }), | ||
268 | playlistUUID | ||
269 | )) | ||
270 | }) | ||
271 | |||
272 | it('Should fail to update to private a public/unlisted playlist', async function () { | ||
273 | const params = getBase({ privacy: VideoPlaylistPrivacy.PUBLIC }, { expectedStatus: 200 }) | ||
274 | |||
275 | const res = await createVideoPlaylist(params) | ||
276 | const playlist = res.body.videoPlaylist | ||
277 | |||
278 | const paramsUpdate = getBase({ privacy: VideoPlaylistPrivacy.PRIVATE }, { expectedStatus: 400 }) | ||
279 | |||
280 | await updateVideoPlaylist(getUpdate(paramsUpdate, playlist.id)) | ||
281 | }) | ||
282 | |||
283 | it('Should fail to update the watch later playlist', async function () { | ||
284 | await updateVideoPlaylist(getUpdate( | ||
285 | getBase({}, { expectedStatus: 400 }), | ||
286 | watchLaterPlaylistId | ||
287 | )) | ||
288 | }) | ||
289 | |||
290 | it('Should succeed with the correct params', async function () { | ||
291 | { | ||
292 | const params = getBase({}, { expectedStatus: 200 }) | ||
293 | await createVideoPlaylist(params) | ||
294 | } | ||
295 | |||
296 | { | ||
297 | const params = getBase({}, { expectedStatus: 204 }) | ||
298 | await updateVideoPlaylist(getUpdate(params, playlistUUID)) | ||
299 | } | ||
300 | }) | ||
301 | }) | ||
302 | |||
303 | describe('When adding an element in a playlist', function () { | ||
304 | const getBase = (elementAttrs: any = {}, wrapper: any = {}) => { | ||
305 | return Object.assign({ | ||
306 | expectedStatus: 400, | ||
307 | url: server.url, | ||
308 | token: server.accessToken, | ||
309 | playlistId: playlistUUID, | ||
310 | elementAttrs: Object.assign({ | ||
311 | videoId: videoId, | ||
312 | startTimestamp: 2, | ||
313 | stopTimestamp: 3 | ||
314 | }, elementAttrs) | ||
315 | }, wrapper) | ||
316 | } | ||
317 | |||
318 | it('Should fail with an unauthenticated user', async function () { | ||
319 | const params = getBase({}, { token: null, expectedStatus: 401 }) | ||
320 | await addVideoInPlaylist(params) | ||
321 | }) | ||
322 | |||
323 | it('Should fail with the playlist of another user', async function () { | ||
324 | const params = getBase({}, { token: userAccessToken, expectedStatus: 403 }) | ||
325 | await addVideoInPlaylist(params) | ||
326 | }) | ||
327 | |||
328 | it('Should fail with an unknown or incorrect playlist id', async function () { | ||
329 | { | ||
330 | const params = getBase({}, { playlistId: 'toto' }) | ||
331 | await addVideoInPlaylist(params) | ||
332 | } | ||
333 | |||
334 | { | ||
335 | const params = getBase({}, { playlistId: 42, expectedStatus: 404 }) | ||
336 | await addVideoInPlaylist(params) | ||
337 | } | ||
338 | }) | ||
339 | |||
340 | it('Should fail with an unknown or incorrect video id', async function () { | ||
341 | const params = getBase({ videoId: 42 }, { expectedStatus: 404 }) | ||
342 | await addVideoInPlaylist(params) | ||
343 | }) | ||
344 | |||
345 | it('Should fail with a bad start/stop timestamp', async function () { | ||
346 | { | ||
347 | const params = getBase({ startTimestamp: -42 }) | ||
348 | await addVideoInPlaylist(params) | ||
349 | } | ||
350 | |||
351 | { | ||
352 | const params = getBase({ stopTimestamp: 'toto' as any }) | ||
353 | await addVideoInPlaylist(params) | ||
354 | } | ||
355 | }) | ||
356 | |||
357 | it('Succeed with the correct params', async function () { | ||
358 | const params = getBase({}, { expectedStatus: 200 }) | ||
359 | await addVideoInPlaylist(params) | ||
360 | }) | ||
361 | |||
362 | it('Should fail if the video was already added in the playlist', async function () { | ||
363 | const params = getBase({}, { expectedStatus: 409 }) | ||
364 | await addVideoInPlaylist(params) | ||
365 | }) | ||
366 | }) | ||
367 | |||
368 | describe('When updating an element in a playlist', function () { | ||
369 | const getBase = (elementAttrs: any = {}, wrapper: any = {}) => { | ||
370 | return Object.assign({ | ||
371 | url: server.url, | ||
372 | token: server.accessToken, | ||
373 | elementAttrs: Object.assign({ | ||
374 | startTimestamp: 1, | ||
375 | stopTimestamp: 2 | ||
376 | }, elementAttrs), | ||
377 | videoId: videoId, | ||
378 | playlistId: playlistUUID, | ||
379 | expectedStatus: 400 | ||
380 | }, wrapper) | ||
381 | } | ||
382 | |||
383 | it('Should fail with an unauthenticated user', async function () { | ||
384 | const params = getBase({}, { token: null, expectedStatus: 401 }) | ||
385 | await updateVideoPlaylistElement(params) | ||
386 | }) | ||
387 | |||
388 | it('Should fail with the playlist of another user', async function () { | ||
389 | const params = getBase({}, { token: userAccessToken, expectedStatus: 403 }) | ||
390 | await updateVideoPlaylistElement(params) | ||
391 | }) | ||
392 | |||
393 | it('Should fail with an unknown or incorrect playlist id', async function () { | ||
394 | { | ||
395 | const params = getBase({}, { playlistId: 'toto' }) | ||
396 | await updateVideoPlaylistElement(params) | ||
397 | } | ||
398 | |||
399 | { | ||
400 | const params = getBase({}, { playlistId: 42, expectedStatus: 404 }) | ||
401 | await updateVideoPlaylistElement(params) | ||
402 | } | ||
403 | }) | ||
404 | |||
405 | it('Should fail with an unknown or incorrect video id', async function () { | ||
406 | { | ||
407 | const params = getBase({}, { videoId: 'toto' }) | ||
408 | await updateVideoPlaylistElement(params) | ||
409 | } | ||
410 | |||
411 | { | ||
412 | const params = getBase({}, { videoId: 42, expectedStatus: 404 }) | ||
413 | await updateVideoPlaylistElement(params) | ||
414 | } | ||
415 | }) | ||
416 | |||
417 | it('Should fail with a bad start/stop timestamp', async function () { | ||
418 | { | ||
419 | const params = getBase({ startTimestamp: 'toto' as any }) | ||
420 | await updateVideoPlaylistElement(params) | ||
421 | } | ||
422 | |||
423 | { | ||
424 | const params = getBase({ stopTimestamp: -42 }) | ||
425 | await updateVideoPlaylistElement(params) | ||
426 | } | ||
427 | }) | ||
428 | |||
429 | it('Should fail with an unknown element', async function () { | ||
430 | const params = getBase({}, { videoId: videoId2, expectedStatus: 404 }) | ||
431 | await updateVideoPlaylistElement(params) | ||
432 | }) | ||
433 | |||
434 | it('Succeed with the correct params', async function () { | ||
435 | const params = getBase({}, { expectedStatus: 204 }) | ||
436 | await updateVideoPlaylistElement(params) | ||
437 | }) | ||
438 | }) | ||
439 | |||
440 | describe('When reordering elements of a playlist', function () { | ||
441 | let videoId3: number | ||
442 | let videoId4: number | ||
443 | |||
444 | const getBase = (elementAttrs: any = {}, wrapper: any = {}) => { | ||
445 | return Object.assign({ | ||
446 | url: server.url, | ||
447 | token: server.accessToken, | ||
448 | playlistId: playlistUUID, | ||
449 | elementAttrs: Object.assign({ | ||
450 | startPosition: 1, | ||
451 | insertAfterPosition: 2, | ||
452 | reorderLength: 3 | ||
453 | }, elementAttrs), | ||
454 | expectedStatus: 400 | ||
455 | }, wrapper) | ||
456 | } | ||
457 | |||
458 | before(async function () { | ||
459 | videoId3 = (await uploadVideoAndGetId({ server, videoName: 'video 3' })).id | ||
460 | videoId4 = (await uploadVideoAndGetId({ server, videoName: 'video 4' })).id | ||
461 | |||
462 | for (let id of [ videoId3, videoId4 ]) { | ||
463 | await addVideoInPlaylist({ | ||
464 | url: server.url, | ||
465 | token: server.accessToken, | ||
466 | playlistId: playlistUUID, | ||
467 | elementAttrs: { videoId: id } | ||
468 | }) | ||
469 | } | ||
470 | }) | ||
471 | |||
472 | it('Should fail with an unauthenticated user', async function () { | ||
473 | const params = getBase({}, { token: null, expectedStatus: 401 }) | ||
474 | await reorderVideosPlaylist(params) | ||
475 | }) | ||
476 | |||
477 | it('Should fail with the playlist of another user', async function () { | ||
478 | const params = getBase({}, { token: userAccessToken, expectedStatus: 403 }) | ||
479 | await reorderVideosPlaylist(params) | ||
480 | }) | ||
481 | |||
482 | it('Should fail with an invalid playlist', async function () { | ||
483 | { | ||
484 | const params = getBase({}, { playlistId: 'toto' }) | ||
485 | await reorderVideosPlaylist(params) | ||
486 | } | ||
487 | |||
488 | { | ||
489 | const params = getBase({}, { playlistId: 42, expectedStatus: 404 }) | ||
490 | await reorderVideosPlaylist(params) | ||
491 | } | ||
492 | }) | ||
493 | |||
494 | it('Should fail with an invalid start position', async function () { | ||
495 | { | ||
496 | const params = getBase({ startPosition: -1 }) | ||
497 | await reorderVideosPlaylist(params) | ||
498 | } | ||
499 | |||
500 | { | ||
501 | const params = getBase({ startPosition: 'toto' as any }) | ||
502 | await reorderVideosPlaylist(params) | ||
503 | } | ||
504 | |||
505 | { | ||
506 | const params = getBase({ startPosition: 42 }) | ||
507 | await reorderVideosPlaylist(params) | ||
508 | } | ||
509 | }) | ||
510 | |||
511 | it('Should fail with an invalid insert after position', async function () { | ||
512 | { | ||
513 | const params = getBase({ insertAfterPosition: 'toto' as any }) | ||
514 | await reorderVideosPlaylist(params) | ||
515 | } | ||
516 | |||
517 | { | ||
518 | const params = getBase({ insertAfterPosition: -2 }) | ||
519 | await reorderVideosPlaylist(params) | ||
520 | } | ||
521 | |||
522 | { | ||
523 | const params = getBase({ insertAfterPosition: 42 }) | ||
524 | await reorderVideosPlaylist(params) | ||
525 | } | ||
526 | }) | ||
527 | |||
528 | it('Should fail with an invalid reorder length', async function () { | ||
529 | { | ||
530 | const params = getBase({ reorderLength: 'toto' as any }) | ||
531 | await reorderVideosPlaylist(params) | ||
532 | } | ||
533 | |||
534 | { | ||
535 | const params = getBase({ reorderLength: -2 }) | ||
536 | await reorderVideosPlaylist(params) | ||
537 | } | ||
538 | |||
539 | { | ||
540 | const params = getBase({ reorderLength: 42 }) | ||
541 | await reorderVideosPlaylist(params) | ||
542 | } | ||
543 | }) | ||
544 | |||
545 | it('Succeed with the correct params', async function () { | ||
546 | const params = getBase({}, { expectedStatus: 204 }) | ||
547 | await reorderVideosPlaylist(params) | ||
548 | }) | ||
549 | }) | ||
550 | |||
551 | describe('When checking exists in playlist endpoint', function () { | ||
552 | const path = '/api/v1/users/me/video-playlists/videos-exist' | ||
553 | |||
554 | it('Should fail with an unauthenticated user', async function () { | ||
555 | await makeGetRequest({ | ||
556 | url: server.url, | ||
557 | path, | ||
558 | query: { videoIds: [ 1, 2 ] }, | ||
559 | statusCodeExpected: 401 | ||
560 | }) | ||
561 | }) | ||
562 | |||
563 | it('Should fail with invalid video ids', async function () { | ||
564 | await makeGetRequest({ | ||
565 | url: server.url, | ||
566 | token: server.accessToken, | ||
567 | path, | ||
568 | query: { videoIds: 'toto' } | ||
569 | }) | ||
570 | |||
571 | await makeGetRequest({ | ||
572 | url: server.url, | ||
573 | token: server.accessToken, | ||
574 | path, | ||
575 | query: { videoIds: [ 'toto' ] } | ||
576 | }) | ||
577 | |||
578 | await makeGetRequest({ | ||
579 | url: server.url, | ||
580 | token: server.accessToken, | ||
581 | path, | ||
582 | query: { videoIds: [ 1, 'toto' ] } | ||
583 | }) | ||
584 | }) | ||
585 | |||
586 | it('Should succeed with the correct params', async function () { | ||
587 | await makeGetRequest({ | ||
588 | url: server.url, | ||
589 | token: server.accessToken, | ||
590 | path, | ||
591 | query: { videoIds: [ 1, 2 ] }, | ||
592 | statusCodeExpected: 200 | ||
593 | }) | ||
594 | }) | ||
595 | }) | ||
596 | |||
597 | describe('When deleting an element in a playlist', function () { | ||
598 | const getBase = (wrapper: any = {}) => { | ||
599 | return Object.assign({ | ||
600 | url: server.url, | ||
601 | token: server.accessToken, | ||
602 | videoId: videoId, | ||
603 | playlistId: playlistUUID, | ||
604 | expectedStatus: 400 | ||
605 | }, wrapper) | ||
606 | } | ||
607 | |||
608 | it('Should fail with an unauthenticated user', async function () { | ||
609 | const params = getBase({ token: null, expectedStatus: 401 }) | ||
610 | await removeVideoFromPlaylist(params) | ||
611 | }) | ||
612 | |||
613 | it('Should fail with the playlist of another user', async function () { | ||
614 | const params = getBase({ token: userAccessToken, expectedStatus: 403 }) | ||
615 | await removeVideoFromPlaylist(params) | ||
616 | }) | ||
617 | |||
618 | it('Should fail with an unknown or incorrect playlist id', async function () { | ||
619 | { | ||
620 | const params = getBase({ playlistId: 'toto' }) | ||
621 | await removeVideoFromPlaylist(params) | ||
622 | } | ||
623 | |||
624 | { | ||
625 | const params = getBase({ playlistId: 42, expectedStatus: 404 }) | ||
626 | await removeVideoFromPlaylist(params) | ||
627 | } | ||
628 | }) | ||
629 | |||
630 | it('Should fail with an unknown or incorrect video id', async function () { | ||
631 | { | ||
632 | const params = getBase({ videoId: 'toto' }) | ||
633 | await removeVideoFromPlaylist(params) | ||
634 | } | ||
635 | |||
636 | { | ||
637 | const params = getBase({ videoId: 42, expectedStatus: 404 }) | ||
638 | await removeVideoFromPlaylist(params) | ||
639 | } | ||
640 | }) | ||
641 | |||
642 | it('Should fail with an unknown element', async function () { | ||
643 | const params = getBase({ videoId: videoId2, expectedStatus: 404 }) | ||
644 | await removeVideoFromPlaylist(params) | ||
645 | }) | ||
646 | |||
647 | it('Succeed with the correct params', async function () { | ||
648 | const params = getBase({ expectedStatus: 204 }) | ||
649 | await removeVideoFromPlaylist(params) | ||
650 | }) | ||
651 | }) | ||
652 | |||
653 | describe('When deleting a playlist', function () { | ||
654 | it('Should fail with an unknown playlist', async function () { | ||
655 | await deleteVideoPlaylist(server.url, server.accessToken, 42, 404) | ||
656 | }) | ||
657 | |||
658 | it('Should fail with a playlist of another user', async function () { | ||
659 | await deleteVideoPlaylist(server.url, userAccessToken, playlistUUID, 403) | ||
660 | }) | ||
661 | |||
662 | it('Should fail with the watch later playlist', async function () { | ||
663 | await deleteVideoPlaylist(server.url, server.accessToken, watchLaterPlaylistId, 400) | ||
664 | }) | ||
665 | |||
666 | it('Should succeed with the correct params', async function () { | ||
667 | await deleteVideoPlaylist(server.url, server.accessToken, playlistUUID) | ||
668 | }) | ||
669 | }) | ||
670 | |||
671 | after(async function () { | ||
672 | await cleanupTests([ server ]) | ||
673 | }) | ||
674 | }) | ||
diff --git a/server/tests/api/check-params/videos-filter.ts b/server/tests/api/check-params/videos-filter.ts index e998c8a3d..babef8223 100644 --- a/server/tests/api/check-params/videos-filter.ts +++ b/server/tests/api/check-params/videos-filter.ts | |||
@@ -1,27 +1,27 @@ | |||
1 | /* tslint:disable:no-unused-expression */ | 1 | /* tslint:disable:no-unused-expression */ |
2 | 2 | ||
3 | import * as chai from 'chai' | ||
4 | import 'mocha' | 3 | import 'mocha' |
5 | import { | 4 | import { |
5 | cleanupTests, | ||
6 | createUser, | 6 | createUser, |
7 | flushTests, | 7 | createVideoPlaylist, |
8 | killallServers, | 8 | flushAndRunServer, |
9 | makeGetRequest, | 9 | makeGetRequest, |
10 | runServer, | ||
11 | ServerInfo, | 10 | ServerInfo, |
12 | setAccessTokensToServers, | 11 | setAccessTokensToServers, |
12 | setDefaultVideoChannel, | ||
13 | userLogin | 13 | userLogin |
14 | } from '../../../../shared/utils' | 14 | } from '../../../../shared/extra-utils' |
15 | import { UserRole } from '../../../../shared/models/users' | 15 | import { UserRole } from '../../../../shared/models/users' |
16 | import { VideoPlaylistPrivacy } from '../../../../shared/models/videos/playlist/video-playlist-privacy.model' | ||
16 | 17 | ||
17 | const expect = chai.expect | 18 | async function testEndpoints (server: ServerInfo, token: string, filter: string, playlistUUID: string, statusCodeExpected: number) { |
18 | |||
19 | async function testEndpoints (server: ServerInfo, token: string, filter: string, statusCodeExpected: number) { | ||
20 | const paths = [ | 19 | const paths = [ |
21 | '/api/v1/video-channels/root_channel/videos', | 20 | '/api/v1/video-channels/root_channel/videos', |
22 | '/api/v1/accounts/root/videos', | 21 | '/api/v1/accounts/root/videos', |
23 | '/api/v1/videos', | 22 | '/api/v1/videos', |
24 | '/api/v1/search/videos' | 23 | '/api/v1/search/videos', |
24 | '/api/v1/video-playlists/' + playlistUUID + '/videos' | ||
25 | ] | 25 | ] |
26 | 26 | ||
27 | for (const path of paths) { | 27 | for (const path of paths) { |
@@ -41,55 +41,68 @@ describe('Test videos filters', function () { | |||
41 | let server: ServerInfo | 41 | let server: ServerInfo |
42 | let userAccessToken: string | 42 | let userAccessToken: string |
43 | let moderatorAccessToken: string | 43 | let moderatorAccessToken: string |
44 | let playlistUUID: string | ||
44 | 45 | ||
45 | // --------------------------------------------------------------- | 46 | // --------------------------------------------------------------- |
46 | 47 | ||
47 | before(async function () { | 48 | before(async function () { |
48 | this.timeout(30000) | 49 | this.timeout(30000) |
49 | 50 | ||
50 | await flushTests() | 51 | server = await flushAndRunServer(1) |
51 | |||
52 | server = await runServer(1) | ||
53 | 52 | ||
54 | await setAccessTokensToServers([ server ]) | 53 | await setAccessTokensToServers([ server ]) |
54 | await setDefaultVideoChannel([ server ]) | ||
55 | 55 | ||
56 | const user = { username: 'user1', password: 'my super password' } | 56 | const user = { username: 'user1', password: 'my super password' } |
57 | await createUser(server.url, server.accessToken, user.username, user.password) | 57 | await createUser({ url: server.url, accessToken: server.accessToken, username: user.username, password: user.password }) |
58 | userAccessToken = await userLogin(server, user) | 58 | userAccessToken = await userLogin(server, user) |
59 | 59 | ||
60 | const moderator = { username: 'moderator', password: 'my super password' } | 60 | const moderator = { username: 'moderator', password: 'my super password' } |
61 | await createUser( | 61 | await createUser( |
62 | server.url, | 62 | { |
63 | server.accessToken, | 63 | url: server.url, |
64 | moderator.username, | 64 | accessToken: server.accessToken, |
65 | moderator.password, | 65 | username: moderator.username, |
66 | undefined, | 66 | password: moderator.password, |
67 | undefined, | 67 | videoQuota: undefined, |
68 | UserRole.MODERATOR | 68 | videoQuotaDaily: undefined, |
69 | role: UserRole.MODERATOR | ||
70 | } | ||
69 | ) | 71 | ) |
70 | moderatorAccessToken = await userLogin(server, moderator) | 72 | moderatorAccessToken = await userLogin(server, moderator) |
73 | |||
74 | const res = await createVideoPlaylist({ | ||
75 | url: server.url, | ||
76 | token: server.accessToken, | ||
77 | playlistAttrs: { | ||
78 | displayName: 'super playlist', | ||
79 | privacy: VideoPlaylistPrivacy.PUBLIC, | ||
80 | videoChannelId: server.videoChannel.id | ||
81 | } | ||
82 | }) | ||
83 | playlistUUID = res.body.videoPlaylist.uuid | ||
71 | }) | 84 | }) |
72 | 85 | ||
73 | describe('When setting a video filter', function () { | 86 | describe('When setting a video filter', function () { |
74 | 87 | ||
75 | it('Should fail with a bad filter', async function () { | 88 | it('Should fail with a bad filter', async function () { |
76 | await testEndpoints(server, server.accessToken, 'bad-filter', 400) | 89 | await testEndpoints(server, server.accessToken, 'bad-filter', playlistUUID, 400) |
77 | }) | 90 | }) |
78 | 91 | ||
79 | it('Should succeed with a good filter', async function () { | 92 | it('Should succeed with a good filter', async function () { |
80 | await testEndpoints(server, server.accessToken,'local', 200) | 93 | await testEndpoints(server, server.accessToken,'local', playlistUUID, 200) |
81 | }) | 94 | }) |
82 | 95 | ||
83 | it('Should fail to list all-local with a simple user', async function () { | 96 | it('Should fail to list all-local with a simple user', async function () { |
84 | await testEndpoints(server, userAccessToken, 'all-local', 401) | 97 | await testEndpoints(server, userAccessToken, 'all-local', playlistUUID, 401) |
85 | }) | 98 | }) |
86 | 99 | ||
87 | it('Should succeed to list all-local with a moderator', async function () { | 100 | it('Should succeed to list all-local with a moderator', async function () { |
88 | await testEndpoints(server, moderatorAccessToken, 'all-local', 200) | 101 | await testEndpoints(server, moderatorAccessToken, 'all-local', playlistUUID, 200) |
89 | }) | 102 | }) |
90 | 103 | ||
91 | it('Should succeed to list all-local with an admin', async function () { | 104 | it('Should succeed to list all-local with an admin', async function () { |
92 | await testEndpoints(server, server.accessToken, 'all-local', 200) | 105 | await testEndpoints(server, server.accessToken, 'all-local', playlistUUID, 200) |
93 | }) | 106 | }) |
94 | 107 | ||
95 | // Because we cannot authenticate the user on the RSS endpoint | 108 | // Because we cannot authenticate the user on the RSS endpoint |
@@ -104,7 +117,7 @@ describe('Test videos filters', function () { | |||
104 | }) | 117 | }) |
105 | }) | 118 | }) |
106 | 119 | ||
107 | it('Should succed on the feeds endpoint with the local filter', async function () { | 120 | it('Should succeed on the feeds endpoint with the local filter', async function () { |
108 | await makeGetRequest({ | 121 | await makeGetRequest({ |
109 | url: server.url, | 122 | url: server.url, |
110 | path: '/feeds/videos.json', | 123 | path: '/feeds/videos.json', |
@@ -117,11 +130,6 @@ describe('Test videos filters', function () { | |||
117 | }) | 130 | }) |
118 | 131 | ||
119 | after(async function () { | 132 | after(async function () { |
120 | killallServers([ server ]) | 133 | await cleanupTests([ server ]) |
121 | |||
122 | // Keep the logs if the test failed | ||
123 | if (this['ok']) { | ||
124 | await flushTests() | ||
125 | } | ||
126 | }) | 134 | }) |
127 | }) | 135 | }) |
diff --git a/server/tests/api/check-params/videos-history.ts b/server/tests/api/check-params/videos-history.ts index 8c079a956..3739e3fad 100644 --- a/server/tests/api/check-params/videos-history.ts +++ b/server/tests/api/check-params/videos-history.ts | |||
@@ -5,16 +5,15 @@ import 'mocha' | |||
5 | import { | 5 | import { |
6 | checkBadCountPagination, | 6 | checkBadCountPagination, |
7 | checkBadStartPagination, | 7 | checkBadStartPagination, |
8 | flushTests, | 8 | cleanupTests, |
9 | killallServers, | 9 | flushAndRunServer, |
10 | makeGetRequest, | 10 | makeGetRequest, |
11 | makePostBodyRequest, | 11 | makePostBodyRequest, |
12 | makePutBodyRequest, | 12 | makePutBodyRequest, |
13 | runServer, | ||
14 | ServerInfo, | 13 | ServerInfo, |
15 | setAccessTokensToServers, | 14 | setAccessTokensToServers, |
16 | uploadVideo | 15 | uploadVideo |
17 | } from '../../../../shared/utils' | 16 | } from '../../../../shared/extra-utils' |
18 | 17 | ||
19 | const expect = chai.expect | 18 | const expect = chai.expect |
20 | 19 | ||
@@ -29,9 +28,7 @@ describe('Test videos history API validator', function () { | |||
29 | before(async function () { | 28 | before(async function () { |
30 | this.timeout(30000) | 29 | this.timeout(30000) |
31 | 30 | ||
32 | await flushTests() | 31 | server = await flushAndRunServer(1) |
33 | |||
34 | server = await runServer(1) | ||
35 | 32 | ||
36 | await setAccessTokensToServers([ server ]) | 33 | await setAccessTokensToServers([ server ]) |
37 | 34 | ||
@@ -129,11 +126,6 @@ describe('Test videos history API validator', function () { | |||
129 | }) | 126 | }) |
130 | 127 | ||
131 | after(async function () { | 128 | after(async function () { |
132 | killallServers([ server ]) | 129 | await cleanupTests([ server ]) |
133 | |||
134 | // Keep the logs if the test failed | ||
135 | if (this['ok']) { | ||
136 | await flushTests() | ||
137 | } | ||
138 | }) | 130 | }) |
139 | }) | 131 | }) |
diff --git a/server/tests/api/check-params/videos.ts b/server/tests/api/check-params/videos.ts index f26b91435..51e592a15 100644 --- a/server/tests/api/check-params/videos.ts +++ b/server/tests/api/check-params/videos.ts | |||
@@ -6,15 +6,28 @@ import 'mocha' | |||
6 | import { join } from 'path' | 6 | import { join } from 'path' |
7 | import { VideoPrivacy } from '../../../../shared/models/videos/video-privacy.enum' | 7 | import { VideoPrivacy } from '../../../../shared/models/videos/video-privacy.enum' |
8 | import { | 8 | import { |
9 | createUser, flushTests, getMyUserInformation, getVideo, getVideosList, immutableAssign, killallServers, makeDeleteRequest, | 9 | cleanupTests, |
10 | makeGetRequest, makeUploadRequest, makePutBodyRequest, removeVideo, runServer, ServerInfo, setAccessTokensToServers, userLogin | 10 | createUser, |
11 | } from '../../../../shared/utils' | 11 | flushAndRunServer, |
12 | getMyUserInformation, | ||
13 | getVideo, | ||
14 | getVideosList, | ||
15 | immutableAssign, | ||
16 | makeDeleteRequest, | ||
17 | makeGetRequest, | ||
18 | makePutBodyRequest, | ||
19 | makeUploadRequest, | ||
20 | removeVideo, | ||
21 | ServerInfo, | ||
22 | setAccessTokensToServers, | ||
23 | userLogin, | ||
24 | root | ||
25 | } from '../../../../shared/extra-utils' | ||
12 | import { | 26 | import { |
13 | checkBadCountPagination, | 27 | checkBadCountPagination, |
14 | checkBadSortPagination, | 28 | checkBadSortPagination, |
15 | checkBadStartPagination | 29 | checkBadStartPagination |
16 | } from '../../../../shared/utils/requests/check-api-params' | 30 | } from '../../../../shared/extra-utils/requests/check-api-params' |
17 | import { getAccountsList } from '../../../../shared/utils/users/accounts' | ||
18 | 31 | ||
19 | const expect = chai.expect | 32 | const expect = chai.expect |
20 | 33 | ||
@@ -32,15 +45,13 @@ describe('Test videos API validator', function () { | |||
32 | before(async function () { | 45 | before(async function () { |
33 | this.timeout(30000) | 46 | this.timeout(30000) |
34 | 47 | ||
35 | await flushTests() | 48 | server = await flushAndRunServer(1) |
36 | |||
37 | server = await runServer(1) | ||
38 | 49 | ||
39 | await setAccessTokensToServers([ server ]) | 50 | await setAccessTokensToServers([ server ]) |
40 | 51 | ||
41 | const username = 'user1' | 52 | const username = 'user1' |
42 | const password = 'my super password' | 53 | const password = 'my super password' |
43 | await createUser(server.url, server.accessToken, username, password) | 54 | await createUser({ url: server.url, accessToken: server.accessToken, username: username, password: password }) |
44 | userAccessToken = await userLogin(server, { username, password }) | 55 | userAccessToken = await userLogin(server, { username, password }) |
45 | 56 | ||
46 | { | 57 | { |
@@ -167,7 +178,7 @@ describe('Test videos API validator', function () { | |||
167 | describe('When adding a video', function () { | 178 | describe('When adding a video', function () { |
168 | let baseCorrectParams | 179 | let baseCorrectParams |
169 | const baseCorrectAttaches = { | 180 | const baseCorrectAttaches = { |
170 | 'videofile': join(__dirname, '..', '..', 'fixtures', 'video_short.webm') | 181 | 'videofile': join(root(), 'server', 'tests', 'fixtures', 'video_short.webm') |
171 | } | 182 | } |
172 | 183 | ||
173 | before(function () { | 184 | before(function () { |
@@ -179,12 +190,14 @@ describe('Test videos API validator', function () { | |||
179 | language: 'pt', | 190 | language: 'pt', |
180 | nsfw: false, | 191 | nsfw: false, |
181 | commentsEnabled: true, | 192 | commentsEnabled: true, |
193 | downloadEnabled: true, | ||
182 | waitTranscoding: true, | 194 | waitTranscoding: true, |
183 | description: 'my super description', | 195 | description: 'my super description', |
184 | support: 'my super support text', | 196 | support: 'my super support text', |
185 | tags: [ 'tag1', 'tag2' ], | 197 | tags: [ 'tag1', 'tag2' ], |
186 | privacy: VideoPrivacy.PUBLIC, | 198 | privacy: VideoPrivacy.PUBLIC, |
187 | channelId: channelId | 199 | channelId: channelId, |
200 | originallyPublishedAt: new Date().toISOString() | ||
188 | } | 201 | } |
189 | }) | 202 | }) |
190 | 203 | ||
@@ -262,7 +275,7 @@ describe('Test videos API validator', function () { | |||
262 | username: 'fake', | 275 | username: 'fake', |
263 | password: 'fake_password' | 276 | password: 'fake_password' |
264 | } | 277 | } |
265 | await createUser(server.url, server.accessToken, user.username, user.password) | 278 | await createUser({ url: server.url, accessToken: server.accessToken, username: user.username, password: user.password }) |
266 | 279 | ||
267 | const accessTokenUser = await userLogin(server, user) | 280 | const accessTokenUser = await userLogin(server, user) |
268 | const res = await getMyUserInformation(server.url, accessTokenUser) | 281 | const res = await getMyUserInformation(server.url, accessTokenUser) |
@@ -312,21 +325,28 @@ describe('Test videos API validator', function () { | |||
312 | await makeUploadRequest({ url: server.url, path: path + '/upload', token: server.accessToken, fields, attaches }) | 325 | await makeUploadRequest({ url: server.url, path: path + '/upload', token: server.accessToken, fields, attaches }) |
313 | }) | 326 | }) |
314 | 327 | ||
328 | it('Should fail with a bad originally published at attribute', async function () { | ||
329 | const fields = immutableAssign(baseCorrectParams, { 'originallyPublishedAt': 'toto' }) | ||
330 | const attaches = baseCorrectAttaches | ||
331 | |||
332 | await makeUploadRequest({ url: server.url, path: path + '/upload', token: server.accessToken, fields, attaches }) | ||
333 | }) | ||
334 | |||
315 | it('Should fail without an input file', async function () { | 335 | it('Should fail without an input file', async function () { |
316 | const fields = baseCorrectParams | 336 | const fields = baseCorrectParams |
317 | const attaches = {} | 337 | const attaches = {} |
318 | await makeUploadRequest({ url: server.url, path: path + '/upload', token: server.accessToken, fields, attaches }) | 338 | await makeUploadRequest({ url: server.url, path: path + '/upload', token: server.accessToken, fields, attaches }) |
319 | }) | 339 | }) |
320 | 340 | ||
321 | it('Should fail without an incorrect input file', async function () { | 341 | it('Should fail with an incorrect input file', async function () { |
322 | const fields = baseCorrectParams | 342 | const fields = baseCorrectParams |
323 | let attaches = { | 343 | let attaches = { |
324 | 'videofile': join(__dirname, '..', '..', 'fixtures', 'video_short_fake.webm') | 344 | 'videofile': join(root(), 'server', 'tests', 'fixtures', 'video_short_fake.webm') |
325 | } | 345 | } |
326 | await makeUploadRequest({ url: server.url, path: path + '/upload', token: server.accessToken, fields, attaches }) | 346 | await makeUploadRequest({ url: server.url, path: path + '/upload', token: server.accessToken, fields, attaches }) |
327 | 347 | ||
328 | attaches = { | 348 | attaches = { |
329 | 'videofile': join(__dirname, '..', '..', 'fixtures', 'video_short.mkv') | 349 | 'videofile': join(root(), 'server', 'tests', 'fixtures', 'video_short.mkv') |
330 | } | 350 | } |
331 | await makeUploadRequest({ url: server.url, path: path + '/upload', token: server.accessToken, fields, attaches }) | 351 | await makeUploadRequest({ url: server.url, path: path + '/upload', token: server.accessToken, fields, attaches }) |
332 | }) | 352 | }) |
@@ -334,8 +354,8 @@ describe('Test videos API validator', function () { | |||
334 | it('Should fail with an incorrect thumbnail file', async function () { | 354 | it('Should fail with an incorrect thumbnail file', async function () { |
335 | const fields = baseCorrectParams | 355 | const fields = baseCorrectParams |
336 | const attaches = { | 356 | const attaches = { |
337 | 'thumbnailfile': join(__dirname, '..', '..', 'fixtures', 'avatar.png'), | 357 | 'thumbnailfile': join(root(), 'server', 'tests', 'fixtures', 'avatar.png'), |
338 | 'videofile': join(__dirname, '..', '..', 'fixtures', 'video_short.mp4') | 358 | 'videofile': join(root(), 'server', 'tests', 'fixtures', 'video_short.mp4') |
339 | } | 359 | } |
340 | 360 | ||
341 | await makeUploadRequest({ url: server.url, path: path + '/upload', token: server.accessToken, fields, attaches }) | 361 | await makeUploadRequest({ url: server.url, path: path + '/upload', token: server.accessToken, fields, attaches }) |
@@ -344,8 +364,8 @@ describe('Test videos API validator', function () { | |||
344 | it('Should fail with a big thumbnail file', async function () { | 364 | it('Should fail with a big thumbnail file', async function () { |
345 | const fields = baseCorrectParams | 365 | const fields = baseCorrectParams |
346 | const attaches = { | 366 | const attaches = { |
347 | 'thumbnailfile': join(__dirname, '..', '..', 'fixtures', 'avatar-big.png'), | 367 | 'thumbnailfile': join(root(), 'server', 'tests', 'fixtures', 'avatar-big.png'), |
348 | 'videofile': join(__dirname, '..', '..', 'fixtures', 'video_short.mp4') | 368 | 'videofile': join(root(), 'server', 'tests', 'fixtures', 'video_short.mp4') |
349 | } | 369 | } |
350 | 370 | ||
351 | await makeUploadRequest({ url: server.url, path: path + '/upload', token: server.accessToken, fields, attaches }) | 371 | await makeUploadRequest({ url: server.url, path: path + '/upload', token: server.accessToken, fields, attaches }) |
@@ -354,8 +374,8 @@ describe('Test videos API validator', function () { | |||
354 | it('Should fail with an incorrect preview file', async function () { | 374 | it('Should fail with an incorrect preview file', async function () { |
355 | const fields = baseCorrectParams | 375 | const fields = baseCorrectParams |
356 | const attaches = { | 376 | const attaches = { |
357 | 'previewfile': join(__dirname, '..', '..', 'fixtures', 'avatar.png'), | 377 | 'previewfile': join(root(), 'server', 'tests', 'fixtures', 'avatar.png'), |
358 | 'videofile': join(__dirname, '..', '..', 'fixtures', 'video_short.mp4') | 378 | 'videofile': join(root(), 'server', 'tests', 'fixtures', 'video_short.mp4') |
359 | } | 379 | } |
360 | 380 | ||
361 | await makeUploadRequest({ url: server.url, path: path + '/upload', token: server.accessToken, fields, attaches }) | 381 | await makeUploadRequest({ url: server.url, path: path + '/upload', token: server.accessToken, fields, attaches }) |
@@ -364,8 +384,8 @@ describe('Test videos API validator', function () { | |||
364 | it('Should fail with a big preview file', async function () { | 384 | it('Should fail with a big preview file', async function () { |
365 | const fields = baseCorrectParams | 385 | const fields = baseCorrectParams |
366 | const attaches = { | 386 | const attaches = { |
367 | 'previewfile': join(__dirname, '..', '..', 'fixtures', 'avatar-big.png'), | 387 | 'previewfile': join(root(), 'server', 'tests', 'fixtures', 'avatar-big.png'), |
368 | 'videofile': join(__dirname, '..', '..', 'fixtures', 'video_short.mp4') | 388 | 'videofile': join(root(), 'server', 'tests', 'fixtures', 'video_short.mp4') |
369 | } | 389 | } |
370 | 390 | ||
371 | await makeUploadRequest({ url: server.url, path: path + '/upload', token: server.accessToken, fields, attaches }) | 391 | await makeUploadRequest({ url: server.url, path: path + '/upload', token: server.accessToken, fields, attaches }) |
@@ -390,7 +410,7 @@ describe('Test videos API validator', function () { | |||
390 | 410 | ||
391 | { | 411 | { |
392 | const attaches = immutableAssign(baseCorrectAttaches, { | 412 | const attaches = immutableAssign(baseCorrectAttaches, { |
393 | videofile: join(__dirname, '..', '..', 'fixtures', 'video_short.mp4') | 413 | videofile: join(root(), 'server', 'tests', 'fixtures', 'video_short.mp4') |
394 | }) | 414 | }) |
395 | 415 | ||
396 | await makeUploadRequest({ | 416 | await makeUploadRequest({ |
@@ -405,7 +425,7 @@ describe('Test videos API validator', function () { | |||
405 | 425 | ||
406 | { | 426 | { |
407 | const attaches = immutableAssign(baseCorrectAttaches, { | 427 | const attaches = immutableAssign(baseCorrectAttaches, { |
408 | videofile: join(__dirname, '..', '..', 'fixtures', 'video_short.ogv') | 428 | videofile: join(root(), 'server', 'tests', 'fixtures', 'video_short.ogv') |
409 | }) | 429 | }) |
410 | 430 | ||
411 | await makeUploadRequest({ | 431 | await makeUploadRequest({ |
@@ -428,6 +448,7 @@ describe('Test videos API validator', function () { | |||
428 | language: 'pt', | 448 | language: 'pt', |
429 | nsfw: false, | 449 | nsfw: false, |
430 | commentsEnabled: false, | 450 | commentsEnabled: false, |
451 | downloadEnabled: false, | ||
431 | description: 'my super description', | 452 | description: 'my super description', |
432 | privacy: VideoPrivacy.PUBLIC, | 453 | privacy: VideoPrivacy.PUBLIC, |
433 | tags: [ 'tag1', 'tag2' ] | 454 | tags: [ 'tag1', 'tag2' ] |
@@ -532,10 +553,16 @@ describe('Test videos API validator', function () { | |||
532 | await makePutBodyRequest({ url: server.url, path: path + videoId, token: server.accessToken, fields }) | 553 | await makePutBodyRequest({ url: server.url, path: path + videoId, token: server.accessToken, fields }) |
533 | }) | 554 | }) |
534 | 555 | ||
556 | it('Should fail with a bad originally published at param', async function () { | ||
557 | const fields = immutableAssign(baseCorrectParams, { originallyPublishedAt: 'toto' }) | ||
558 | |||
559 | await makePutBodyRequest({ url: server.url, path: path + videoId, token: server.accessToken, fields }) | ||
560 | }) | ||
561 | |||
535 | it('Should fail with an incorrect thumbnail file', async function () { | 562 | it('Should fail with an incorrect thumbnail file', async function () { |
536 | const fields = baseCorrectParams | 563 | const fields = baseCorrectParams |
537 | const attaches = { | 564 | const attaches = { |
538 | 'thumbnailfile': join(__dirname, '..', '..', 'fixtures', 'avatar.png') | 565 | 'thumbnailfile': join(root(), 'server', 'tests', 'fixtures', 'avatar.png') |
539 | } | 566 | } |
540 | 567 | ||
541 | await makeUploadRequest({ | 568 | await makeUploadRequest({ |
@@ -551,7 +578,7 @@ describe('Test videos API validator', function () { | |||
551 | it('Should fail with a big thumbnail file', async function () { | 578 | it('Should fail with a big thumbnail file', async function () { |
552 | const fields = baseCorrectParams | 579 | const fields = baseCorrectParams |
553 | const attaches = { | 580 | const attaches = { |
554 | 'thumbnailfile': join(__dirname, '..', '..', 'fixtures', 'avatar-big.png') | 581 | 'thumbnailfile': join(root(), 'server', 'tests', 'fixtures', 'avatar-big.png') |
555 | } | 582 | } |
556 | 583 | ||
557 | await makeUploadRequest({ | 584 | await makeUploadRequest({ |
@@ -567,7 +594,7 @@ describe('Test videos API validator', function () { | |||
567 | it('Should fail with an incorrect preview file', async function () { | 594 | it('Should fail with an incorrect preview file', async function () { |
568 | const fields = baseCorrectParams | 595 | const fields = baseCorrectParams |
569 | const attaches = { | 596 | const attaches = { |
570 | 'previewfile': join(__dirname, '..', '..', 'fixtures', 'avatar.png') | 597 | 'previewfile': join(root(), 'server', 'tests', 'fixtures', 'avatar.png') |
571 | } | 598 | } |
572 | 599 | ||
573 | await makeUploadRequest({ | 600 | await makeUploadRequest({ |
@@ -583,7 +610,7 @@ describe('Test videos API validator', function () { | |||
583 | it('Should fail with a big preview file', async function () { | 610 | it('Should fail with a big preview file', async function () { |
584 | const fields = baseCorrectParams | 611 | const fields = baseCorrectParams |
585 | const attaches = { | 612 | const attaches = { |
586 | 'previewfile': join(__dirname, '..', '..', 'fixtures', 'avatar-big.png') | 613 | 'previewfile': join(root(), 'server', 'tests', 'fixtures', 'avatar-big.png') |
587 | } | 614 | } |
588 | 615 | ||
589 | await makeUploadRequest({ | 616 | await makeUploadRequest({ |
@@ -714,11 +741,6 @@ describe('Test videos API validator', function () { | |||
714 | }) | 741 | }) |
715 | 742 | ||
716 | after(async function () { | 743 | after(async function () { |
717 | killallServers([ server ]) | 744 | await cleanupTests([ server ]) |
718 | |||
719 | // Keep the logs if the test failed | ||
720 | if (this['ok']) { | ||
721 | await flushTests() | ||
722 | } | ||
723 | }) | 745 | }) |
724 | }) | 746 | }) |
diff --git a/server/tests/api/index-1.ts b/server/tests/api/index-1.ts index 80d752f42..75cdd9025 100644 --- a/server/tests/api/index-1.ts +++ b/server/tests/api/index-1.ts | |||
@@ -1,2 +1,3 @@ | |||
1 | import './check-params' | 1 | import './check-params' |
2 | import './notifications' | ||
2 | import './search' | 3 | import './search' |
diff --git a/server/tests/api/notifications/index.ts b/server/tests/api/notifications/index.ts new file mode 100644 index 000000000..95ac8fc51 --- /dev/null +++ b/server/tests/api/notifications/index.ts | |||
@@ -0,0 +1 @@ | |||
export * from './user-notifications' | |||
diff --git a/server/tests/api/users/user-notifications.ts b/server/tests/api/notifications/user-notifications.ts index 72b6a0aa2..f479e1785 100644 --- a/server/tests/api/users/user-notifications.ts +++ b/server/tests/api/notifications/user-notifications.ts | |||
@@ -4,25 +4,30 @@ import * as chai from 'chai' | |||
4 | import 'mocha' | 4 | import 'mocha' |
5 | import { | 5 | import { |
6 | addVideoToBlacklist, | 6 | addVideoToBlacklist, |
7 | cleanupTests, | ||
7 | createUser, | 8 | createUser, |
8 | doubleFollow, | 9 | doubleFollow, |
9 | flushAndRunMultipleServers, | 10 | flushAndRunMultipleServers, |
10 | flushTests, | 11 | follow, |
12 | getCustomConfig, | ||
11 | getMyUserInformation, | 13 | getMyUserInformation, |
14 | getVideoCommentThreads, | ||
15 | getVideoThreadComments, | ||
12 | immutableAssign, | 16 | immutableAssign, |
13 | registerUser, | 17 | registerUser, |
14 | removeVideoFromBlacklist, | 18 | removeVideoFromBlacklist, |
15 | reportVideoAbuse, | 19 | reportVideoAbuse, |
20 | updateCustomConfig, | ||
16 | updateMyUser, | 21 | updateMyUser, |
17 | updateVideo, | 22 | updateVideo, |
18 | updateVideoChannel, | 23 | updateVideoChannel, |
19 | userLogin, | 24 | userLogin, |
20 | wait | 25 | wait |
21 | } from '../../../../shared/utils' | 26 | } from '../../../../shared/extra-utils' |
22 | import { killallServers, ServerInfo, uploadVideo } from '../../../../shared/utils/index' | 27 | import { ServerInfo, uploadVideo } from '../../../../shared/extra-utils/index' |
23 | import { setAccessTokensToServers } from '../../../../shared/utils/users/login' | 28 | import { setAccessTokensToServers } from '../../../../shared/extra-utils/users/login' |
24 | import { waitJobs } from '../../../../shared/utils/server/jobs' | 29 | import { waitJobs } from '../../../../shared/extra-utils/server/jobs' |
25 | import { getUserNotificationSocket } from '../../../../shared/utils/socket/socket-io' | 30 | import { getUserNotificationSocket } from '../../../../shared/extra-utils/socket/socket-io' |
26 | import { | 31 | import { |
27 | checkCommentMention, | 32 | checkCommentMention, |
28 | CheckerBaseParams, | 33 | CheckerBaseParams, |
@@ -30,16 +35,18 @@ import { | |||
30 | checkNewActorFollow, | 35 | checkNewActorFollow, |
31 | checkNewBlacklistOnMyVideo, | 36 | checkNewBlacklistOnMyVideo, |
32 | checkNewCommentOnMyVideo, | 37 | checkNewCommentOnMyVideo, |
38 | checkNewInstanceFollower, | ||
33 | checkNewVideoAbuseForModerators, | 39 | checkNewVideoAbuseForModerators, |
34 | checkNewVideoFromSubscription, | 40 | checkNewVideoFromSubscription, |
35 | checkUserRegistered, | 41 | checkUserRegistered, |
42 | checkVideoAutoBlacklistForModerators, | ||
36 | checkVideoIsPublished, | 43 | checkVideoIsPublished, |
37 | getLastNotification, | 44 | getLastNotification, |
38 | getUserNotifications, | 45 | getUserNotifications, |
46 | markAsReadAllNotifications, | ||
39 | markAsReadNotifications, | 47 | markAsReadNotifications, |
40 | updateMyNotificationSettings, | 48 | updateMyNotificationSettings |
41 | markAsReadAllNotifications | 49 | } from '../../../../shared/extra-utils/users/user-notifications' |
42 | } from '../../../../shared/utils/users/user-notifications' | ||
43 | import { | 50 | import { |
44 | User, | 51 | User, |
45 | UserNotification, | 52 | UserNotification, |
@@ -47,13 +54,15 @@ import { | |||
47 | UserNotificationSettingValue, | 54 | UserNotificationSettingValue, |
48 | UserNotificationType | 55 | UserNotificationType |
49 | } from '../../../../shared/models/users' | 56 | } from '../../../../shared/models/users' |
50 | import { MockSmtpServer } from '../../../../shared/utils/miscs/email' | 57 | import { MockSmtpServer } from '../../../../shared/extra-utils/miscs/email' |
51 | import { addUserSubscription, removeUserSubscription } from '../../../../shared/utils/users/user-subscriptions' | 58 | import { addUserSubscription, removeUserSubscription } from '../../../../shared/extra-utils/users/user-subscriptions' |
52 | import { VideoPrivacy } from '../../../../shared/models/videos' | 59 | import { VideoPrivacy } from '../../../../shared/models/videos' |
53 | import { getBadVideoUrl, getYoutubeVideoUrl, importVideo } from '../../../../shared/utils/videos/video-imports' | 60 | import { getBadVideoUrl, getYoutubeVideoUrl, importVideo } from '../../../../shared/extra-utils/videos/video-imports' |
54 | import { addVideoCommentReply, addVideoCommentThread } from '../../../../shared/utils/videos/video-comments' | 61 | import { addVideoCommentReply, addVideoCommentThread } from '../../../../shared/extra-utils/videos/video-comments' |
55 | import * as uuidv4 from 'uuid/v4' | 62 | import * as uuidv4 from 'uuid/v4' |
56 | import { addAccountToAccountBlocklist, removeAccountFromAccountBlocklist } from '../../../../shared/utils/users/blocklist' | 63 | import { addAccountToAccountBlocklist, removeAccountFromAccountBlocklist } from '../../../../shared/extra-utils/users/blocklist' |
64 | import { CustomConfig } from '../../../../shared/models/server' | ||
65 | import { VideoCommentThreadTree } from '../../../../shared/models/videos/video-comment.model' | ||
57 | 66 | ||
58 | const expect = chai.expect | 67 | const expect = chai.expect |
59 | 68 | ||
@@ -92,12 +101,14 @@ describe('Test users notifications', function () { | |||
92 | newVideoFromSubscription: UserNotificationSettingValue.WEB | UserNotificationSettingValue.EMAIL, | 101 | newVideoFromSubscription: UserNotificationSettingValue.WEB | UserNotificationSettingValue.EMAIL, |
93 | newCommentOnMyVideo: UserNotificationSettingValue.WEB | UserNotificationSettingValue.EMAIL, | 102 | newCommentOnMyVideo: UserNotificationSettingValue.WEB | UserNotificationSettingValue.EMAIL, |
94 | videoAbuseAsModerator: UserNotificationSettingValue.WEB | UserNotificationSettingValue.EMAIL, | 103 | videoAbuseAsModerator: UserNotificationSettingValue.WEB | UserNotificationSettingValue.EMAIL, |
104 | videoAutoBlacklistAsModerator: UserNotificationSettingValue.WEB | UserNotificationSettingValue.EMAIL, | ||
95 | blacklistOnMyVideo: UserNotificationSettingValue.WEB | UserNotificationSettingValue.EMAIL, | 105 | blacklistOnMyVideo: UserNotificationSettingValue.WEB | UserNotificationSettingValue.EMAIL, |
96 | myVideoImportFinished: UserNotificationSettingValue.WEB | UserNotificationSettingValue.EMAIL, | 106 | myVideoImportFinished: UserNotificationSettingValue.WEB | UserNotificationSettingValue.EMAIL, |
97 | myVideoPublished: UserNotificationSettingValue.WEB | UserNotificationSettingValue.EMAIL, | 107 | myVideoPublished: UserNotificationSettingValue.WEB | UserNotificationSettingValue.EMAIL, |
98 | commentMention: UserNotificationSettingValue.WEB | UserNotificationSettingValue.EMAIL, | 108 | commentMention: UserNotificationSettingValue.WEB | UserNotificationSettingValue.EMAIL, |
99 | newFollow: UserNotificationSettingValue.WEB | UserNotificationSettingValue.EMAIL, | 109 | newFollow: UserNotificationSettingValue.WEB | UserNotificationSettingValue.EMAIL, |
100 | newUserRegistration: UserNotificationSettingValue.WEB | UserNotificationSettingValue.EMAIL | 110 | newUserRegistration: UserNotificationSettingValue.WEB | UserNotificationSettingValue.EMAIL, |
111 | newInstanceFollower: UserNotificationSettingValue.WEB | UserNotificationSettingValue.EMAIL | ||
101 | } | 112 | } |
102 | 113 | ||
103 | before(async function () { | 114 | before(async function () { |
@@ -105,14 +116,12 @@ describe('Test users notifications', function () { | |||
105 | 116 | ||
106 | await MockSmtpServer.Instance.collectEmails(emails) | 117 | await MockSmtpServer.Instance.collectEmails(emails) |
107 | 118 | ||
108 | await flushTests() | ||
109 | |||
110 | const overrideConfig = { | 119 | const overrideConfig = { |
111 | smtp: { | 120 | smtp: { |
112 | hostname: 'localhost' | 121 | hostname: 'localhost' |
113 | } | 122 | } |
114 | } | 123 | } |
115 | servers = await flushAndRunMultipleServers(2, overrideConfig) | 124 | servers = await flushAndRunMultipleServers(3, overrideConfig) |
116 | 125 | ||
117 | // Get the access tokens | 126 | // Get the access tokens |
118 | await setAccessTokensToServers(servers) | 127 | await setAccessTokensToServers(servers) |
@@ -126,7 +135,13 @@ describe('Test users notifications', function () { | |||
126 | username: 'user_1', | 135 | username: 'user_1', |
127 | password: 'super password' | 136 | password: 'super password' |
128 | } | 137 | } |
129 | await createUser(servers[0].url, servers[0].accessToken, user.username, user.password, 10 * 1000 * 1000) | 138 | await createUser({ |
139 | url: servers[ 0 ].url, | ||
140 | accessToken: servers[ 0 ].accessToken, | ||
141 | username: user.username, | ||
142 | password: user.password, | ||
143 | videoQuota: 10 * 1000 * 1000 | ||
144 | }) | ||
130 | userAccessToken = await userLogin(servers[0], user) | 145 | userAccessToken = await userLogin(servers[0], user) |
131 | 146 | ||
132 | await updateMyNotificationSettings(servers[0].url, userAccessToken, allNotificationSettings) | 147 | await updateMyNotificationSettings(servers[0].url, userAccessToken, allNotificationSettings) |
@@ -165,6 +180,8 @@ describe('Test users notifications', function () { | |||
165 | }) | 180 | }) |
166 | 181 | ||
167 | it('Should not send notifications if the user does not follow the video publisher', async function () { | 182 | it('Should not send notifications if the user does not follow the video publisher', async function () { |
183 | this.timeout(10000) | ||
184 | |||
168 | await uploadVideoByLocalAccount(servers) | 185 | await uploadVideoByLocalAccount(servers) |
169 | 186 | ||
170 | const notification = await getLastNotification(servers[ 0 ].url, userAccessToken) | 187 | const notification = await getLastNotification(servers[ 0 ].url, userAccessToken) |
@@ -214,7 +231,7 @@ describe('Test users notifications', function () { | |||
214 | }) | 231 | }) |
215 | 232 | ||
216 | it('Should send a new video notification on a remote scheduled publication', async function () { | 233 | it('Should send a new video notification on a remote scheduled publication', async function () { |
217 | this.timeout(20000) | 234 | this.timeout(50000) |
218 | 235 | ||
219 | // In 2 seconds | 236 | // In 2 seconds |
220 | let updateAt = new Date(new Date().getTime() + 2000) | 237 | let updateAt = new Date(new Date().getTime() + 2000) |
@@ -236,7 +253,7 @@ describe('Test users notifications', function () { | |||
236 | it('Should not send a notification before the video is published', async function () { | 253 | it('Should not send a notification before the video is published', async function () { |
237 | this.timeout(20000) | 254 | this.timeout(20000) |
238 | 255 | ||
239 | let updateAt = new Date(new Date().getTime() + 100000) | 256 | let updateAt = new Date(new Date().getTime() + 1000000) |
240 | 257 | ||
241 | const data = { | 258 | const data = { |
242 | privacy: VideoPrivacy.PRIVATE, | 259 | privacy: VideoPrivacy.PRIVATE, |
@@ -303,7 +320,7 @@ describe('Test users notifications', function () { | |||
303 | }) | 320 | }) |
304 | 321 | ||
305 | it('Should send a new video notification after a video import', async function () { | 322 | it('Should send a new video notification after a video import', async function () { |
306 | this.timeout(30000) | 323 | this.timeout(100000) |
307 | 324 | ||
308 | const name = 'video import ' + uuidv4() | 325 | const name = 'video import ' + uuidv4() |
309 | 326 | ||
@@ -398,10 +415,14 @@ describe('Test users notifications', function () { | |||
398 | 415 | ||
399 | await waitJobs(servers) | 416 | await waitJobs(servers) |
400 | 417 | ||
401 | const resComment = await addVideoCommentThread(servers[1].url, servers[1].accessToken, uuid, 'comment') | 418 | await addVideoCommentThread(servers[1].url, servers[1].accessToken, uuid, 'comment') |
402 | const commentId = resComment.body.comment.id | ||
403 | 419 | ||
404 | await waitJobs(servers) | 420 | await waitJobs(servers) |
421 | |||
422 | const resComment = await getVideoCommentThreads(servers[0].url, uuid, 0, 5) | ||
423 | expect(resComment.body.data).to.have.lengthOf(1) | ||
424 | const commentId = resComment.body.data[0].id | ||
425 | |||
405 | await checkNewCommentOnMyVideo(baseParams, uuid, commentId, commentId, 'presence') | 426 | await checkNewCommentOnMyVideo(baseParams, uuid, commentId, commentId, 'presence') |
406 | }) | 427 | }) |
407 | 428 | ||
@@ -428,13 +449,24 @@ describe('Test users notifications', function () { | |||
428 | const uuid = resVideo.body.video.uuid | 449 | const uuid = resVideo.body.video.uuid |
429 | await waitJobs(servers) | 450 | await waitJobs(servers) |
430 | 451 | ||
431 | const resThread = await addVideoCommentThread(servers[1].url, servers[1].accessToken, uuid, 'comment') | 452 | { |
432 | const threadId = resThread.body.comment.id | 453 | const resThread = await addVideoCommentThread(servers[ 1 ].url, servers[ 1 ].accessToken, uuid, 'comment') |
433 | 454 | const threadId = resThread.body.comment.id | |
434 | const resComment = await addVideoCommentReply(servers[1].url, servers[1].accessToken, uuid, threadId, 'reply') | 455 | await addVideoCommentReply(servers[ 1 ].url, servers[ 1 ].accessToken, uuid, threadId, 'reply') |
435 | const commentId = resComment.body.comment.id | 456 | } |
436 | 457 | ||
437 | await waitJobs(servers) | 458 | await waitJobs(servers) |
459 | |||
460 | const resThread = await getVideoCommentThreads(servers[0].url, uuid, 0, 5) | ||
461 | expect(resThread.body.data).to.have.lengthOf(1) | ||
462 | const threadId = resThread.body.data[0].id | ||
463 | |||
464 | const resComments = await getVideoThreadComments(servers[0].url, uuid, threadId) | ||
465 | const tree = resComments.body as VideoCommentThreadTree | ||
466 | |||
467 | expect(tree.children).to.have.lengthOf(1) | ||
468 | const commentId = tree.children[0].comment.id | ||
469 | |||
438 | await checkNewCommentOnMyVideo(baseParams, uuid, commentId, threadId, 'presence') | 470 | await checkNewCommentOnMyVideo(baseParams, uuid, commentId, threadId, 'presence') |
439 | }) | 471 | }) |
440 | }) | 472 | }) |
@@ -547,17 +579,27 @@ describe('Test users notifications', function () { | |||
547 | 579 | ||
548 | await waitJobs(servers) | 580 | await waitJobs(servers) |
549 | const resThread = await addVideoCommentThread(servers[1].url, servers[1].accessToken, uuid, 'hello @user_1@localhost:9001 1') | 581 | const resThread = await addVideoCommentThread(servers[1].url, servers[1].accessToken, uuid, 'hello @user_1@localhost:9001 1') |
550 | const threadId = resThread.body.comment.id | 582 | const server2ThreadId = resThread.body.comment.id |
551 | 583 | ||
552 | await waitJobs(servers) | 584 | await waitJobs(servers) |
553 | await checkCommentMention(baseParams, uuid, threadId, threadId, 'super root 2 name', 'presence') | 585 | |
586 | const resThread2 = await getVideoCommentThreads(servers[0].url, uuid, 0, 5) | ||
587 | expect(resThread2.body.data).to.have.lengthOf(1) | ||
588 | const server1ThreadId = resThread2.body.data[0].id | ||
589 | await checkCommentMention(baseParams, uuid, server1ThreadId, server1ThreadId, 'super root 2 name', 'presence') | ||
554 | 590 | ||
555 | const text = '@user_1@localhost:9001 hello 2 @root@localhost:9001' | 591 | const text = '@user_1@localhost:9001 hello 2 @root@localhost:9001' |
556 | const resComment = await addVideoCommentReply(servers[1].url, servers[1].accessToken, uuid, threadId, text) | 592 | await addVideoCommentReply(servers[1].url, servers[1].accessToken, uuid, server2ThreadId, text) |
557 | const commentId = resComment.body.comment.id | ||
558 | 593 | ||
559 | await waitJobs(servers) | 594 | await waitJobs(servers) |
560 | await checkCommentMention(baseParams, uuid, commentId, threadId, 'super root 2 name', 'presence') | 595 | |
596 | const resComments = await getVideoThreadComments(servers[0].url, uuid, server1ThreadId) | ||
597 | const tree = resComments.body as VideoCommentThreadTree | ||
598 | |||
599 | expect(tree.children).to.have.lengthOf(1) | ||
600 | const commentId = tree.children[0].comment.id | ||
601 | |||
602 | await checkCommentMention(baseParams, uuid, commentId, server1ThreadId, 'super root 2 name', 'presence') | ||
561 | }) | 603 | }) |
562 | }) | 604 | }) |
563 | 605 | ||
@@ -658,6 +700,8 @@ describe('Test users notifications', function () { | |||
658 | }) | 700 | }) |
659 | 701 | ||
660 | it('Should not send a notification if transcoding is not enabled', async function () { | 702 | it('Should not send a notification if transcoding is not enabled', async function () { |
703 | this.timeout(10000) | ||
704 | |||
661 | const { name, uuid } = await uploadVideoByLocalAccount(servers) | 705 | const { name, uuid } = await uploadVideoByLocalAccount(servers) |
662 | await waitJobs(servers) | 706 | await waitJobs(servers) |
663 | 707 | ||
@@ -731,6 +775,24 @@ describe('Test users notifications', function () { | |||
731 | await wait(6000) | 775 | await wait(6000) |
732 | await checkVideoIsPublished(baseParams, name, uuid, 'presence') | 776 | await checkVideoIsPublished(baseParams, name, uuid, 'presence') |
733 | }) | 777 | }) |
778 | |||
779 | it('Should not send a notification before the video is published', async function () { | ||
780 | this.timeout(20000) | ||
781 | |||
782 | let updateAt = new Date(new Date().getTime() + 100000) | ||
783 | |||
784 | const data = { | ||
785 | privacy: VideoPrivacy.PRIVATE, | ||
786 | scheduleUpdate: { | ||
787 | updateAt: updateAt.toISOString(), | ||
788 | privacy: VideoPrivacy.PUBLIC | ||
789 | } | ||
790 | } | ||
791 | const { name, uuid } = await uploadVideoByRemoteAccount(servers, data) | ||
792 | |||
793 | await wait(6000) | ||
794 | await checkVideoIsPublished(baseParams, name, uuid, 'absence') | ||
795 | }) | ||
734 | }) | 796 | }) |
735 | 797 | ||
736 | describe('My video is imported', function () { | 798 | describe('My video is imported', function () { |
@@ -795,6 +857,8 @@ describe('Test users notifications', function () { | |||
795 | }) | 857 | }) |
796 | 858 | ||
797 | it('Should send a notification only to moderators when a user registers on the instance', async function () { | 859 | it('Should send a notification only to moderators when a user registers on the instance', async function () { |
860 | this.timeout(10000) | ||
861 | |||
798 | await registerUser(servers[0].url, 'user_45', 'password') | 862 | await registerUser(servers[0].url, 'user_45', 'password') |
799 | 863 | ||
800 | await waitJobs(servers) | 864 | await waitJobs(servers) |
@@ -806,6 +870,32 @@ describe('Test users notifications', function () { | |||
806 | }) | 870 | }) |
807 | }) | 871 | }) |
808 | 872 | ||
873 | describe('New instance follower', function () { | ||
874 | let baseParams: CheckerBaseParams | ||
875 | |||
876 | before(async () => { | ||
877 | baseParams = { | ||
878 | server: servers[0], | ||
879 | emails, | ||
880 | socketNotifications: adminNotifications, | ||
881 | token: servers[0].accessToken | ||
882 | } | ||
883 | }) | ||
884 | |||
885 | it('Should send a notification only to admin when there is a new instance follower', async function () { | ||
886 | this.timeout(20000) | ||
887 | |||
888 | await follow(servers[2].url, [ servers[0].url ], servers[2].accessToken) | ||
889 | |||
890 | await waitJobs(servers) | ||
891 | |||
892 | await checkNewInstanceFollower(baseParams, 'localhost:9003', 'presence') | ||
893 | |||
894 | const userOverride = { socketNotifications: userNotifications, token: userAccessToken, check: { web: true, mail: false } } | ||
895 | await checkNewInstanceFollower(immutableAssign(baseParams, userOverride), 'localhost:9003', 'absence') | ||
896 | }) | ||
897 | }) | ||
898 | |||
809 | describe('New actor follow', function () { | 899 | describe('New actor follow', function () { |
810 | let baseParams: CheckerBaseParams | 900 | let baseParams: CheckerBaseParams |
811 | let myChannelName = 'super channel name' | 901 | let myChannelName = 'super channel name' |
@@ -863,6 +953,8 @@ describe('Test users notifications', function () { | |||
863 | }) | 953 | }) |
864 | 954 | ||
865 | it('Should notify when a local account is following one of our channel', async function () { | 955 | it('Should notify when a local account is following one of our channel', async function () { |
956 | this.timeout(10000) | ||
957 | |||
866 | await addUserSubscription(servers[0].url, servers[0].accessToken, 'user_1@localhost:9001') | 958 | await addUserSubscription(servers[0].url, servers[0].accessToken, 'user_1@localhost:9001') |
867 | 959 | ||
868 | await waitJobs(servers) | 960 | await waitJobs(servers) |
@@ -871,6 +963,8 @@ describe('Test users notifications', function () { | |||
871 | }) | 963 | }) |
872 | 964 | ||
873 | it('Should notify when a remote account is following one of our channel', async function () { | 965 | it('Should notify when a remote account is following one of our channel', async function () { |
966 | this.timeout(10000) | ||
967 | |||
874 | await addUserSubscription(servers[1].url, servers[1].accessToken, 'user_1@localhost:9001') | 968 | await addUserSubscription(servers[1].url, servers[1].accessToken, 'user_1@localhost:9001') |
875 | 969 | ||
876 | await waitJobs(servers) | 970 | await waitJobs(servers) |
@@ -879,6 +973,180 @@ describe('Test users notifications', function () { | |||
879 | }) | 973 | }) |
880 | }) | 974 | }) |
881 | 975 | ||
976 | describe('Video-related notifications when video auto-blacklist is enabled', function () { | ||
977 | let userBaseParams: CheckerBaseParams | ||
978 | let adminBaseParamsServer1: CheckerBaseParams | ||
979 | let adminBaseParamsServer2: CheckerBaseParams | ||
980 | let videoUUID: string | ||
981 | let videoName: string | ||
982 | let currentCustomConfig: CustomConfig | ||
983 | |||
984 | before(async () => { | ||
985 | |||
986 | adminBaseParamsServer1 = { | ||
987 | server: servers[0], | ||
988 | emails, | ||
989 | socketNotifications: adminNotifications, | ||
990 | token: servers[0].accessToken | ||
991 | } | ||
992 | |||
993 | adminBaseParamsServer2 = { | ||
994 | server: servers[1], | ||
995 | emails, | ||
996 | socketNotifications: adminNotificationsServer2, | ||
997 | token: servers[1].accessToken | ||
998 | } | ||
999 | |||
1000 | userBaseParams = { | ||
1001 | server: servers[0], | ||
1002 | emails, | ||
1003 | socketNotifications: userNotifications, | ||
1004 | token: userAccessToken | ||
1005 | } | ||
1006 | |||
1007 | const resCustomConfig = await getCustomConfig(servers[0].url, servers[0].accessToken) | ||
1008 | currentCustomConfig = resCustomConfig.body | ||
1009 | const autoBlacklistTestsCustomConfig = immutableAssign(currentCustomConfig, { | ||
1010 | autoBlacklist: { | ||
1011 | videos: { | ||
1012 | ofUsers: { | ||
1013 | enabled: true | ||
1014 | } | ||
1015 | } | ||
1016 | } | ||
1017 | }) | ||
1018 | // enable transcoding otherwise own publish notification after transcoding not expected | ||
1019 | autoBlacklistTestsCustomConfig.transcoding.enabled = true | ||
1020 | await updateCustomConfig(servers[0].url, servers[0].accessToken, autoBlacklistTestsCustomConfig) | ||
1021 | |||
1022 | await addUserSubscription(servers[0].url, servers[0].accessToken, 'user_1_channel@localhost:9001') | ||
1023 | await addUserSubscription(servers[1].url, servers[1].accessToken, 'user_1_channel@localhost:9001') | ||
1024 | |||
1025 | }) | ||
1026 | |||
1027 | it('Should send notification to moderators on new video with auto-blacklist', async function () { | ||
1028 | this.timeout(20000) | ||
1029 | |||
1030 | videoName = 'video with auto-blacklist ' + uuidv4() | ||
1031 | const resVideo = await uploadVideo(servers[0].url, userAccessToken, { name: videoName }) | ||
1032 | videoUUID = resVideo.body.video.uuid | ||
1033 | |||
1034 | await waitJobs(servers) | ||
1035 | await checkVideoAutoBlacklistForModerators(adminBaseParamsServer1, videoUUID, videoName, 'presence') | ||
1036 | }) | ||
1037 | |||
1038 | it('Should not send video publish notification if auto-blacklisted', async function () { | ||
1039 | await checkVideoIsPublished(userBaseParams, videoName, videoUUID, 'absence') | ||
1040 | }) | ||
1041 | |||
1042 | it('Should not send a local user subscription notification if auto-blacklisted', async function () { | ||
1043 | await checkNewVideoFromSubscription(adminBaseParamsServer1, videoName, videoUUID, 'absence') | ||
1044 | }) | ||
1045 | |||
1046 | it('Should not send a remote user subscription notification if auto-blacklisted', async function () { | ||
1047 | await checkNewVideoFromSubscription(adminBaseParamsServer2, videoName, videoUUID, 'absence') | ||
1048 | }) | ||
1049 | |||
1050 | it('Should send video published and unblacklist after video unblacklisted', async function () { | ||
1051 | this.timeout(20000) | ||
1052 | |||
1053 | await removeVideoFromBlacklist(servers[0].url, servers[0].accessToken, videoUUID) | ||
1054 | |||
1055 | await waitJobs(servers) | ||
1056 | |||
1057 | // FIXME: Can't test as two notifications sent to same user and util only checks last one | ||
1058 | // One notification might be better anyways | ||
1059 | // await checkNewBlacklistOnMyVideo(userBaseParams, videoUUID, videoName, 'unblacklist') | ||
1060 | // await checkVideoIsPublished(userBaseParams, videoName, videoUUID, 'presence') | ||
1061 | }) | ||
1062 | |||
1063 | it('Should send a local user subscription notification after removed from blacklist', async function () { | ||
1064 | await checkNewVideoFromSubscription(adminBaseParamsServer1, videoName, videoUUID, 'presence') | ||
1065 | }) | ||
1066 | |||
1067 | it('Should send a remote user subscription notification after removed from blacklist', async function () { | ||
1068 | await checkNewVideoFromSubscription(adminBaseParamsServer2, videoName, videoUUID, 'presence') | ||
1069 | }) | ||
1070 | |||
1071 | it('Should send unblacklist but not published/subscription notes after unblacklisted if scheduled update pending', async function () { | ||
1072 | this.timeout(20000) | ||
1073 | |||
1074 | let updateAt = new Date(new Date().getTime() + 100000) | ||
1075 | |||
1076 | const name = 'video with auto-blacklist and future schedule ' + uuidv4() | ||
1077 | |||
1078 | const data = { | ||
1079 | name, | ||
1080 | privacy: VideoPrivacy.PRIVATE, | ||
1081 | scheduleUpdate: { | ||
1082 | updateAt: updateAt.toISOString(), | ||
1083 | privacy: VideoPrivacy.PUBLIC | ||
1084 | } | ||
1085 | } | ||
1086 | |||
1087 | const resVideo = await uploadVideo(servers[0].url, userAccessToken, data) | ||
1088 | const uuid = resVideo.body.video.uuid | ||
1089 | |||
1090 | await removeVideoFromBlacklist(servers[0].url, servers[0].accessToken, uuid) | ||
1091 | |||
1092 | await waitJobs(servers) | ||
1093 | await checkNewBlacklistOnMyVideo(userBaseParams, uuid, name, 'unblacklist') | ||
1094 | |||
1095 | // FIXME: Can't test absence as two notifications sent to same user and util only checks last one | ||
1096 | // One notification might be better anyways | ||
1097 | // await checkVideoIsPublished(userBaseParams, name, uuid, 'absence') | ||
1098 | |||
1099 | await checkNewVideoFromSubscription(adminBaseParamsServer1, name, uuid, 'absence') | ||
1100 | await checkNewVideoFromSubscription(adminBaseParamsServer2, name, uuid, 'absence') | ||
1101 | }) | ||
1102 | |||
1103 | it('Should not send publish/subscription notifications after scheduled update if video still auto-blacklisted', async function () { | ||
1104 | this.timeout(20000) | ||
1105 | |||
1106 | // In 2 seconds | ||
1107 | let updateAt = new Date(new Date().getTime() + 2000) | ||
1108 | |||
1109 | const name = 'video with schedule done and still auto-blacklisted ' + uuidv4() | ||
1110 | |||
1111 | const data = { | ||
1112 | name, | ||
1113 | privacy: VideoPrivacy.PRIVATE, | ||
1114 | scheduleUpdate: { | ||
1115 | updateAt: updateAt.toISOString(), | ||
1116 | privacy: VideoPrivacy.PUBLIC | ||
1117 | } | ||
1118 | } | ||
1119 | |||
1120 | const resVideo = await uploadVideo(servers[0].url, userAccessToken, data) | ||
1121 | const uuid = resVideo.body.video.uuid | ||
1122 | |||
1123 | await wait(6000) | ||
1124 | await checkVideoIsPublished(userBaseParams, name, uuid, 'absence') | ||
1125 | await checkNewVideoFromSubscription(adminBaseParamsServer1, name, uuid, 'absence') | ||
1126 | await checkNewVideoFromSubscription(adminBaseParamsServer2, name, uuid, 'absence') | ||
1127 | }) | ||
1128 | |||
1129 | it('Should not send a notification to moderators on new video without auto-blacklist', async function () { | ||
1130 | this.timeout(20000) | ||
1131 | |||
1132 | const name = 'video without auto-blacklist ' + uuidv4() | ||
1133 | |||
1134 | // admin with blacklist right will not be auto-blacklisted | ||
1135 | const resVideo = await uploadVideo(servers[0].url, servers[0].accessToken, { name }) | ||
1136 | const uuid = resVideo.body.video.uuid | ||
1137 | |||
1138 | await waitJobs(servers) | ||
1139 | await checkVideoAutoBlacklistForModerators(adminBaseParamsServer1, uuid, name, 'absence') | ||
1140 | }) | ||
1141 | |||
1142 | after(async () => { | ||
1143 | await updateCustomConfig(servers[0].url, servers[0].accessToken, currentCustomConfig) | ||
1144 | |||
1145 | await removeUserSubscription(servers[0].url, servers[0].accessToken, 'user_1_channel@localhost:9001') | ||
1146 | await removeUserSubscription(servers[1].url, servers[1].accessToken, 'user_1_channel@localhost:9001') | ||
1147 | }) | ||
1148 | }) | ||
1149 | |||
882 | describe('Mark as read', function () { | 1150 | describe('Mark as read', function () { |
883 | it('Should mark as read some notifications', async function () { | 1151 | it('Should mark as read some notifications', async function () { |
884 | const res = await getUserNotifications(servers[ 0 ].url, userAccessToken, 2, 3) | 1152 | const res = await getUserNotifications(servers[ 0 ].url, userAccessToken, 2, 3) |
@@ -940,6 +1208,8 @@ describe('Test users notifications', function () { | |||
940 | }) | 1208 | }) |
941 | 1209 | ||
942 | it('Should not have notifications', async function () { | 1210 | it('Should not have notifications', async function () { |
1211 | this.timeout(20000) | ||
1212 | |||
943 | await updateMyNotificationSettings(servers[0].url, userAccessToken, immutableAssign(allNotificationSettings, { | 1213 | await updateMyNotificationSettings(servers[0].url, userAccessToken, immutableAssign(allNotificationSettings, { |
944 | newVideoFromSubscription: UserNotificationSettingValue.NONE | 1214 | newVideoFromSubscription: UserNotificationSettingValue.NONE |
945 | })) | 1215 | })) |
@@ -957,6 +1227,8 @@ describe('Test users notifications', function () { | |||
957 | }) | 1227 | }) |
958 | 1228 | ||
959 | it('Should only have web notifications', async function () { | 1229 | it('Should only have web notifications', async function () { |
1230 | this.timeout(20000) | ||
1231 | |||
960 | await updateMyNotificationSettings(servers[0].url, userAccessToken, immutableAssign(allNotificationSettings, { | 1232 | await updateMyNotificationSettings(servers[0].url, userAccessToken, immutableAssign(allNotificationSettings, { |
961 | newVideoFromSubscription: UserNotificationSettingValue.WEB | 1233 | newVideoFromSubscription: UserNotificationSettingValue.WEB |
962 | })) | 1234 | })) |
@@ -981,6 +1253,8 @@ describe('Test users notifications', function () { | |||
981 | }) | 1253 | }) |
982 | 1254 | ||
983 | it('Should only have mail notifications', async function () { | 1255 | it('Should only have mail notifications', async function () { |
1256 | this.timeout(20000) | ||
1257 | |||
984 | await updateMyNotificationSettings(servers[0].url, userAccessToken, immutableAssign(allNotificationSettings, { | 1258 | await updateMyNotificationSettings(servers[0].url, userAccessToken, immutableAssign(allNotificationSettings, { |
985 | newVideoFromSubscription: UserNotificationSettingValue.EMAIL | 1259 | newVideoFromSubscription: UserNotificationSettingValue.EMAIL |
986 | })) | 1260 | })) |
@@ -1005,6 +1279,8 @@ describe('Test users notifications', function () { | |||
1005 | }) | 1279 | }) |
1006 | 1280 | ||
1007 | it('Should have email and web notifications', async function () { | 1281 | it('Should have email and web notifications', async function () { |
1282 | this.timeout(20000) | ||
1283 | |||
1008 | await updateMyNotificationSettings(servers[0].url, userAccessToken, immutableAssign(allNotificationSettings, { | 1284 | await updateMyNotificationSettings(servers[0].url, userAccessToken, immutableAssign(allNotificationSettings, { |
1009 | newVideoFromSubscription: UserNotificationSettingValue.WEB | UserNotificationSettingValue.EMAIL | 1285 | newVideoFromSubscription: UserNotificationSettingValue.WEB | UserNotificationSettingValue.EMAIL |
1010 | })) | 1286 | })) |
@@ -1026,6 +1302,6 @@ describe('Test users notifications', function () { | |||
1026 | after(async function () { | 1302 | after(async function () { |
1027 | MockSmtpServer.Instance.kill() | 1303 | MockSmtpServer.Instance.kill() |
1028 | 1304 | ||
1029 | killallServers(servers) | 1305 | await cleanupTests(servers) |
1030 | }) | 1306 | }) |
1031 | }) | 1307 | }) |
diff --git a/server/tests/api/redundancy/redundancy.ts b/server/tests/api/redundancy/redundancy.ts index 9d3ce8153..e31329c25 100644 --- a/server/tests/api/redundancy/redundancy.ts +++ b/server/tests/api/redundancy/redundancy.ts | |||
@@ -4,30 +4,36 @@ import * as chai from 'chai' | |||
4 | import 'mocha' | 4 | import 'mocha' |
5 | import { VideoDetails } from '../../../../shared/models/videos' | 5 | import { VideoDetails } from '../../../../shared/models/videos' |
6 | import { | 6 | import { |
7 | checkSegmentHash, | ||
8 | checkVideoFilesWereRemoved, cleanupTests, | ||
7 | doubleFollow, | 9 | doubleFollow, |
8 | flushAndRunMultipleServers, | 10 | flushAndRunMultipleServers, |
9 | getFollowingListPaginationAndSort, | 11 | getFollowingListPaginationAndSort, |
10 | getVideo, | 12 | getVideo, |
13 | getVideoWithToken, | ||
11 | immutableAssign, | 14 | immutableAssign, |
12 | killallServers, makeGetRequest, | 15 | killallServers, |
16 | makeGetRequest, | ||
17 | removeVideo, | ||
18 | reRunServer, | ||
13 | root, | 19 | root, |
14 | ServerInfo, | 20 | ServerInfo, |
15 | setAccessTokensToServers, unfollow, | 21 | setAccessTokensToServers, |
22 | unfollow, | ||
16 | uploadVideo, | 23 | uploadVideo, |
17 | viewVideo, | 24 | viewVideo, |
18 | wait, | 25 | wait, |
19 | waitUntilLog, | 26 | waitUntilLog |
20 | checkVideoFilesWereRemoved, removeVideo, getVideoWithToken | 27 | } from '../../../../shared/extra-utils' |
21 | } from '../../../../shared/utils' | 28 | import { waitJobs } from '../../../../shared/extra-utils/server/jobs' |
22 | import { waitJobs } from '../../../../shared/utils/server/jobs' | ||
23 | 29 | ||
24 | import * as magnetUtil from 'magnet-uri' | 30 | import * as magnetUtil from 'magnet-uri' |
25 | import { updateRedundancy } from '../../../../shared/utils/server/redundancy' | 31 | import { updateRedundancy } from '../../../../shared/extra-utils/server/redundancy' |
26 | import { ActorFollow } from '../../../../shared/models/actors' | 32 | import { ActorFollow } from '../../../../shared/models/actors' |
27 | import { readdir } from 'fs-extra' | 33 | import { readdir } from 'fs-extra' |
28 | import { join } from 'path' | 34 | import { join } from 'path' |
29 | import { VideoRedundancyStrategy } from '../../../../shared/models/redundancy' | 35 | import { VideoRedundancyStrategy } from '../../../../shared/models/redundancy' |
30 | import { getStats } from '../../../../shared/utils/server/stats' | 36 | import { getStats } from '../../../../shared/extra-utils/server/stats' |
31 | import { ServerStats } from '../../../../shared/models/server/server-stats.model' | 37 | import { ServerStats } from '../../../../shared/models/server/server-stats.model' |
32 | 38 | ||
33 | const expect = chai.expect | 39 | const expect = chai.expect |
@@ -46,8 +52,13 @@ function checkMagnetWebseeds (file: { magnetUri: string, resolution: { id: numbe | |||
46 | expect(parsed.urlList).to.have.lengthOf(baseWebseeds.length) | 52 | expect(parsed.urlList).to.have.lengthOf(baseWebseeds.length) |
47 | } | 53 | } |
48 | 54 | ||
49 | async function runServers (strategy: VideoRedundancyStrategy, additionalParams: any = {}) { | 55 | async function flushAndRunServers (strategy: VideoRedundancyStrategy, additionalParams: any = {}) { |
50 | const config = { | 56 | const config = { |
57 | transcoding: { | ||
58 | hls: { | ||
59 | enabled: true | ||
60 | } | ||
61 | }, | ||
51 | redundancy: { | 62 | redundancy: { |
52 | videos: { | 63 | videos: { |
53 | check_interval: '5 seconds', | 64 | check_interval: '5 seconds', |
@@ -85,7 +96,7 @@ async function runServers (strategy: VideoRedundancyStrategy, additionalParams: | |||
85 | await waitJobs(servers) | 96 | await waitJobs(servers) |
86 | } | 97 | } |
87 | 98 | ||
88 | async function check1WebSeed (strategy: VideoRedundancyStrategy, videoUUID?: string) { | 99 | async function check1WebSeed (videoUUID?: string) { |
89 | if (!videoUUID) videoUUID = video1Server2UUID | 100 | if (!videoUUID) videoUUID = video1Server2UUID |
90 | 101 | ||
91 | const webseeds = [ | 102 | const webseeds = [ |
@@ -93,47 +104,17 @@ async function check1WebSeed (strategy: VideoRedundancyStrategy, videoUUID?: str | |||
93 | ] | 104 | ] |
94 | 105 | ||
95 | for (const server of servers) { | 106 | for (const server of servers) { |
96 | { | 107 | // With token to avoid issues with video follow constraints |
97 | // With token to avoid issues with video follow constraints | 108 | const res = await getVideoWithToken(server.url, server.accessToken, videoUUID) |
98 | const res = await getVideoWithToken(server.url, server.accessToken, videoUUID) | ||
99 | 109 | ||
100 | const video: VideoDetails = res.body | 110 | const video: VideoDetails = res.body |
101 | for (const f of video.files) { | 111 | for (const f of video.files) { |
102 | checkMagnetWebseeds(f, webseeds, server) | 112 | checkMagnetWebseeds(f, webseeds, server) |
103 | } | ||
104 | } | 113 | } |
105 | } | 114 | } |
106 | } | 115 | } |
107 | 116 | ||
108 | async function checkStatsWith2Webseed (strategy: VideoRedundancyStrategy) { | 117 | async function check2Webseeds (videoUUID?: string) { |
109 | const res = await getStats(servers[0].url) | ||
110 | const data: ServerStats = res.body | ||
111 | |||
112 | expect(data.videosRedundancy).to.have.lengthOf(1) | ||
113 | const stat = data.videosRedundancy[0] | ||
114 | |||
115 | expect(stat.strategy).to.equal(strategy) | ||
116 | expect(stat.totalSize).to.equal(204800) | ||
117 | expect(stat.totalUsed).to.be.at.least(1).and.below(204801) | ||
118 | expect(stat.totalVideoFiles).to.equal(4) | ||
119 | expect(stat.totalVideos).to.equal(1) | ||
120 | } | ||
121 | |||
122 | async function checkStatsWith1Webseed (strategy: VideoRedundancyStrategy) { | ||
123 | const res = await getStats(servers[0].url) | ||
124 | const data: ServerStats = res.body | ||
125 | |||
126 | expect(data.videosRedundancy).to.have.lengthOf(1) | ||
127 | |||
128 | const stat = data.videosRedundancy[0] | ||
129 | expect(stat.strategy).to.equal(strategy) | ||
130 | expect(stat.totalSize).to.equal(204800) | ||
131 | expect(stat.totalUsed).to.equal(0) | ||
132 | expect(stat.totalVideoFiles).to.equal(0) | ||
133 | expect(stat.totalVideos).to.equal(0) | ||
134 | } | ||
135 | |||
136 | async function check2Webseeds (strategy: VideoRedundancyStrategy, videoUUID?: string) { | ||
137 | if (!videoUUID) videoUUID = video1Server2UUID | 118 | if (!videoUUID) videoUUID = video1Server2UUID |
138 | 119 | ||
139 | const webseeds = [ | 120 | const webseeds = [ |
@@ -158,7 +139,7 @@ async function check2Webseeds (strategy: VideoRedundancyStrategy, videoUUID?: st | |||
158 | await makeGetRequest({ | 139 | await makeGetRequest({ |
159 | url: servers[1].url, | 140 | url: servers[1].url, |
160 | statusCodeExpected: 200, | 141 | statusCodeExpected: 200, |
161 | path: '/static/webseed/' + `${videoUUID}-${file.resolution.id}.mp4`, | 142 | path: `/static/webseed/${videoUUID}-${file.resolution.id}.mp4`, |
162 | contentType: null | 143 | contentType: null |
163 | }) | 144 | }) |
164 | } | 145 | } |
@@ -174,6 +155,85 @@ async function check2Webseeds (strategy: VideoRedundancyStrategy, videoUUID?: st | |||
174 | } | 155 | } |
175 | } | 156 | } |
176 | 157 | ||
158 | async function check0PlaylistRedundancies (videoUUID?: string) { | ||
159 | if (!videoUUID) videoUUID = video1Server2UUID | ||
160 | |||
161 | for (const server of servers) { | ||
162 | // With token to avoid issues with video follow constraints | ||
163 | const res = await getVideoWithToken(server.url, server.accessToken, videoUUID) | ||
164 | const video: VideoDetails = res.body | ||
165 | |||
166 | expect(video.streamingPlaylists).to.be.an('array') | ||
167 | expect(video.streamingPlaylists).to.have.lengthOf(1) | ||
168 | expect(video.streamingPlaylists[0].redundancies).to.have.lengthOf(0) | ||
169 | } | ||
170 | } | ||
171 | |||
172 | async function check1PlaylistRedundancies (videoUUID?: string) { | ||
173 | if (!videoUUID) videoUUID = video1Server2UUID | ||
174 | |||
175 | for (const server of servers) { | ||
176 | const res = await getVideo(server.url, videoUUID) | ||
177 | const video: VideoDetails = res.body | ||
178 | |||
179 | expect(video.streamingPlaylists).to.have.lengthOf(1) | ||
180 | expect(video.streamingPlaylists[0].redundancies).to.have.lengthOf(1) | ||
181 | |||
182 | const redundancy = video.streamingPlaylists[0].redundancies[0] | ||
183 | |||
184 | expect(redundancy.baseUrl).to.equal(servers[0].url + '/static/redundancy/hls/' + videoUUID) | ||
185 | } | ||
186 | |||
187 | const baseUrlPlaylist = servers[1].url + '/static/streaming-playlists/hls' | ||
188 | const baseUrlSegment = servers[0].url + '/static/redundancy/hls' | ||
189 | |||
190 | const res = await getVideo(servers[0].url, videoUUID) | ||
191 | const hlsPlaylist = (res.body as VideoDetails).streamingPlaylists[0] | ||
192 | |||
193 | for (const resolution of [ 240, 360, 480, 720 ]) { | ||
194 | await checkSegmentHash(baseUrlPlaylist, baseUrlSegment, videoUUID, resolution, hlsPlaylist) | ||
195 | } | ||
196 | |||
197 | for (const directory of [ 'test1/redundancy/hls', 'test2/streaming-playlists/hls' ]) { | ||
198 | const files = await readdir(join(root(), directory, videoUUID)) | ||
199 | expect(files).to.have.length.at.least(4) | ||
200 | |||
201 | for (const resolution of [ 240, 360, 480, 720 ]) { | ||
202 | const filename = `${videoUUID}-${resolution}-fragmented.mp4` | ||
203 | |||
204 | expect(files.find(f => f === filename)).to.not.be.undefined | ||
205 | } | ||
206 | } | ||
207 | } | ||
208 | |||
209 | async function checkStatsWith2Webseed (strategy: VideoRedundancyStrategy) { | ||
210 | const res = await getStats(servers[0].url) | ||
211 | const data: ServerStats = res.body | ||
212 | |||
213 | expect(data.videosRedundancy).to.have.lengthOf(1) | ||
214 | const stat = data.videosRedundancy[0] | ||
215 | |||
216 | expect(stat.strategy).to.equal(strategy) | ||
217 | expect(stat.totalSize).to.equal(204800) | ||
218 | expect(stat.totalUsed).to.be.at.least(1).and.below(204801) | ||
219 | expect(stat.totalVideoFiles).to.equal(4) | ||
220 | expect(stat.totalVideos).to.equal(1) | ||
221 | } | ||
222 | |||
223 | async function checkStatsWith1Webseed (strategy: VideoRedundancyStrategy) { | ||
224 | const res = await getStats(servers[0].url) | ||
225 | const data: ServerStats = res.body | ||
226 | |||
227 | expect(data.videosRedundancy).to.have.lengthOf(1) | ||
228 | |||
229 | const stat = data.videosRedundancy[0] | ||
230 | expect(stat.strategy).to.equal(strategy) | ||
231 | expect(stat.totalSize).to.equal(204800) | ||
232 | expect(stat.totalUsed).to.equal(0) | ||
233 | expect(stat.totalVideoFiles).to.equal(0) | ||
234 | expect(stat.totalVideos).to.equal(0) | ||
235 | } | ||
236 | |||
177 | async function enableRedundancyOnServer1 () { | 237 | async function enableRedundancyOnServer1 () { |
178 | await updateRedundancy(servers[ 0 ].url, servers[ 0 ].accessToken, servers[ 1 ].host, true) | 238 | await updateRedundancy(servers[ 0 ].url, servers[ 0 ].accessToken, servers[ 1 ].host, true) |
179 | 239 | ||
@@ -204,10 +264,6 @@ async function disableRedundancyOnServer1 () { | |||
204 | expect(server2.following.hostRedundancyAllowed).to.be.false | 264 | expect(server2.following.hostRedundancyAllowed).to.be.false |
205 | } | 265 | } |
206 | 266 | ||
207 | async function cleanServers () { | ||
208 | killallServers(servers) | ||
209 | } | ||
210 | |||
211 | describe('Test videos redundancy', function () { | 267 | describe('Test videos redundancy', function () { |
212 | 268 | ||
213 | describe('With most-views strategy', function () { | 269 | describe('With most-views strategy', function () { |
@@ -216,11 +272,12 @@ describe('Test videos redundancy', function () { | |||
216 | before(function () { | 272 | before(function () { |
217 | this.timeout(120000) | 273 | this.timeout(120000) |
218 | 274 | ||
219 | return runServers(strategy) | 275 | return flushAndRunServers(strategy) |
220 | }) | 276 | }) |
221 | 277 | ||
222 | it('Should have 1 webseed on the first video', async function () { | 278 | it('Should have 1 webseed on the first video', async function () { |
223 | await check1WebSeed(strategy) | 279 | await check1WebSeed() |
280 | await check0PlaylistRedundancies() | ||
224 | await checkStatsWith1Webseed(strategy) | 281 | await checkStatsWith1Webseed(strategy) |
225 | }) | 282 | }) |
226 | 283 | ||
@@ -229,31 +286,33 @@ describe('Test videos redundancy', function () { | |||
229 | }) | 286 | }) |
230 | 287 | ||
231 | it('Should have 2 webseeds on the first video', async function () { | 288 | it('Should have 2 webseeds on the first video', async function () { |
232 | this.timeout(40000) | 289 | this.timeout(80000) |
233 | 290 | ||
234 | await waitJobs(servers) | 291 | await waitJobs(servers) |
235 | await waitUntilLog(servers[0], 'Duplicated ', 4) | 292 | await waitUntilLog(servers[0], 'Duplicated ', 5) |
236 | await waitJobs(servers) | 293 | await waitJobs(servers) |
237 | 294 | ||
238 | await check2Webseeds(strategy) | 295 | await check2Webseeds() |
296 | await check1PlaylistRedundancies() | ||
239 | await checkStatsWith2Webseed(strategy) | 297 | await checkStatsWith2Webseed(strategy) |
240 | }) | 298 | }) |
241 | 299 | ||
242 | it('Should undo redundancy on server 1 and remove duplicated videos', async function () { | 300 | it('Should undo redundancy on server 1 and remove duplicated videos', async function () { |
243 | this.timeout(40000) | 301 | this.timeout(80000) |
244 | 302 | ||
245 | await disableRedundancyOnServer1() | 303 | await disableRedundancyOnServer1() |
246 | 304 | ||
247 | await waitJobs(servers) | 305 | await waitJobs(servers) |
248 | await wait(5000) | 306 | await wait(5000) |
249 | 307 | ||
250 | await check1WebSeed(strategy) | 308 | await check1WebSeed() |
309 | await check0PlaylistRedundancies() | ||
251 | 310 | ||
252 | await checkVideoFilesWereRemoved(video1Server2UUID, servers[0].serverNumber, [ 'videos' ]) | 311 | await checkVideoFilesWereRemoved(video1Server2UUID, servers[0].serverNumber, [ 'videos', join('playlists', 'hls') ]) |
253 | }) | 312 | }) |
254 | 313 | ||
255 | after(function () { | 314 | after(async function () { |
256 | return cleanServers() | 315 | return cleanupTests(servers) |
257 | }) | 316 | }) |
258 | }) | 317 | }) |
259 | 318 | ||
@@ -263,11 +322,12 @@ describe('Test videos redundancy', function () { | |||
263 | before(function () { | 322 | before(function () { |
264 | this.timeout(120000) | 323 | this.timeout(120000) |
265 | 324 | ||
266 | return runServers(strategy) | 325 | return flushAndRunServers(strategy) |
267 | }) | 326 | }) |
268 | 327 | ||
269 | it('Should have 1 webseed on the first video', async function () { | 328 | it('Should have 1 webseed on the first video', async function () { |
270 | await check1WebSeed(strategy) | 329 | await check1WebSeed() |
330 | await check0PlaylistRedundancies() | ||
271 | await checkStatsWith1Webseed(strategy) | 331 | await checkStatsWith1Webseed(strategy) |
272 | }) | 332 | }) |
273 | 333 | ||
@@ -276,31 +336,33 @@ describe('Test videos redundancy', function () { | |||
276 | }) | 336 | }) |
277 | 337 | ||
278 | it('Should have 2 webseeds on the first video', async function () { | 338 | it('Should have 2 webseeds on the first video', async function () { |
279 | this.timeout(40000) | 339 | this.timeout(80000) |
280 | 340 | ||
281 | await waitJobs(servers) | 341 | await waitJobs(servers) |
282 | await waitUntilLog(servers[0], 'Duplicated ', 4) | 342 | await waitUntilLog(servers[0], 'Duplicated ', 5) |
283 | await waitJobs(servers) | 343 | await waitJobs(servers) |
284 | 344 | ||
285 | await check2Webseeds(strategy) | 345 | await check2Webseeds() |
346 | await check1PlaylistRedundancies() | ||
286 | await checkStatsWith2Webseed(strategy) | 347 | await checkStatsWith2Webseed(strategy) |
287 | }) | 348 | }) |
288 | 349 | ||
289 | it('Should unfollow on server 1 and remove duplicated videos', async function () { | 350 | it('Should unfollow on server 1 and remove duplicated videos', async function () { |
290 | this.timeout(40000) | 351 | this.timeout(80000) |
291 | 352 | ||
292 | await unfollow(servers[0].url, servers[0].accessToken, servers[1]) | 353 | await unfollow(servers[0].url, servers[0].accessToken, servers[1]) |
293 | 354 | ||
294 | await waitJobs(servers) | 355 | await waitJobs(servers) |
295 | await wait(5000) | 356 | await wait(5000) |
296 | 357 | ||
297 | await check1WebSeed(strategy) | 358 | await check1WebSeed() |
359 | await check0PlaylistRedundancies() | ||
298 | 360 | ||
299 | await checkVideoFilesWereRemoved(video1Server2UUID, servers[0].serverNumber, [ 'videos' ]) | 361 | await checkVideoFilesWereRemoved(video1Server2UUID, servers[0].serverNumber, [ 'videos' ]) |
300 | }) | 362 | }) |
301 | 363 | ||
302 | after(function () { | 364 | after(async function () { |
303 | return cleanServers() | 365 | await cleanupTests(servers) |
304 | }) | 366 | }) |
305 | }) | 367 | }) |
306 | 368 | ||
@@ -310,11 +372,12 @@ describe('Test videos redundancy', function () { | |||
310 | before(function () { | 372 | before(function () { |
311 | this.timeout(120000) | 373 | this.timeout(120000) |
312 | 374 | ||
313 | return runServers(strategy, { min_views: 3 }) | 375 | return flushAndRunServers(strategy, { min_views: 3 }) |
314 | }) | 376 | }) |
315 | 377 | ||
316 | it('Should have 1 webseed on the first video', async function () { | 378 | it('Should have 1 webseed on the first video', async function () { |
317 | await check1WebSeed(strategy) | 379 | await check1WebSeed() |
380 | await check0PlaylistRedundancies() | ||
318 | await checkStatsWith1Webseed(strategy) | 381 | await checkStatsWith1Webseed(strategy) |
319 | }) | 382 | }) |
320 | 383 | ||
@@ -323,18 +386,19 @@ describe('Test videos redundancy', function () { | |||
323 | }) | 386 | }) |
324 | 387 | ||
325 | it('Should still have 1 webseed on the first video', async function () { | 388 | it('Should still have 1 webseed on the first video', async function () { |
326 | this.timeout(40000) | 389 | this.timeout(80000) |
327 | 390 | ||
328 | await waitJobs(servers) | 391 | await waitJobs(servers) |
329 | await wait(15000) | 392 | await wait(15000) |
330 | await waitJobs(servers) | 393 | await waitJobs(servers) |
331 | 394 | ||
332 | await check1WebSeed(strategy) | 395 | await check1WebSeed() |
396 | await check0PlaylistRedundancies() | ||
333 | await checkStatsWith1Webseed(strategy) | 397 | await checkStatsWith1Webseed(strategy) |
334 | }) | 398 | }) |
335 | 399 | ||
336 | it('Should view 2 times the first video to have > min_views config', async function () { | 400 | it('Should view 2 times the first video to have > min_views config', async function () { |
337 | this.timeout(40000) | 401 | this.timeout(80000) |
338 | 402 | ||
339 | await viewVideo(servers[ 0 ].url, video1Server2UUID) | 403 | await viewVideo(servers[ 0 ].url, video1Server2UUID) |
340 | await viewVideo(servers[ 2 ].url, video1Server2UUID) | 404 | await viewVideo(servers[ 2 ].url, video1Server2UUID) |
@@ -344,13 +408,14 @@ describe('Test videos redundancy', function () { | |||
344 | }) | 408 | }) |
345 | 409 | ||
346 | it('Should have 2 webseeds on the first video', async function () { | 410 | it('Should have 2 webseeds on the first video', async function () { |
347 | this.timeout(40000) | 411 | this.timeout(80000) |
348 | 412 | ||
349 | await waitJobs(servers) | 413 | await waitJobs(servers) |
350 | await waitUntilLog(servers[0], 'Duplicated ', 4) | 414 | await waitUntilLog(servers[0], 'Duplicated ', 5) |
351 | await waitJobs(servers) | 415 | await waitJobs(servers) |
352 | 416 | ||
353 | await check2Webseeds(strategy) | 417 | await check2Webseeds() |
418 | await check1PlaylistRedundancies() | ||
354 | await checkStatsWith2Webseed(strategy) | 419 | await checkStatsWith2Webseed(strategy) |
355 | }) | 420 | }) |
356 | 421 | ||
@@ -366,8 +431,8 @@ describe('Test videos redundancy', function () { | |||
366 | } | 431 | } |
367 | }) | 432 | }) |
368 | 433 | ||
369 | after(function () { | 434 | after(async function () { |
370 | return cleanServers() | 435 | await cleanupTests(servers) |
371 | }) | 436 | }) |
372 | }) | 437 | }) |
373 | 438 | ||
@@ -399,13 +464,13 @@ describe('Test videos redundancy', function () { | |||
399 | before(async function () { | 464 | before(async function () { |
400 | this.timeout(120000) | 465 | this.timeout(120000) |
401 | 466 | ||
402 | await runServers(strategy, { min_lifetime: '7 seconds', min_views: 0 }) | 467 | await flushAndRunServers(strategy, { min_lifetime: '7 seconds', min_views: 0 }) |
403 | 468 | ||
404 | await enableRedundancyOnServer1() | 469 | await enableRedundancyOnServer1() |
405 | }) | 470 | }) |
406 | 471 | ||
407 | it('Should still have 2 webseeds after 10 seconds', async function () { | 472 | it('Should still have 2 webseeds after 10 seconds', async function () { |
408 | this.timeout(40000) | 473 | this.timeout(80000) |
409 | 474 | ||
410 | await wait(10000) | 475 | await wait(10000) |
411 | 476 | ||
@@ -420,7 +485,7 @@ describe('Test videos redundancy', function () { | |||
420 | }) | 485 | }) |
421 | 486 | ||
422 | it('Should stop server 1 and expire video redundancy', async function () { | 487 | it('Should stop server 1 and expire video redundancy', async function () { |
423 | this.timeout(40000) | 488 | this.timeout(80000) |
424 | 489 | ||
425 | killallServers([ servers[0] ]) | 490 | killallServers([ servers[0] ]) |
426 | 491 | ||
@@ -429,8 +494,8 @@ describe('Test videos redundancy', function () { | |||
429 | await checkNotContains([ servers[1], servers[2] ], 'http%3A%2F%2Flocalhost%3A9001') | 494 | await checkNotContains([ servers[1], servers[2] ], 'http%3A%2F%2Flocalhost%3A9001') |
430 | }) | 495 | }) |
431 | 496 | ||
432 | after(function () { | 497 | after(async function () { |
433 | return killallServers([ servers[1], servers[2] ]) | 498 | await cleanupTests(servers) |
434 | }) | 499 | }) |
435 | }) | 500 | }) |
436 | 501 | ||
@@ -441,15 +506,16 @@ describe('Test videos redundancy', function () { | |||
441 | before(async function () { | 506 | before(async function () { |
442 | this.timeout(120000) | 507 | this.timeout(120000) |
443 | 508 | ||
444 | await runServers(strategy, { min_lifetime: '7 seconds', min_views: 0 }) | 509 | await flushAndRunServers(strategy, { min_lifetime: '7 seconds', min_views: 0 }) |
445 | 510 | ||
446 | await enableRedundancyOnServer1() | 511 | await enableRedundancyOnServer1() |
447 | 512 | ||
448 | await waitJobs(servers) | 513 | await waitJobs(servers) |
449 | await waitUntilLog(servers[0], 'Duplicated ', 4) | 514 | await waitUntilLog(servers[0], 'Duplicated ', 5) |
450 | await waitJobs(servers) | 515 | await waitJobs(servers) |
451 | 516 | ||
452 | await check2Webseeds(strategy) | 517 | await check2Webseeds() |
518 | await check1PlaylistRedundancies() | ||
453 | await checkStatsWith2Webseed(strategy) | 519 | await checkStatsWith2Webseed(strategy) |
454 | 520 | ||
455 | const res = await uploadVideo(servers[ 1 ].url, servers[ 1 ].accessToken, { name: 'video 2 server 2' }) | 521 | const res = await uploadVideo(servers[ 1 ].url, servers[ 1 ].accessToken, { name: 'video 2 server 2' }) |
@@ -467,8 +533,10 @@ describe('Test videos redundancy', function () { | |||
467 | await wait(1000) | 533 | await wait(1000) |
468 | 534 | ||
469 | try { | 535 | try { |
470 | await check1WebSeed(strategy, video1Server2UUID) | 536 | await check1WebSeed(video1Server2UUID) |
471 | await check2Webseeds(strategy, video2Server2UUID) | 537 | await check0PlaylistRedundancies(video1Server2UUID) |
538 | await check2Webseeds(video2Server2UUID) | ||
539 | await check1PlaylistRedundancies(video2Server2UUID) | ||
472 | 540 | ||
473 | checked = true | 541 | checked = true |
474 | } catch { | 542 | } catch { |
@@ -477,8 +545,28 @@ describe('Test videos redundancy', function () { | |||
477 | } | 545 | } |
478 | }) | 546 | }) |
479 | 547 | ||
480 | after(function () { | 548 | it('Should disable strategy and remove redundancies', async function () { |
481 | return cleanServers() | 549 | this.timeout(80000) |
550 | |||
551 | await waitJobs(servers) | ||
552 | |||
553 | killallServers([ servers[ 0 ] ]) | ||
554 | await reRunServer(servers[ 0 ], { | ||
555 | redundancy: { | ||
556 | videos: { | ||
557 | check_interval: '1 second', | ||
558 | strategies: [] | ||
559 | } | ||
560 | } | ||
561 | }) | ||
562 | |||
563 | await waitJobs(servers) | ||
564 | |||
565 | await checkVideoFilesWereRemoved(video1Server2UUID, servers[0].serverNumber, [ join('redundancy', 'hls') ]) | ||
566 | }) | ||
567 | |||
568 | after(async function () { | ||
569 | await cleanupTests(servers) | ||
482 | }) | 570 | }) |
483 | }) | 571 | }) |
484 | }) | 572 | }) |
diff --git a/server/tests/api/search/search-activitypub-video-channels.ts b/server/tests/api/search/search-activitypub-video-channels.ts index a411e973b..4d1ceb767 100644 --- a/server/tests/api/search/search-activitypub-video-channels.ts +++ b/server/tests/api/search/search-activitypub-video-channels.ts | |||
@@ -3,7 +3,7 @@ | |||
3 | import * as chai from 'chai' | 3 | import * as chai from 'chai' |
4 | import 'mocha' | 4 | import 'mocha' |
5 | import { | 5 | import { |
6 | addVideoChannel, | 6 | addVideoChannel, cleanupTests, |
7 | createUser, | 7 | createUser, |
8 | deleteVideoChannel, | 8 | deleteVideoChannel, |
9 | flushAndRunMultipleServers, | 9 | flushAndRunMultipleServers, |
@@ -17,10 +17,10 @@ import { | |||
17 | uploadVideo, | 17 | uploadVideo, |
18 | userLogin, | 18 | userLogin, |
19 | wait | 19 | wait |
20 | } from '../../../../shared/utils' | 20 | } from '../../../../shared/extra-utils' |
21 | import { waitJobs } from '../../../../shared/utils/server/jobs' | 21 | import { waitJobs } from '../../../../shared/extra-utils/server/jobs' |
22 | import { VideoChannel } from '../../../../shared/models/videos' | 22 | import { VideoChannel } from '../../../../shared/models/videos' |
23 | import { searchVideoChannel } from '../../../../shared/utils/search/video-channels' | 23 | import { searchVideoChannel } from '../../../../shared/extra-utils/search/video-channels' |
24 | 24 | ||
25 | const expect = chai.expect | 25 | const expect = chai.expect |
26 | 26 | ||
@@ -33,14 +33,12 @@ describe('Test a ActivityPub video channels search', function () { | |||
33 | before(async function () { | 33 | before(async function () { |
34 | this.timeout(120000) | 34 | this.timeout(120000) |
35 | 35 | ||
36 | await flushTests() | ||
37 | |||
38 | servers = await flushAndRunMultipleServers(2) | 36 | servers = await flushAndRunMultipleServers(2) |
39 | 37 | ||
40 | await setAccessTokensToServers(servers) | 38 | await setAccessTokensToServers(servers) |
41 | 39 | ||
42 | { | 40 | { |
43 | await createUser(servers[0].url, servers[0].accessToken, 'user1_server1', 'password') | 41 | await createUser({ url: servers[ 0 ].url, accessToken: servers[ 0 ].accessToken, username: 'user1_server1', password: 'password' }) |
44 | const channel = { | 42 | const channel = { |
45 | name: 'channel1_server1', | 43 | name: 'channel1_server1', |
46 | displayName: 'Channel 1 server 1' | 44 | displayName: 'Channel 1 server 1' |
@@ -50,7 +48,7 @@ describe('Test a ActivityPub video channels search', function () { | |||
50 | 48 | ||
51 | { | 49 | { |
52 | const user = { username: 'user1_server2', password: 'password' } | 50 | const user = { username: 'user1_server2', password: 'password' } |
53 | await createUser(servers[1].url, servers[1].accessToken, user.username, user.password) | 51 | await createUser({ url: servers[ 1 ].url, accessToken: servers[ 1 ].accessToken, username: user.username, password: user.password }) |
54 | userServer2Token = await userLogin(servers[1], user) | 52 | userServer2Token = await userLogin(servers[1], user) |
55 | 53 | ||
56 | const channel = { | 54 | const channel = { |
@@ -208,11 +206,6 @@ describe('Test a ActivityPub video channels search', function () { | |||
208 | }) | 206 | }) |
209 | 207 | ||
210 | after(async function () { | 208 | after(async function () { |
211 | killallServers(servers) | 209 | await cleanupTests(servers) |
212 | |||
213 | // Keep the logs if the test failed | ||
214 | if (this['ok']) { | ||
215 | await flushTests() | ||
216 | } | ||
217 | }) | 210 | }) |
218 | }) | 211 | }) |
diff --git a/server/tests/api/search/search-activitypub-videos.ts b/server/tests/api/search/search-activitypub-videos.ts index f881917e7..e039961cb 100644 --- a/server/tests/api/search/search-activitypub-videos.ts +++ b/server/tests/api/search/search-activitypub-videos.ts | |||
@@ -15,9 +15,9 @@ import { | |||
15 | updateVideo, | 15 | updateVideo, |
16 | uploadVideo, | 16 | uploadVideo, |
17 | wait, | 17 | wait, |
18 | searchVideo | 18 | searchVideo, cleanupTests |
19 | } from '../../../../shared/utils' | 19 | } from '../../../../shared/extra-utils' |
20 | import { waitJobs } from '../../../../shared/utils/server/jobs' | 20 | import { waitJobs } from '../../../../shared/extra-utils/server/jobs' |
21 | import { Video, VideoPrivacy } from '../../../../shared/models/videos' | 21 | import { Video, VideoPrivacy } from '../../../../shared/models/videos' |
22 | 22 | ||
23 | const expect = chai.expect | 23 | const expect = chai.expect |
@@ -30,8 +30,6 @@ describe('Test a ActivityPub videos search', function () { | |||
30 | before(async function () { | 30 | before(async function () { |
31 | this.timeout(120000) | 31 | this.timeout(120000) |
32 | 32 | ||
33 | await flushTests() | ||
34 | |||
35 | servers = await flushAndRunMultipleServers(2) | 33 | servers = await flushAndRunMultipleServers(2) |
36 | 34 | ||
37 | await setAccessTokensToServers(servers) | 35 | await setAccessTokensToServers(servers) |
@@ -152,11 +150,6 @@ describe('Test a ActivityPub videos search', function () { | |||
152 | }) | 150 | }) |
153 | 151 | ||
154 | after(async function () { | 152 | after(async function () { |
155 | killallServers(servers) | 153 | await cleanupTests(servers) |
156 | |||
157 | // Keep the logs if the test failed | ||
158 | if (this['ok']) { | ||
159 | await flushTests() | ||
160 | } | ||
161 | }) | 154 | }) |
162 | }) | 155 | }) |
diff --git a/server/tests/api/search/search-videos.ts b/server/tests/api/search/search-videos.ts index 50da837da..1a086b33a 100644 --- a/server/tests/api/search/search-videos.ts +++ b/server/tests/api/search/search-videos.ts | |||
@@ -6,14 +6,15 @@ import { | |||
6 | advancedVideosSearch, | 6 | advancedVideosSearch, |
7 | flushTests, | 7 | flushTests, |
8 | killallServers, | 8 | killallServers, |
9 | runServer, | 9 | flushAndRunServer, |
10 | searchVideo, | 10 | searchVideo, |
11 | ServerInfo, | 11 | ServerInfo, |
12 | setAccessTokensToServers, | 12 | setAccessTokensToServers, |
13 | uploadVideo, | 13 | uploadVideo, |
14 | wait, | 14 | wait, |
15 | immutableAssign | 15 | immutableAssign, |
16 | } from '../../../../shared/utils' | 16 | cleanupTests |
17 | } from '../../../../shared/extra-utils' | ||
17 | 18 | ||
18 | const expect = chai.expect | 19 | const expect = chai.expect |
19 | 20 | ||
@@ -24,9 +25,7 @@ describe('Test a videos search', function () { | |||
24 | before(async function () { | 25 | before(async function () { |
25 | this.timeout(30000) | 26 | this.timeout(30000) |
26 | 27 | ||
27 | await flushTests() | 28 | server = await flushAndRunServer(1) |
28 | |||
29 | server = await runServer(1) | ||
30 | 29 | ||
31 | await setAccessTokensToServers([ server ]) | 30 | await setAccessTokensToServers([ server ]) |
32 | 31 | ||
@@ -60,7 +59,10 @@ describe('Test a videos search', function () { | |||
60 | const attributes6 = immutableAssign(attributes1, { name: attributes1.name + ' - 6', tags: [ 't1', 't2 '] }) | 59 | const attributes6 = immutableAssign(attributes1, { name: attributes1.name + ' - 6', tags: [ 't1', 't2 '] }) |
61 | await uploadVideo(server.url, server.accessToken, attributes6) | 60 | await uploadVideo(server.url, server.accessToken, attributes6) |
62 | 61 | ||
63 | const attributes7 = immutableAssign(attributes1, { name: attributes1.name + ' - 7' }) | 62 | const attributes7 = immutableAssign(attributes1, { |
63 | name: attributes1.name + ' - 7', | ||
64 | originallyPublishedAt: '2019-02-12T09:58:08.286Z' | ||
65 | }) | ||
64 | await uploadVideo(server.url, server.accessToken, attributes7) | 66 | await uploadVideo(server.url, server.accessToken, attributes7) |
65 | 67 | ||
66 | const attributes8 = immutableAssign(attributes1, { name: attributes1.name + ' - 8', licence: 4 }) | 68 | const attributes8 = immutableAssign(attributes1, { name: attributes1.name + ' - 8', licence: 4 }) |
@@ -343,12 +345,68 @@ describe('Test a videos search', function () { | |||
343 | expect(videos[0].name).to.equal('1111 2222 3333') | 345 | expect(videos[0].name).to.equal('1111 2222 3333') |
344 | }) | 346 | }) |
345 | 347 | ||
346 | after(async function () { | 348 | it('Should search on originally published date', async function () { |
347 | killallServers([ server ]) | 349 | const baseQuery = { |
350 | search: '1111 2222 3333', | ||
351 | languageOneOf: [ 'pl', 'fr' ], | ||
352 | durationMax: 4, | ||
353 | nsfw: 'false' as 'false', | ||
354 | licenceOneOf: [ 1, 4 ] | ||
355 | } | ||
356 | |||
357 | { | ||
358 | const query = immutableAssign(baseQuery, { originallyPublishedStartDate: '2019-02-11T09:58:08.286Z' }) | ||
359 | const res = await advancedVideosSearch(server.url, query) | ||
360 | |||
361 | expect(res.body.total).to.equal(1) | ||
362 | expect(res.body.data[0].name).to.equal('1111 2222 3333 - 7') | ||
363 | } | ||
364 | |||
365 | { | ||
366 | const query = immutableAssign(baseQuery, { originallyPublishedEndDate: '2019-03-11T09:58:08.286Z' }) | ||
367 | const res = await advancedVideosSearch(server.url, query) | ||
368 | |||
369 | expect(res.body.total).to.equal(1) | ||
370 | expect(res.body.data[0].name).to.equal('1111 2222 3333 - 7') | ||
371 | } | ||
348 | 372 | ||
349 | // Keep the logs if the test failed | 373 | { |
350 | if (this['ok']) { | 374 | const query = immutableAssign(baseQuery, { originallyPublishedEndDate: '2019-01-11T09:58:08.286Z' }) |
351 | await flushTests() | 375 | const res = await advancedVideosSearch(server.url, query) |
376 | |||
377 | expect(res.body.total).to.equal(0) | ||
378 | } | ||
379 | |||
380 | { | ||
381 | const query = immutableAssign(baseQuery, { originallyPublishedStartDate: '2019-03-11T09:58:08.286Z' }) | ||
382 | const res = await advancedVideosSearch(server.url, query) | ||
383 | |||
384 | expect(res.body.total).to.equal(0) | ||
385 | } | ||
386 | |||
387 | { | ||
388 | const query = immutableAssign(baseQuery, { | ||
389 | originallyPublishedStartDate: '2019-01-11T09:58:08.286Z', | ||
390 | originallyPublishedEndDate: '2019-01-10T09:58:08.286Z' | ||
391 | }) | ||
392 | const res = await advancedVideosSearch(server.url, query) | ||
393 | |||
394 | expect(res.body.total).to.equal(0) | ||
395 | } | ||
396 | |||
397 | { | ||
398 | const query = immutableAssign(baseQuery, { | ||
399 | originallyPublishedStartDate: '2019-01-11T09:58:08.286Z', | ||
400 | originallyPublishedEndDate: '2019-04-11T09:58:08.286Z' | ||
401 | }) | ||
402 | const res = await advancedVideosSearch(server.url, query) | ||
403 | |||
404 | expect(res.body.total).to.equal(1) | ||
405 | expect(res.body.data[0].name).to.equal('1111 2222 3333 - 7') | ||
352 | } | 406 | } |
353 | }) | 407 | }) |
408 | |||
409 | after(async function () { | ||
410 | await cleanupTests([ server ]) | ||
411 | }) | ||
354 | }) | 412 | }) |
diff --git a/server/tests/api/server/config.ts b/server/tests/api/server/config.ts index bebfc7398..c0d11914b 100644 --- a/server/tests/api/server/config.ts +++ b/server/tests/api/server/config.ts | |||
@@ -5,18 +5,18 @@ import * as chai from 'chai' | |||
5 | import { About } from '../../../../shared/models/server/about.model' | 5 | import { About } from '../../../../shared/models/server/about.model' |
6 | import { CustomConfig } from '../../../../shared/models/server/custom-config.model' | 6 | import { CustomConfig } from '../../../../shared/models/server/custom-config.model' |
7 | import { | 7 | import { |
8 | cleanupTests, | ||
8 | deleteCustomConfig, | 9 | deleteCustomConfig, |
10 | flushAndRunServer, | ||
9 | getAbout, | 11 | getAbout, |
10 | killallServers, | ||
11 | reRunServer, | ||
12 | flushTests, | ||
13 | getConfig, | 12 | getConfig, |
14 | getCustomConfig, | 13 | getCustomConfig, |
14 | killallServers, | ||
15 | registerUser, | 15 | registerUser, |
16 | runServer, | 16 | reRunServer, |
17 | setAccessTokensToServers, | 17 | setAccessTokensToServers, |
18 | updateCustomConfig | 18 | updateCustomConfig |
19 | } from '../../../../shared/utils' | 19 | } from '../../../../shared/extra-utils' |
20 | import { ServerConfig } from '../../../../shared/models' | 20 | import { ServerConfig } from '../../../../shared/models' |
21 | 21 | ||
22 | const expect = chai.expect | 22 | const expect = chai.expect |
@@ -30,6 +30,7 @@ function checkInitialConfig (data: CustomConfig) { | |||
30 | expect(data.instance.description).to.equal('Welcome to this PeerTube instance!') | 30 | expect(data.instance.description).to.equal('Welcome to this PeerTube instance!') |
31 | expect(data.instance.terms).to.equal('No terms for now.') | 31 | expect(data.instance.terms).to.equal('No terms for now.') |
32 | expect(data.instance.defaultClientRoute).to.equal('/videos/trending') | 32 | expect(data.instance.defaultClientRoute).to.equal('/videos/trending') |
33 | expect(data.instance.isNSFW).to.be.false | ||
33 | expect(data.instance.defaultNSFWPolicy).to.equal('display') | 34 | expect(data.instance.defaultNSFWPolicy).to.equal('display') |
34 | expect(data.instance.customizations.css).to.be.empty | 35 | expect(data.instance.customizations.css).to.be.empty |
35 | expect(data.instance.customizations.javascript).to.be.empty | 36 | expect(data.instance.customizations.javascript).to.be.empty |
@@ -57,8 +58,14 @@ function checkInitialConfig (data: CustomConfig) { | |||
57 | expect(data.transcoding.resolutions['480p']).to.be.true | 58 | expect(data.transcoding.resolutions['480p']).to.be.true |
58 | expect(data.transcoding.resolutions['720p']).to.be.true | 59 | expect(data.transcoding.resolutions['720p']).to.be.true |
59 | expect(data.transcoding.resolutions['1080p']).to.be.true | 60 | expect(data.transcoding.resolutions['1080p']).to.be.true |
61 | expect(data.transcoding.hls.enabled).to.be.true | ||
62 | |||
60 | expect(data.import.videos.http.enabled).to.be.true | 63 | expect(data.import.videos.http.enabled).to.be.true |
61 | expect(data.import.videos.torrent.enabled).to.be.true | 64 | expect(data.import.videos.torrent.enabled).to.be.true |
65 | expect(data.autoBlacklist.videos.ofUsers.enabled).to.be.false | ||
66 | |||
67 | expect(data.followers.instance.enabled).to.be.true | ||
68 | expect(data.followers.instance.manualApproval).to.be.false | ||
62 | } | 69 | } |
63 | 70 | ||
64 | function checkUpdatedConfig (data: CustomConfig) { | 71 | function checkUpdatedConfig (data: CustomConfig) { |
@@ -67,6 +74,7 @@ function checkUpdatedConfig (data: CustomConfig) { | |||
67 | expect(data.instance.description).to.equal('my super description') | 74 | expect(data.instance.description).to.equal('my super description') |
68 | expect(data.instance.terms).to.equal('my super terms') | 75 | expect(data.instance.terms).to.equal('my super terms') |
69 | expect(data.instance.defaultClientRoute).to.equal('/videos/recently-added') | 76 | expect(data.instance.defaultClientRoute).to.equal('/videos/recently-added') |
77 | expect(data.instance.isNSFW).to.be.true | ||
70 | expect(data.instance.defaultNSFWPolicy).to.equal('blur') | 78 | expect(data.instance.defaultNSFWPolicy).to.equal('blur') |
71 | expect(data.instance.customizations.javascript).to.equal('alert("coucou")') | 79 | expect(data.instance.customizations.javascript).to.equal('alert("coucou")') |
72 | expect(data.instance.customizations.css).to.equal('body { background-color: red; }') | 80 | expect(data.instance.customizations.css).to.equal('body { background-color: red; }') |
@@ -79,7 +87,7 @@ function checkUpdatedConfig (data: CustomConfig) { | |||
79 | 87 | ||
80 | expect(data.signup.enabled).to.be.false | 88 | expect(data.signup.enabled).to.be.false |
81 | expect(data.signup.limit).to.equal(5) | 89 | expect(data.signup.limit).to.equal(5) |
82 | expect(data.signup.requiresEmailVerification).to.be.true | 90 | expect(data.signup.requiresEmailVerification).to.be.false |
83 | 91 | ||
84 | expect(data.admin.email).to.equal('superadmin1@example.com') | 92 | expect(data.admin.email).to.equal('superadmin1@example.com') |
85 | expect(data.contactForm.enabled).to.be.false | 93 | expect(data.contactForm.enabled).to.be.false |
@@ -95,9 +103,14 @@ function checkUpdatedConfig (data: CustomConfig) { | |||
95 | expect(data.transcoding.resolutions['480p']).to.be.true | 103 | expect(data.transcoding.resolutions['480p']).to.be.true |
96 | expect(data.transcoding.resolutions['720p']).to.be.false | 104 | expect(data.transcoding.resolutions['720p']).to.be.false |
97 | expect(data.transcoding.resolutions['1080p']).to.be.false | 105 | expect(data.transcoding.resolutions['1080p']).to.be.false |
106 | expect(data.transcoding.hls.enabled).to.be.false | ||
98 | 107 | ||
99 | expect(data.import.videos.http.enabled).to.be.false | 108 | expect(data.import.videos.http.enabled).to.be.false |
100 | expect(data.import.videos.torrent.enabled).to.be.false | 109 | expect(data.import.videos.torrent.enabled).to.be.false |
110 | expect(data.autoBlacklist.videos.ofUsers.enabled).to.be.true | ||
111 | |||
112 | expect(data.followers.instance.enabled).to.be.false | ||
113 | expect(data.followers.instance.manualApproval).to.be.true | ||
101 | } | 114 | } |
102 | 115 | ||
103 | describe('Test config', function () { | 116 | describe('Test config', function () { |
@@ -105,9 +118,7 @@ describe('Test config', function () { | |||
105 | 118 | ||
106 | before(async function () { | 119 | before(async function () { |
107 | this.timeout(30000) | 120 | this.timeout(30000) |
108 | 121 | server = await flushAndRunServer(1) | |
109 | await flushTests() | ||
110 | server = await runServer(1) | ||
111 | await setAccessTokensToServers([ server ]) | 122 | await setAccessTokensToServers([ server ]) |
112 | }) | 123 | }) |
113 | 124 | ||
@@ -160,6 +171,7 @@ describe('Test config', function () { | |||
160 | description: 'my super description', | 171 | description: 'my super description', |
161 | terms: 'my super terms', | 172 | terms: 'my super terms', |
162 | defaultClientRoute: '/videos/recently-added', | 173 | defaultClientRoute: '/videos/recently-added', |
174 | isNSFW: true, | ||
163 | defaultNSFWPolicy: 'blur' as 'blur', | 175 | defaultNSFWPolicy: 'blur' as 'blur', |
164 | customizations: { | 176 | customizations: { |
165 | javascript: 'alert("coucou")', | 177 | javascript: 'alert("coucou")', |
@@ -183,7 +195,7 @@ describe('Test config', function () { | |||
183 | signup: { | 195 | signup: { |
184 | enabled: false, | 196 | enabled: false, |
185 | limit: 5, | 197 | limit: 5, |
186 | requiresEmailVerification: true | 198 | requiresEmailVerification: false |
187 | }, | 199 | }, |
188 | admin: { | 200 | admin: { |
189 | email: 'superadmin1@example.com' | 201 | email: 'superadmin1@example.com' |
@@ -205,6 +217,9 @@ describe('Test config', function () { | |||
205 | '480p': true, | 217 | '480p': true, |
206 | '720p': false, | 218 | '720p': false, |
207 | '1080p': false | 219 | '1080p': false |
220 | }, | ||
221 | hls: { | ||
222 | enabled: false | ||
208 | } | 223 | } |
209 | }, | 224 | }, |
210 | import: { | 225 | import: { |
@@ -216,6 +231,19 @@ describe('Test config', function () { | |||
216 | enabled: false | 231 | enabled: false |
217 | } | 232 | } |
218 | } | 233 | } |
234 | }, | ||
235 | autoBlacklist: { | ||
236 | videos: { | ||
237 | ofUsers: { | ||
238 | enabled: true | ||
239 | } | ||
240 | } | ||
241 | }, | ||
242 | followers: { | ||
243 | instance: { | ||
244 | enabled: false, | ||
245 | manualApproval: true | ||
246 | } | ||
219 | } | 247 | } |
220 | } | 248 | } |
221 | await updateCustomConfig(server.url, server.accessToken, newCustomConfig) | 249 | await updateCustomConfig(server.url, server.accessToken, newCustomConfig) |
@@ -273,6 +301,6 @@ describe('Test config', function () { | |||
273 | }) | 301 | }) |
274 | 302 | ||
275 | after(async function () { | 303 | after(async function () { |
276 | killallServers([ server ]) | 304 | await cleanupTests([ server ]) |
277 | }) | 305 | }) |
278 | }) | 306 | }) |
diff --git a/server/tests/api/server/contact-form.ts b/server/tests/api/server/contact-form.ts index 06a2f89b0..ba51198b3 100644 --- a/server/tests/api/server/contact-form.ts +++ b/server/tests/api/server/contact-form.ts | |||
@@ -2,10 +2,18 @@ | |||
2 | 2 | ||
3 | import * as chai from 'chai' | 3 | import * as chai from 'chai' |
4 | import 'mocha' | 4 | import 'mocha' |
5 | import { flushTests, killallServers, runServer, ServerInfo, setAccessTokensToServers, wait } from '../../../../shared/utils' | 5 | import { |
6 | import { MockSmtpServer } from '../../../../shared/utils/miscs/email' | 6 | flushTests, |
7 | import { waitJobs } from '../../../../shared/utils/server/jobs' | 7 | killallServers, |
8 | import { sendContactForm } from '../../../../shared/utils/server/contact-form' | 8 | flushAndRunServer, |
9 | ServerInfo, | ||
10 | setAccessTokensToServers, | ||
11 | wait, | ||
12 | cleanupTests | ||
13 | } from '../../../../shared/extra-utils' | ||
14 | import { MockSmtpServer } from '../../../../shared/extra-utils/miscs/email' | ||
15 | import { waitJobs } from '../../../../shared/extra-utils/server/jobs' | ||
16 | import { sendContactForm } from '../../../../shared/extra-utils/server/contact-form' | ||
9 | 17 | ||
10 | const expect = chai.expect | 18 | const expect = chai.expect |
11 | 19 | ||
@@ -18,14 +26,12 @@ describe('Test contact form', function () { | |||
18 | 26 | ||
19 | await MockSmtpServer.Instance.collectEmails(emails) | 27 | await MockSmtpServer.Instance.collectEmails(emails) |
20 | 28 | ||
21 | await flushTests() | ||
22 | |||
23 | const overrideConfig = { | 29 | const overrideConfig = { |
24 | smtp: { | 30 | smtp: { |
25 | hostname: 'localhost' | 31 | hostname: 'localhost' |
26 | } | 32 | } |
27 | } | 33 | } |
28 | server = await runServer(1, overrideConfig) | 34 | server = await flushAndRunServer(1, overrideConfig) |
29 | await setAccessTokensToServers([ server ]) | 35 | await setAccessTokensToServers([ server ]) |
30 | }) | 36 | }) |
31 | 37 | ||
@@ -82,6 +88,7 @@ describe('Test contact form', function () { | |||
82 | 88 | ||
83 | after(async function () { | 89 | after(async function () { |
84 | MockSmtpServer.Instance.kill() | 90 | MockSmtpServer.Instance.kill() |
85 | killallServers([ server ]) | 91 | |
92 | await cleanupTests([ server ]) | ||
86 | }) | 93 | }) |
87 | }) | 94 | }) |
diff --git a/server/tests/api/server/email.ts b/server/tests/api/server/email.ts index f8f16f54f..bacdf1b1b 100644 --- a/server/tests/api/server/email.ts +++ b/server/tests/api/server/email.ts | |||
@@ -10,7 +10,7 @@ import { | |||
10 | createUser, removeVideoFromBlacklist, | 10 | createUser, removeVideoFromBlacklist, |
11 | reportVideoAbuse, | 11 | reportVideoAbuse, |
12 | resetPassword, | 12 | resetPassword, |
13 | runServer, | 13 | flushAndRunServer, |
14 | unblockUser, | 14 | unblockUser, |
15 | uploadVideo, | 15 | uploadVideo, |
16 | userLogin, | 16 | userLogin, |
@@ -18,10 +18,10 @@ import { | |||
18 | flushTests, | 18 | flushTests, |
19 | killallServers, | 19 | killallServers, |
20 | ServerInfo, | 20 | ServerInfo, |
21 | setAccessTokensToServers | 21 | setAccessTokensToServers, cleanupTests |
22 | } from '../../../../shared/utils' | 22 | } from '../../../../shared/extra-utils' |
23 | import { MockSmtpServer } from '../../../../shared/utils/miscs/email' | 23 | import { MockSmtpServer } from '../../../../shared/extra-utils/miscs/email' |
24 | import { waitJobs } from '../../../../shared/utils/server/jobs' | 24 | import { waitJobs } from '../../../../shared/extra-utils/server/jobs' |
25 | 25 | ||
26 | const expect = chai.expect | 26 | const expect = chai.expect |
27 | 27 | ||
@@ -43,18 +43,16 @@ describe('Test emails', function () { | |||
43 | 43 | ||
44 | await MockSmtpServer.Instance.collectEmails(emails) | 44 | await MockSmtpServer.Instance.collectEmails(emails) |
45 | 45 | ||
46 | await flushTests() | ||
47 | |||
48 | const overrideConfig = { | 46 | const overrideConfig = { |
49 | smtp: { | 47 | smtp: { |
50 | hostname: 'localhost' | 48 | hostname: 'localhost' |
51 | } | 49 | } |
52 | } | 50 | } |
53 | server = await runServer(1, overrideConfig) | 51 | server = await flushAndRunServer(1, overrideConfig) |
54 | await setAccessTokensToServers([ server ]) | 52 | await setAccessTokensToServers([ server ]) |
55 | 53 | ||
56 | { | 54 | { |
57 | const res = await createUser(server.url, server.accessToken, user.username, user.password) | 55 | const res = await createUser({ url: server.url, accessToken: server.accessToken, username: user.username, password: user.password }) |
58 | userId = res.body.user.id | 56 | userId = res.body.user.id |
59 | 57 | ||
60 | userAccessToken = await userLogin(server, user) | 58 | userAccessToken = await userLogin(server, user) |
@@ -142,7 +140,8 @@ describe('Test emails', function () { | |||
142 | }) | 140 | }) |
143 | }) | 141 | }) |
144 | 142 | ||
145 | describe('When blocking/unblocking user', async function () { | 143 | describe('When blocking/unblocking user', function () { |
144 | |||
146 | it('Should send the notification email when blocking a user', async function () { | 145 | it('Should send the notification email when blocking a user', async function () { |
147 | this.timeout(10000) | 146 | this.timeout(10000) |
148 | 147 | ||
@@ -259,6 +258,7 @@ describe('Test emails', function () { | |||
259 | 258 | ||
260 | after(async function () { | 259 | after(async function () { |
261 | MockSmtpServer.Instance.kill() | 260 | MockSmtpServer.Instance.kill() |
262 | killallServers([ server ]) | 261 | |
262 | await cleanupTests([ server ]) | ||
263 | }) | 263 | }) |
264 | }) | 264 | }) |
diff --git a/server/tests/api/server/follow-constraints.ts b/server/tests/api/server/follow-constraints.ts index 8bb073c41..4285a9e7a 100644 --- a/server/tests/api/server/follow-constraints.ts +++ b/server/tests/api/server/follow-constraints.ts | |||
@@ -12,11 +12,11 @@ import { | |||
12 | killallServers, | 12 | killallServers, |
13 | ServerInfo, | 13 | ServerInfo, |
14 | setAccessTokensToServers, | 14 | setAccessTokensToServers, |
15 | uploadVideo | 15 | uploadVideo, cleanupTests |
16 | } from '../../../../shared/utils' | 16 | } from '../../../../shared/extra-utils' |
17 | import { unfollow } from '../../../../shared/utils/server/follows' | 17 | import { unfollow } from '../../../../shared/extra-utils/server/follows' |
18 | import { userLogin } from '../../../../shared/utils/users/login' | 18 | import { userLogin } from '../../../../shared/extra-utils/users/login' |
19 | import { createUser } from '../../../../shared/utils/users/users' | 19 | import { createUser } from '../../../../shared/extra-utils/users/users' |
20 | 20 | ||
21 | const expect = chai.expect | 21 | const expect = chai.expect |
22 | 22 | ||
@@ -47,7 +47,7 @@ describe('Test follow constraints', function () { | |||
47 | username: 'user1', | 47 | username: 'user1', |
48 | password: 'super_password' | 48 | password: 'super_password' |
49 | } | 49 | } |
50 | await createUser(servers[0].url, servers[0].accessToken, user.username, user.password) | 50 | await createUser({ url: servers[ 0 ].url, accessToken: servers[ 0 ].accessToken, username: user.username, password: user.password }) |
51 | userAccessToken = await userLogin(servers[0], user) | 51 | userAccessToken = await userLogin(servers[0], user) |
52 | 52 | ||
53 | await doubleFollow(servers[0], servers[1]) | 53 | await doubleFollow(servers[0], servers[1]) |
@@ -220,6 +220,6 @@ describe('Test follow constraints', function () { | |||
220 | }) | 220 | }) |
221 | 221 | ||
222 | after(async function () { | 222 | after(async function () { |
223 | killallServers(servers) | 223 | await cleanupTests(servers) |
224 | }) | 224 | }) |
225 | }) | 225 | }) |
diff --git a/server/tests/api/server/follows-moderation.ts b/server/tests/api/server/follows-moderation.ts new file mode 100644 index 000000000..2a3a4d5c8 --- /dev/null +++ b/server/tests/api/server/follows-moderation.ts | |||
@@ -0,0 +1,195 @@ | |||
1 | /* tslint:disable:no-unused-expression */ | ||
2 | |||
3 | import * as chai from 'chai' | ||
4 | import 'mocha' | ||
5 | import { | ||
6 | acceptFollower, cleanupTests, | ||
7 | flushAndRunMultipleServers, | ||
8 | killallServers, | ||
9 | ServerInfo, | ||
10 | setAccessTokensToServers, | ||
11 | updateCustomSubConfig | ||
12 | } from '../../../../shared/extra-utils/index' | ||
13 | import { | ||
14 | follow, | ||
15 | getFollowersListPaginationAndSort, | ||
16 | getFollowingListPaginationAndSort, | ||
17 | removeFollower, | ||
18 | rejectFollower | ||
19 | } from '../../../../shared/extra-utils/server/follows' | ||
20 | import { waitJobs } from '../../../../shared/extra-utils/server/jobs' | ||
21 | import { ActorFollow } from '../../../../shared/models/actors' | ||
22 | |||
23 | const expect = chai.expect | ||
24 | |||
25 | async function checkServer1And2HasFollowers (servers: ServerInfo[], state = 'accepted') { | ||
26 | { | ||
27 | const res = await getFollowingListPaginationAndSort(servers[0].url, 0, 5, 'createdAt') | ||
28 | expect(res.body.total).to.equal(1) | ||
29 | |||
30 | const follow = res.body.data[0] as ActorFollow | ||
31 | expect(follow.state).to.equal(state) | ||
32 | expect(follow.follower.url).to.equal('http://localhost:9001/accounts/peertube') | ||
33 | expect(follow.following.url).to.equal('http://localhost:9002/accounts/peertube') | ||
34 | } | ||
35 | |||
36 | { | ||
37 | const res = await getFollowersListPaginationAndSort(servers[1].url, 0, 5, 'createdAt') | ||
38 | expect(res.body.total).to.equal(1) | ||
39 | |||
40 | const follow = res.body.data[0] as ActorFollow | ||
41 | expect(follow.state).to.equal(state) | ||
42 | expect(follow.follower.url).to.equal('http://localhost:9001/accounts/peertube') | ||
43 | expect(follow.following.url).to.equal('http://localhost:9002/accounts/peertube') | ||
44 | } | ||
45 | } | ||
46 | |||
47 | async function checkNoFollowers (servers: ServerInfo[]) { | ||
48 | { | ||
49 | const res = await getFollowingListPaginationAndSort(servers[ 0 ].url, 0, 5, 'createdAt') | ||
50 | expect(res.body.total).to.equal(0) | ||
51 | } | ||
52 | |||
53 | { | ||
54 | const res = await getFollowersListPaginationAndSort(servers[ 1 ].url, 0, 5, 'createdAt') | ||
55 | expect(res.body.total).to.equal(0) | ||
56 | } | ||
57 | } | ||
58 | |||
59 | describe('Test follows moderation', function () { | ||
60 | let servers: ServerInfo[] = [] | ||
61 | |||
62 | before(async function () { | ||
63 | this.timeout(30000) | ||
64 | |||
65 | servers = await flushAndRunMultipleServers(3) | ||
66 | |||
67 | // Get the access tokens | ||
68 | await setAccessTokensToServers(servers) | ||
69 | }) | ||
70 | |||
71 | it('Should have server 1 following server 2', async function () { | ||
72 | this.timeout(30000) | ||
73 | |||
74 | await follow(servers[0].url, [ servers[1].url ], servers[0].accessToken) | ||
75 | |||
76 | await waitJobs(servers) | ||
77 | }) | ||
78 | |||
79 | it('Should have correct follows', async function () { | ||
80 | await checkServer1And2HasFollowers(servers) | ||
81 | }) | ||
82 | |||
83 | it('Should remove follower on server 2', async function () { | ||
84 | await removeFollower(servers[1].url, servers[1].accessToken, servers[0]) | ||
85 | |||
86 | await waitJobs(servers) | ||
87 | }) | ||
88 | |||
89 | it('Should not not have follows anymore', async function () { | ||
90 | await checkNoFollowers(servers) | ||
91 | }) | ||
92 | |||
93 | it('Should disable followers on server 2', async function () { | ||
94 | const subConfig = { | ||
95 | followers: { | ||
96 | instance: { | ||
97 | enabled: false, | ||
98 | manualApproval: false | ||
99 | } | ||
100 | } | ||
101 | } | ||
102 | |||
103 | await updateCustomSubConfig(servers[1].url, servers[1].accessToken, subConfig) | ||
104 | |||
105 | await follow(servers[0].url, [ servers[1].url ], servers[0].accessToken) | ||
106 | await waitJobs(servers) | ||
107 | |||
108 | await checkNoFollowers(servers) | ||
109 | }) | ||
110 | |||
111 | it('Should re enable followers on server 2', async function () { | ||
112 | const subConfig = { | ||
113 | followers: { | ||
114 | instance: { | ||
115 | enabled: true, | ||
116 | manualApproval: false | ||
117 | } | ||
118 | } | ||
119 | } | ||
120 | |||
121 | await updateCustomSubConfig(servers[1].url, servers[1].accessToken, subConfig) | ||
122 | |||
123 | await follow(servers[0].url, [ servers[1].url ], servers[0].accessToken) | ||
124 | await waitJobs(servers) | ||
125 | |||
126 | await checkServer1And2HasFollowers(servers) | ||
127 | }) | ||
128 | |||
129 | it('Should manually approve followers', async function () { | ||
130 | this.timeout(20000) | ||
131 | |||
132 | await removeFollower(servers[1].url, servers[1].accessToken, servers[0]) | ||
133 | await waitJobs(servers) | ||
134 | |||
135 | const subConfig = { | ||
136 | followers: { | ||
137 | instance: { | ||
138 | enabled: true, | ||
139 | manualApproval: true | ||
140 | } | ||
141 | } | ||
142 | } | ||
143 | |||
144 | await updateCustomSubConfig(servers[1].url, servers[1].accessToken, subConfig) | ||
145 | await updateCustomSubConfig(servers[2].url, servers[2].accessToken, subConfig) | ||
146 | |||
147 | await follow(servers[0].url, [ servers[1].url ], servers[0].accessToken) | ||
148 | await waitJobs(servers) | ||
149 | |||
150 | await checkServer1And2HasFollowers(servers, 'pending') | ||
151 | }) | ||
152 | |||
153 | it('Should accept a follower', async function () { | ||
154 | await acceptFollower(servers[1].url, servers[1].accessToken, 'peertube@localhost:9001') | ||
155 | await waitJobs(servers) | ||
156 | |||
157 | await checkServer1And2HasFollowers(servers) | ||
158 | }) | ||
159 | |||
160 | it('Should reject another follower', async function () { | ||
161 | this.timeout(20000) | ||
162 | |||
163 | await follow(servers[0].url, [ servers[2].url ], servers[0].accessToken) | ||
164 | await waitJobs(servers) | ||
165 | |||
166 | { | ||
167 | const res = await getFollowingListPaginationAndSort(servers[0].url, 0, 5, 'createdAt') | ||
168 | expect(res.body.total).to.equal(2) | ||
169 | } | ||
170 | |||
171 | { | ||
172 | const res = await getFollowersListPaginationAndSort(servers[1].url, 0, 5, 'createdAt') | ||
173 | expect(res.body.total).to.equal(1) | ||
174 | } | ||
175 | |||
176 | { | ||
177 | const res = await getFollowersListPaginationAndSort(servers[2].url, 0, 5, 'createdAt') | ||
178 | expect(res.body.total).to.equal(1) | ||
179 | } | ||
180 | |||
181 | await rejectFollower(servers[2].url, servers[2].accessToken, 'peertube@localhost:9001') | ||
182 | await waitJobs(servers) | ||
183 | |||
184 | await checkServer1And2HasFollowers(servers) | ||
185 | |||
186 | { | ||
187 | const res = await getFollowersListPaginationAndSort(servers[ 2 ].url, 0, 5, 'createdAt') | ||
188 | expect(res.body.total).to.equal(0) | ||
189 | } | ||
190 | }) | ||
191 | |||
192 | after(async function () { | ||
193 | await cleanupTests(servers) | ||
194 | }) | ||
195 | }) | ||
diff --git a/server/tests/api/server/follows.ts b/server/tests/api/server/follows.ts index b0fc5d293..397093cdb 100644 --- a/server/tests/api/server/follows.ts +++ b/server/tests/api/server/follows.ts | |||
@@ -4,7 +4,7 @@ import * as chai from 'chai' | |||
4 | import 'mocha' | 4 | import 'mocha' |
5 | import { Video, VideoPrivacy } from '../../../../shared/models/videos' | 5 | import { Video, VideoPrivacy } from '../../../../shared/models/videos' |
6 | import { VideoComment, VideoCommentThreadTree } from '../../../../shared/models/videos/video-comment.model' | 6 | import { VideoComment, VideoCommentThreadTree } from '../../../../shared/models/videos/video-comment.model' |
7 | import { completeVideoCheck } from '../../../../shared/utils' | 7 | import { cleanupTests, completeVideoCheck } from '../../../../shared/extra-utils' |
8 | import { | 8 | import { |
9 | flushAndRunMultipleServers, | 9 | flushAndRunMultipleServers, |
10 | getVideosList, | 10 | getVideosList, |
@@ -12,26 +12,26 @@ import { | |||
12 | ServerInfo, | 12 | ServerInfo, |
13 | setAccessTokensToServers, | 13 | setAccessTokensToServers, |
14 | uploadVideo | 14 | uploadVideo |
15 | } from '../../../../shared/utils/index' | 15 | } from '../../../../shared/extra-utils/index' |
16 | import { dateIsValid } from '../../../../shared/utils/miscs/miscs' | 16 | import { dateIsValid } from '../../../../shared/extra-utils/miscs/miscs' |
17 | import { | 17 | import { |
18 | follow, | 18 | follow, |
19 | getFollowersListPaginationAndSort, | 19 | getFollowersListPaginationAndSort, |
20 | getFollowingListPaginationAndSort, | 20 | getFollowingListPaginationAndSort, |
21 | unfollow | 21 | unfollow |
22 | } from '../../../../shared/utils/server/follows' | 22 | } from '../../../../shared/extra-utils/server/follows' |
23 | import { expectAccountFollows } from '../../../../shared/utils/users/accounts' | 23 | import { expectAccountFollows } from '../../../../shared/extra-utils/users/accounts' |
24 | import { userLogin } from '../../../../shared/utils/users/login' | 24 | import { userLogin } from '../../../../shared/extra-utils/users/login' |
25 | import { createUser } from '../../../../shared/utils/users/users' | 25 | import { createUser } from '../../../../shared/extra-utils/users/users' |
26 | import { | 26 | import { |
27 | addVideoCommentReply, | 27 | addVideoCommentReply, |
28 | addVideoCommentThread, | 28 | addVideoCommentThread, |
29 | getVideoCommentThreads, | 29 | getVideoCommentThreads, |
30 | getVideoThreadComments | 30 | getVideoThreadComments |
31 | } from '../../../../shared/utils/videos/video-comments' | 31 | } from '../../../../shared/extra-utils/videos/video-comments' |
32 | import { rateVideo } from '../../../../shared/utils/videos/videos' | 32 | import { rateVideo } from '../../../../shared/extra-utils/videos/videos' |
33 | import { waitJobs } from '../../../../shared/utils/server/jobs' | 33 | import { waitJobs } from '../../../../shared/extra-utils/server/jobs' |
34 | import { createVideoCaption, listVideoCaptions, testCaptionFile } from '../../../../shared/utils/videos/video-captions' | 34 | import { createVideoCaption, listVideoCaptions, testCaptionFile } from '../../../../shared/extra-utils/videos/video-captions' |
35 | import { VideoCaption } from '../../../../shared/models/videos/caption/video-caption.model' | 35 | import { VideoCaption } from '../../../../shared/models/videos/caption/video-caption.model' |
36 | 36 | ||
37 | const expect = chai.expect | 37 | const expect = chai.expect |
@@ -241,7 +241,7 @@ describe('Test follows', function () { | |||
241 | expect(res.body.data[0].name).to.equal('server3') | 241 | expect(res.body.data[0].name).to.equal('server3') |
242 | }) | 242 | }) |
243 | 243 | ||
244 | describe('Should propagate data on a new following', async function () { | 244 | describe('Should propagate data on a new following', function () { |
245 | let video4: Video | 245 | let video4: Video |
246 | 246 | ||
247 | before(async function () { | 247 | before(async function () { |
@@ -263,7 +263,7 @@ describe('Test follows', function () { | |||
263 | 263 | ||
264 | { | 264 | { |
265 | const user = { username: 'captain', password: 'password' } | 265 | const user = { username: 'captain', password: 'password' } |
266 | await createUser(servers[ 2 ].url, servers[ 2 ].accessToken, user.username, user.password) | 266 | await createUser({ url: servers[ 2 ].url, accessToken: servers[ 2 ].accessToken, username: user.username, password: user.password }) |
267 | const userAccessToken = await userLogin(servers[ 2 ], user) | 267 | const userAccessToken = await userLogin(servers[ 2 ], user) |
268 | 268 | ||
269 | const resVideos = await getVideosList(servers[ 2 ].url) | 269 | const resVideos = await getVideosList(servers[ 2 ].url) |
@@ -348,6 +348,7 @@ describe('Test follows', function () { | |||
348 | }, | 348 | }, |
349 | isLocal, | 349 | isLocal, |
350 | commentsEnabled: true, | 350 | commentsEnabled: true, |
351 | downloadEnabled: true, | ||
351 | duration: 5, | 352 | duration: 5, |
352 | tags: [ 'tag1', 'tag2', 'tag3' ], | 353 | tags: [ 'tag1', 'tag2', 'tag3' ], |
353 | privacy: VideoPrivacy.PUBLIC, | 354 | privacy: VideoPrivacy.PUBLIC, |
@@ -435,6 +436,6 @@ describe('Test follows', function () { | |||
435 | }) | 436 | }) |
436 | 437 | ||
437 | after(async function () { | 438 | after(async function () { |
438 | killallServers(servers) | 439 | await cleanupTests(servers) |
439 | }) | 440 | }) |
440 | }) | 441 | }) |
diff --git a/server/tests/api/server/handle-down.ts b/server/tests/api/server/handle-down.ts index cd7baadad..19010dbc1 100644 --- a/server/tests/api/server/handle-down.ts +++ b/server/tests/api/server/handle-down.ts | |||
@@ -7,6 +7,7 @@ import { VideoPrivacy } from '../../../../shared/models/videos' | |||
7 | import { VideoCommentThreadTree } from '../../../../shared/models/videos/video-comment.model' | 7 | import { VideoCommentThreadTree } from '../../../../shared/models/videos/video-comment.model' |
8 | 8 | ||
9 | import { | 9 | import { |
10 | cleanupTests, | ||
10 | completeVideoCheck, | 11 | completeVideoCheck, |
11 | flushAndRunMultipleServers, | 12 | flushAndRunMultipleServers, |
12 | getVideo, | 13 | getVideo, |
@@ -20,15 +21,15 @@ import { | |||
20 | updateVideo, | 21 | updateVideo, |
21 | uploadVideo, | 22 | uploadVideo, |
22 | wait | 23 | wait |
23 | } from '../../../../shared/utils' | 24 | } from '../../../../shared/extra-utils' |
24 | import { follow, getFollowersListPaginationAndSort } from '../../../../shared/utils/server/follows' | 25 | import { follow, getFollowersListPaginationAndSort } from '../../../../shared/extra-utils/server/follows' |
25 | import { getJobsListPaginationAndSort, waitJobs } from '../../../../shared/utils/server/jobs' | 26 | import { getJobsListPaginationAndSort, waitJobs } from '../../../../shared/extra-utils/server/jobs' |
26 | import { | 27 | import { |
27 | addVideoCommentReply, | 28 | addVideoCommentReply, |
28 | addVideoCommentThread, | 29 | addVideoCommentThread, |
29 | getVideoCommentThreads, | 30 | getVideoCommentThreads, |
30 | getVideoThreadComments | 31 | getVideoThreadComments |
31 | } from '../../../../shared/utils/videos/video-comments' | 32 | } from '../../../../shared/extra-utils/videos/video-comments' |
32 | 33 | ||
33 | const expect = chai.expect | 34 | const expect = chai.expect |
34 | 35 | ||
@@ -76,6 +77,7 @@ describe('Test handle downs', function () { | |||
76 | tags: [ 'tag1p1', 'tag2p1' ], | 77 | tags: [ 'tag1p1', 'tag2p1' ], |
77 | privacy: VideoPrivacy.PUBLIC, | 78 | privacy: VideoPrivacy.PUBLIC, |
78 | commentsEnabled: true, | 79 | commentsEnabled: true, |
80 | downloadEnabled: true, | ||
79 | channel: { | 81 | channel: { |
80 | name: 'root_channel', | 82 | name: 'root_channel', |
81 | displayName: 'Main root channel', | 83 | displayName: 'Main root channel', |
@@ -296,6 +298,6 @@ describe('Test handle downs', function () { | |||
296 | }) | 298 | }) |
297 | 299 | ||
298 | after(async function () { | 300 | after(async function () { |
299 | killallServers(servers) | 301 | await cleanupTests(servers) |
300 | }) | 302 | }) |
301 | }) | 303 | }) |
diff --git a/server/tests/api/server/index.ts b/server/tests/api/server/index.ts index 1f80cc6cf..94c15e0d0 100644 --- a/server/tests/api/server/index.ts +++ b/server/tests/api/server/index.ts | |||
@@ -3,8 +3,10 @@ import './contact-form' | |||
3 | import './email' | 3 | import './email' |
4 | import './follow-constraints' | 4 | import './follow-constraints' |
5 | import './follows' | 5 | import './follows' |
6 | import './follows-moderation' | ||
6 | import './handle-down' | 7 | import './handle-down' |
7 | import './jobs' | 8 | import './jobs' |
9 | import './logs' | ||
8 | import './reverse-proxy' | 10 | import './reverse-proxy' |
9 | import './stats' | 11 | import './stats' |
10 | import './tracker' | 12 | import './tracker' |
diff --git a/server/tests/api/server/jobs.ts b/server/tests/api/server/jobs.ts index 52948b1d6..634654626 100644 --- a/server/tests/api/server/jobs.ts +++ b/server/tests/api/server/jobs.ts | |||
@@ -2,12 +2,12 @@ | |||
2 | 2 | ||
3 | import * as chai from 'chai' | 3 | import * as chai from 'chai' |
4 | import 'mocha' | 4 | import 'mocha' |
5 | import { killallServers, ServerInfo, setAccessTokensToServers } from '../../../../shared/utils/index' | 5 | import { cleanupTests, killallServers, ServerInfo, setAccessTokensToServers } from '../../../../shared/extra-utils/index' |
6 | import { doubleFollow } from '../../../../shared/utils/server/follows' | 6 | import { doubleFollow } from '../../../../shared/extra-utils/server/follows' |
7 | import { getJobsList, getJobsListPaginationAndSort, waitJobs } from '../../../../shared/utils/server/jobs' | 7 | import { getJobsList, getJobsListPaginationAndSort, waitJobs } from '../../../../shared/extra-utils/server/jobs' |
8 | import { flushAndRunMultipleServers } from '../../../../shared/utils/server/servers' | 8 | import { flushAndRunMultipleServers } from '../../../../shared/extra-utils/server/servers' |
9 | import { uploadVideo } from '../../../../shared/utils/videos/videos' | 9 | import { uploadVideo } from '../../../../shared/extra-utils/videos/videos' |
10 | import { dateIsValid } from '../../../../shared/utils/miscs/miscs' | 10 | import { dateIsValid } from '../../../../shared/extra-utils/miscs/miscs' |
11 | 11 | ||
12 | const expect = chai.expect | 12 | const expect = chai.expect |
13 | 13 | ||
@@ -57,6 +57,6 @@ describe('Test jobs', function () { | |||
57 | }) | 57 | }) |
58 | 58 | ||
59 | after(async function () { | 59 | after(async function () { |
60 | killallServers(servers) | 60 | await cleanupTests(servers) |
61 | }) | 61 | }) |
62 | }) | 62 | }) |
diff --git a/server/tests/api/server/logs.ts b/server/tests/api/server/logs.ts new file mode 100644 index 000000000..3644fa0d3 --- /dev/null +++ b/server/tests/api/server/logs.ts | |||
@@ -0,0 +1,97 @@ | |||
1 | /* tslint:disable:no-unused-expression */ | ||
2 | |||
3 | import * as chai from 'chai' | ||
4 | import 'mocha' | ||
5 | import { | ||
6 | flushTests, | ||
7 | killallServers, | ||
8 | flushAndRunServer, | ||
9 | ServerInfo, | ||
10 | setAccessTokensToServers, | ||
11 | cleanupTests | ||
12 | } from '../../../../shared/extra-utils/index' | ||
13 | import { waitJobs } from '../../../../shared/extra-utils/server/jobs' | ||
14 | import { uploadVideo } from '../../../../shared/extra-utils/videos/videos' | ||
15 | import { getLogs } from '../../../../shared/extra-utils/logs/logs' | ||
16 | |||
17 | const expect = chai.expect | ||
18 | |||
19 | describe('Test logs', function () { | ||
20 | let server: ServerInfo | ||
21 | |||
22 | before(async function () { | ||
23 | this.timeout(30000) | ||
24 | |||
25 | server = await flushAndRunServer(1) | ||
26 | await setAccessTokensToServers([ server ]) | ||
27 | }) | ||
28 | |||
29 | it('Should get logs with a start date', async function () { | ||
30 | this.timeout(10000) | ||
31 | |||
32 | await uploadVideo(server.url, server.accessToken, { name: 'video 1' }) | ||
33 | await waitJobs([ server ]) | ||
34 | |||
35 | const now = new Date() | ||
36 | |||
37 | await uploadVideo(server.url, server.accessToken, { name: 'video 2' }) | ||
38 | await waitJobs([ server ]) | ||
39 | |||
40 | const res = await getLogs(server.url, server.accessToken, now) | ||
41 | const logsString = JSON.stringify(res.body) | ||
42 | |||
43 | expect(logsString.includes('video 1')).to.be.false | ||
44 | expect(logsString.includes('video 2')).to.be.true | ||
45 | }) | ||
46 | |||
47 | it('Should get logs with an end date', async function () { | ||
48 | this.timeout(10000) | ||
49 | |||
50 | await uploadVideo(server.url, server.accessToken, { name: 'video 3' }) | ||
51 | await waitJobs([ server ]) | ||
52 | |||
53 | const now1 = new Date() | ||
54 | |||
55 | await uploadVideo(server.url, server.accessToken, { name: 'video 4' }) | ||
56 | await waitJobs([ server ]) | ||
57 | |||
58 | const now2 = new Date() | ||
59 | |||
60 | await uploadVideo(server.url, server.accessToken, { name: 'video 5' }) | ||
61 | await waitJobs([ server ]) | ||
62 | |||
63 | const res = await getLogs(server.url, server.accessToken, now1, now2) | ||
64 | const logsString = JSON.stringify(res.body) | ||
65 | |||
66 | expect(logsString.includes('video 3')).to.be.false | ||
67 | expect(logsString.includes('video 4')).to.be.true | ||
68 | expect(logsString.includes('video 5')).to.be.false | ||
69 | }) | ||
70 | |||
71 | it('Should get filter by level', async function () { | ||
72 | this.timeout(10000) | ||
73 | |||
74 | const now = new Date() | ||
75 | |||
76 | await uploadVideo(server.url, server.accessToken, { name: 'video 6' }) | ||
77 | await waitJobs([ server ]) | ||
78 | |||
79 | { | ||
80 | const res = await getLogs(server.url, server.accessToken, now, undefined, 'info') | ||
81 | const logsString = JSON.stringify(res.body) | ||
82 | |||
83 | expect(logsString.includes('video 6')).to.be.true | ||
84 | } | ||
85 | |||
86 | { | ||
87 | const res = await getLogs(server.url, server.accessToken, now, undefined, 'warn') | ||
88 | const logsString = JSON.stringify(res.body) | ||
89 | |||
90 | expect(logsString.includes('video 6')).to.be.false | ||
91 | } | ||
92 | }) | ||
93 | |||
94 | after(async function () { | ||
95 | await cleanupTests([ server ]) | ||
96 | }) | ||
97 | }) | ||
diff --git a/server/tests/api/server/no-client.ts b/server/tests/api/server/no-client.ts index 3b95ce945..86edeb289 100644 --- a/server/tests/api/server/no-client.ts +++ b/server/tests/api/server/no-client.ts | |||
@@ -1,11 +1,7 @@ | |||
1 | import 'mocha' | 1 | import 'mocha' |
2 | import * as request from 'supertest' | 2 | import * as request from 'supertest' |
3 | import { | 3 | import { ServerInfo } from '../../../../shared/extra-utils' |
4 | flushTests, | 4 | import { cleanupTests, flushAndRunServer } from '../../../../shared/extra-utils/server/servers' |
5 | killallServers, | ||
6 | ServerInfo | ||
7 | } from '../../../../shared/utils' | ||
8 | import { runServer } from '../../../../shared/utils/server/servers' | ||
9 | 5 | ||
10 | describe('Start and stop server without web client routes', function () { | 6 | describe('Start and stop server without web client routes', function () { |
11 | let server: ServerInfo | 7 | let server: ServerInfo |
@@ -13,9 +9,7 @@ describe('Start and stop server without web client routes', function () { | |||
13 | before(async function () { | 9 | before(async function () { |
14 | this.timeout(30000) | 10 | this.timeout(30000) |
15 | 11 | ||
16 | await flushTests() | 12 | server = await flushAndRunServer(1, {}, ['--no-client']) |
17 | |||
18 | server = await runServer(1, {}, ['--no-client']) | ||
19 | }) | 13 | }) |
20 | 14 | ||
21 | it('Should fail getting the client', function () { | 15 | it('Should fail getting the client', function () { |
@@ -26,11 +20,6 @@ describe('Start and stop server without web client routes', function () { | |||
26 | }) | 20 | }) |
27 | 21 | ||
28 | after(async function () { | 22 | after(async function () { |
29 | killallServers([ server ]) | 23 | await cleanupTests([ server ]) |
30 | |||
31 | // Keep the logs if the test failed | ||
32 | if (this['ok']) { | ||
33 | await flushTests() | ||
34 | } | ||
35 | }) | 24 | }) |
36 | }) | 25 | }) |
diff --git a/server/tests/api/server/reverse-proxy.ts b/server/tests/api/server/reverse-proxy.ts index d4c08c346..987538237 100644 --- a/server/tests/api/server/reverse-proxy.ts +++ b/server/tests/api/server/reverse-proxy.ts | |||
@@ -2,28 +2,10 @@ | |||
2 | 2 | ||
3 | import 'mocha' | 3 | import 'mocha' |
4 | import * as chai from 'chai' | 4 | import * as chai from 'chai' |
5 | import { About } from '../../../../shared/models/server/about.model' | 5 | import { cleanupTests, getVideo, uploadVideo, userLogin, viewVideo, wait } from '../../../../shared/extra-utils' |
6 | import { CustomConfig } from '../../../../shared/models/server/custom-config.model' | 6 | import { flushAndRunServer, setAccessTokensToServers } from '../../../../shared/extra-utils/index' |
7 | import { | ||
8 | deleteCustomConfig, | ||
9 | getAbout, | ||
10 | getVideo, | ||
11 | killallServers, | ||
12 | login, | ||
13 | reRunServer, | ||
14 | uploadVideo, | ||
15 | userLogin, | ||
16 | viewVideo, | ||
17 | wait | ||
18 | } from '../../../../shared/utils' | ||
19 | const expect = chai.expect | ||
20 | 7 | ||
21 | import { | 8 | const expect = chai.expect |
22 | getConfig, | ||
23 | flushTests, | ||
24 | runServer, | ||
25 | registerUser, getCustomConfig, setAccessTokensToServers, updateCustomConfig | ||
26 | } from '../../../../shared/utils/index' | ||
27 | 9 | ||
28 | describe('Test application behind a reverse proxy', function () { | 10 | describe('Test application behind a reverse proxy', function () { |
29 | let server = null | 11 | let server = null |
@@ -31,9 +13,7 @@ describe('Test application behind a reverse proxy', function () { | |||
31 | 13 | ||
32 | before(async function () { | 14 | before(async function () { |
33 | this.timeout(30000) | 15 | this.timeout(30000) |
34 | 16 | server = await flushAndRunServer(1) | |
35 | await flushTests() | ||
36 | server = await runServer(1) | ||
37 | await setAccessTokensToServers([ server ]) | 17 | await setAccessTokensToServers([ server ]) |
38 | 18 | ||
39 | const { body } = await uploadVideo(server.url, server.accessToken, {}) | 19 | const { body } = await uploadVideo(server.url, server.accessToken, {}) |
@@ -95,7 +75,7 @@ describe('Test application behind a reverse proxy', function () { | |||
95 | it('Should rate limit logins', async function () { | 75 | it('Should rate limit logins', async function () { |
96 | const user = { username: 'root', password: 'fail' } | 76 | const user = { username: 'root', password: 'fail' } |
97 | 77 | ||
98 | for (let i = 0; i < 14; i++) { | 78 | for (let i = 0; i < 19; i++) { |
99 | await userLogin(server, user, 400) | 79 | await userLogin(server, user, 400) |
100 | } | 80 | } |
101 | 81 | ||
@@ -103,6 +83,6 @@ describe('Test application behind a reverse proxy', function () { | |||
103 | }) | 83 | }) |
104 | 84 | ||
105 | after(async function () { | 85 | after(async function () { |
106 | killallServers([ server ]) | 86 | await cleanupTests([ server ]) |
107 | }) | 87 | }) |
108 | }) | 88 | }) |
diff --git a/server/tests/api/server/stats.ts b/server/tests/api/server/stats.ts index aaa6c62f7..a01cd4b38 100644 --- a/server/tests/api/server/stats.ts +++ b/server/tests/api/server/stats.ts | |||
@@ -4,6 +4,7 @@ import * as chai from 'chai' | |||
4 | import 'mocha' | 4 | import 'mocha' |
5 | import { ServerStats } from '../../../../shared/models/server/server-stats.model' | 5 | import { ServerStats } from '../../../../shared/models/server/server-stats.model' |
6 | import { | 6 | import { |
7 | cleanupTests, | ||
7 | createUser, | 8 | createUser, |
8 | doubleFollow, | 9 | doubleFollow, |
9 | flushAndRunMultipleServers, | 10 | flushAndRunMultipleServers, |
@@ -13,11 +14,11 @@ import { | |||
13 | uploadVideo, | 14 | uploadVideo, |
14 | viewVideo, | 15 | viewVideo, |
15 | wait | 16 | wait |
16 | } from '../../../../shared/utils' | 17 | } from '../../../../shared/extra-utils' |
17 | import { flushTests, setAccessTokensToServers } from '../../../../shared/utils/index' | 18 | import { flushTests, setAccessTokensToServers } from '../../../../shared/extra-utils/index' |
18 | import { getStats } from '../../../../shared/utils/server/stats' | 19 | import { getStats } from '../../../../shared/extra-utils/server/stats' |
19 | import { addVideoCommentThread } from '../../../../shared/utils/videos/video-comments' | 20 | import { addVideoCommentThread } from '../../../../shared/extra-utils/videos/video-comments' |
20 | import { waitJobs } from '../../../../shared/utils/server/jobs' | 21 | import { waitJobs } from '../../../../shared/extra-utils/server/jobs' |
21 | 22 | ||
22 | const expect = chai.expect | 23 | const expect = chai.expect |
23 | 24 | ||
@@ -26,8 +27,6 @@ describe('Test stats (excluding redundancy)', function () { | |||
26 | 27 | ||
27 | before(async function () { | 28 | before(async function () { |
28 | this.timeout(60000) | 29 | this.timeout(60000) |
29 | |||
30 | await flushTests() | ||
31 | servers = await flushAndRunMultipleServers(3) | 30 | servers = await flushAndRunMultipleServers(3) |
32 | await setAccessTokensToServers(servers) | 31 | await setAccessTokensToServers(servers) |
33 | 32 | ||
@@ -37,7 +36,7 @@ describe('Test stats (excluding redundancy)', function () { | |||
37 | username: 'user1', | 36 | username: 'user1', |
38 | password: 'super_password' | 37 | password: 'super_password' |
39 | } | 38 | } |
40 | await createUser(servers[0].url, servers[0].accessToken, user.username, user.password) | 39 | await createUser({ url: servers[ 0 ].url, accessToken: servers[ 0 ].accessToken, username: user.username, password: user.password }) |
41 | 40 | ||
42 | const resVideo = await uploadVideo(servers[0].url, servers[0].accessToken, { fixture: 'video_short.webm' }) | 41 | const resVideo = await uploadVideo(servers[0].url, servers[0].accessToken, { fixture: 'video_short.webm' }) |
43 | const videoUUID = resVideo.body.video.uuid | 42 | const videoUUID = resVideo.body.video.uuid |
@@ -98,6 +97,6 @@ describe('Test stats (excluding redundancy)', function () { | |||
98 | }) | 97 | }) |
99 | 98 | ||
100 | after(async function () { | 99 | after(async function () { |
101 | killallServers(servers) | 100 | await cleanupTests(servers) |
102 | }) | 101 | }) |
103 | }) | 102 | }) |
diff --git a/server/tests/api/server/tracker.ts b/server/tests/api/server/tracker.ts index 25ca00029..9d7eec8ca 100644 --- a/server/tests/api/server/tracker.ts +++ b/server/tests/api/server/tracker.ts | |||
@@ -2,8 +2,16 @@ | |||
2 | 2 | ||
3 | import * as magnetUtil from 'magnet-uri' | 3 | import * as magnetUtil from 'magnet-uri' |
4 | import 'mocha' | 4 | import 'mocha' |
5 | import { getVideo, killallServers, runServer, ServerInfo, uploadVideo } from '../../../../shared/utils' | 5 | import { |
6 | import { flushTests, setAccessTokensToServers } from '../../../../shared/utils/index' | 6 | cleanupTests, |
7 | flushAndRunServer, | ||
8 | getVideo, | ||
9 | killallServers, | ||
10 | reRunServer, | ||
11 | ServerInfo, | ||
12 | uploadVideo | ||
13 | } from '../../../../shared/extra-utils' | ||
14 | import { setAccessTokensToServers } from '../../../../shared/extra-utils/index' | ||
7 | import { VideoDetails } from '../../../../shared/models/videos' | 15 | import { VideoDetails } from '../../../../shared/models/videos' |
8 | import * as WebTorrent from 'webtorrent' | 16 | import * as WebTorrent from 'webtorrent' |
9 | 17 | ||
@@ -14,9 +22,7 @@ describe('Test tracker', function () { | |||
14 | 22 | ||
15 | before(async function () { | 23 | before(async function () { |
16 | this.timeout(60000) | 24 | this.timeout(60000) |
17 | 25 | server = await flushAndRunServer(1) | |
18 | await flushTests() | ||
19 | server = await runServer(1) | ||
20 | await setAccessTokensToServers([ server ]) | 26 | await setAccessTokensToServers([ server ]) |
21 | 27 | ||
22 | { | 28 | { |
@@ -34,7 +40,7 @@ describe('Test tracker', function () { | |||
34 | } | 40 | } |
35 | }) | 41 | }) |
36 | 42 | ||
37 | it('Should return an error when adding an incorrect infohash', done => { | 43 | it('Should return an error when adding an incorrect infohash', function (done) { |
38 | this.timeout(10000) | 44 | this.timeout(10000) |
39 | const webtorrent = new WebTorrent() | 45 | const webtorrent = new WebTorrent() |
40 | 46 | ||
@@ -49,7 +55,7 @@ describe('Test tracker', function () { | |||
49 | torrent.on('done', () => done(new Error('No error on infohash'))) | 55 | torrent.on('done', () => done(new Error('No error on infohash'))) |
50 | }) | 56 | }) |
51 | 57 | ||
52 | it('Should succeed with the correct infohash', done => { | 58 | it('Should succeed with the correct infohash', function (done) { |
53 | this.timeout(10000) | 59 | this.timeout(10000) |
54 | const webtorrent = new WebTorrent() | 60 | const webtorrent = new WebTorrent() |
55 | 61 | ||
@@ -64,7 +70,27 @@ describe('Test tracker', function () { | |||
64 | torrent.on('done', done) | 70 | torrent.on('done', done) |
65 | }) | 71 | }) |
66 | 72 | ||
67 | after(async function () { | 73 | it('Should disable the tracker', function (done) { |
74 | this.timeout(20000) | ||
75 | |||
68 | killallServers([ server ]) | 76 | killallServers([ server ]) |
77 | reRunServer(server, { tracker: { enabled: false } }) | ||
78 | .then(() => { | ||
79 | const webtorrent = new WebTorrent() | ||
80 | |||
81 | const torrent = webtorrent.add(goodMagnet) | ||
82 | |||
83 | torrent.on('error', done) | ||
84 | torrent.on('warning', warn => { | ||
85 | const message = typeof warn === 'string' ? warn : warn.message | ||
86 | if (message.indexOf('disabled ') !== -1) return done() | ||
87 | }) | ||
88 | |||
89 | torrent.on('done', () => done(new Error('Tracker is enabled'))) | ||
90 | }) | ||
91 | }) | ||
92 | |||
93 | after(async function () { | ||
94 | await cleanupTests([ server ]) | ||
69 | }) | 95 | }) |
70 | }) | 96 | }) |
diff --git a/server/tests/api/users/blocklist.ts b/server/tests/api/users/blocklist.ts index 4bca27a94..fbc57e0ef 100644 --- a/server/tests/api/users/blocklist.ts +++ b/server/tests/api/users/blocklist.ts | |||
@@ -4,6 +4,7 @@ import * as chai from 'chai' | |||
4 | import 'mocha' | 4 | import 'mocha' |
5 | import { AccountBlock, ServerBlock, Video } from '../../../../shared/index' | 5 | import { AccountBlock, ServerBlock, Video } from '../../../../shared/index' |
6 | import { | 6 | import { |
7 | cleanupTests, | ||
7 | createUser, | 8 | createUser, |
8 | doubleFollow, | 9 | doubleFollow, |
9 | flushAndRunMultipleServers, | 10 | flushAndRunMultipleServers, |
@@ -12,16 +13,16 @@ import { | |||
12 | ServerInfo, | 13 | ServerInfo, |
13 | uploadVideo, | 14 | uploadVideo, |
14 | userLogin | 15 | userLogin |
15 | } from '../../../../shared/utils/index' | 16 | } from '../../../../shared/extra-utils/index' |
16 | import { setAccessTokensToServers } from '../../../../shared/utils/users/login' | 17 | import { setAccessTokensToServers } from '../../../../shared/extra-utils/users/login' |
17 | import { getVideosListWithToken, getVideosList } from '../../../../shared/utils/videos/videos' | 18 | import { getVideosListWithToken, getVideosList } from '../../../../shared/extra-utils/videos/videos' |
18 | import { | 19 | import { |
19 | addVideoCommentReply, | 20 | addVideoCommentReply, |
20 | addVideoCommentThread, | 21 | addVideoCommentThread, |
21 | getVideoCommentThreads, | 22 | getVideoCommentThreads, |
22 | getVideoThreadComments | 23 | getVideoThreadComments |
23 | } from '../../../../shared/utils/videos/video-comments' | 24 | } from '../../../../shared/extra-utils/videos/video-comments' |
24 | import { waitJobs } from '../../../../shared/utils/server/jobs' | 25 | import { waitJobs } from '../../../../shared/extra-utils/server/jobs' |
25 | import { VideoComment, VideoCommentThreadTree } from '../../../../shared/models/videos/video-comment.model' | 26 | import { VideoComment, VideoCommentThreadTree } from '../../../../shared/models/videos/video-comment.model' |
26 | import { | 27 | import { |
27 | addAccountToAccountBlocklist, | 28 | addAccountToAccountBlocklist, |
@@ -36,7 +37,7 @@ import { | |||
36 | removeAccountFromServerBlocklist, | 37 | removeAccountFromServerBlocklist, |
37 | removeServerFromAccountBlocklist, | 38 | removeServerFromAccountBlocklist, |
38 | removeServerFromServerBlocklist | 39 | removeServerFromServerBlocklist |
39 | } from '../../../../shared/utils/users/blocklist' | 40 | } from '../../../../shared/extra-utils/users/blocklist' |
40 | 41 | ||
41 | const expect = chai.expect | 42 | const expect = chai.expect |
42 | 43 | ||
@@ -79,14 +80,12 @@ describe('Test blocklist', function () { | |||
79 | before(async function () { | 80 | before(async function () { |
80 | this.timeout(60000) | 81 | this.timeout(60000) |
81 | 82 | ||
82 | await flushTests() | ||
83 | |||
84 | servers = await flushAndRunMultipleServers(2) | 83 | servers = await flushAndRunMultipleServers(2) |
85 | await setAccessTokensToServers(servers) | 84 | await setAccessTokensToServers(servers) |
86 | 85 | ||
87 | { | 86 | { |
88 | const user = { username: 'user1', password: 'password' } | 87 | const user = { username: 'user1', password: 'password' } |
89 | await createUser(servers[0].url, servers[0].accessToken, user.username, user.password) | 88 | await createUser({ url: servers[ 0 ].url, accessToken: servers[ 0 ].accessToken, username: user.username, password: user.password }) |
90 | 89 | ||
91 | userToken1 = await userLogin(servers[0], user) | 90 | userToken1 = await userLogin(servers[0], user) |
92 | await uploadVideo(servers[0].url, userToken1, { name: 'video user 1' }) | 91 | await uploadVideo(servers[0].url, userToken1, { name: 'video user 1' }) |
@@ -94,14 +93,14 @@ describe('Test blocklist', function () { | |||
94 | 93 | ||
95 | { | 94 | { |
96 | const user = { username: 'moderator', password: 'password' } | 95 | const user = { username: 'moderator', password: 'password' } |
97 | await createUser(servers[0].url, servers[0].accessToken, user.username, user.password) | 96 | await createUser({ url: servers[ 0 ].url, accessToken: servers[ 0 ].accessToken, username: user.username, password: user.password }) |
98 | 97 | ||
99 | userModeratorToken = await userLogin(servers[0], user) | 98 | userModeratorToken = await userLogin(servers[0], user) |
100 | } | 99 | } |
101 | 100 | ||
102 | { | 101 | { |
103 | const user = { username: 'user2', password: 'password' } | 102 | const user = { username: 'user2', password: 'password' } |
104 | await createUser(servers[1].url, servers[1].accessToken, user.username, user.password) | 103 | await createUser({ url: servers[ 1 ].url, accessToken: servers[ 1 ].accessToken, username: user.username, password: user.password }) |
105 | 104 | ||
106 | userToken2 = await userLogin(servers[1], user) | 105 | userToken2 = await userLogin(servers[1], user) |
107 | await uploadVideo(servers[1].url, userToken2, { name: 'video user 2' }) | 106 | await uploadVideo(servers[1].url, userToken2, { name: 'video user 2' }) |
@@ -501,11 +500,6 @@ describe('Test blocklist', function () { | |||
501 | }) | 500 | }) |
502 | 501 | ||
503 | after(async function () { | 502 | after(async function () { |
504 | killallServers(servers) | 503 | await cleanupTests(servers) |
505 | |||
506 | // Keep the logs if the test failed | ||
507 | if (this[ 'ok' ]) { | ||
508 | await flushTests() | ||
509 | } | ||
510 | }) | 504 | }) |
511 | }) | 505 | }) |
diff --git a/server/tests/api/users/index.ts b/server/tests/api/users/index.ts index 52ba6984e..fcd022429 100644 --- a/server/tests/api/users/index.ts +++ b/server/tests/api/users/index.ts | |||
@@ -1,5 +1,4 @@ | |||
1 | import './users-verification' | 1 | import './users-verification' |
2 | import './user-notifications' | ||
3 | import './blocklist' | 2 | import './blocklist' |
4 | import './user-subscriptions' | 3 | import './user-subscriptions' |
5 | import './users' | 4 | import './users' |
diff --git a/server/tests/api/users/user-subscriptions.ts b/server/tests/api/users/user-subscriptions.ts index 88a7187d6..48811e647 100644 --- a/server/tests/api/users/user-subscriptions.ts +++ b/server/tests/api/users/user-subscriptions.ts | |||
@@ -3,6 +3,7 @@ | |||
3 | import * as chai from 'chai' | 3 | import * as chai from 'chai' |
4 | import 'mocha' | 4 | import 'mocha' |
5 | import { | 5 | import { |
6 | cleanupTests, | ||
6 | createUser, | 7 | createUser, |
7 | doubleFollow, | 8 | doubleFollow, |
8 | flushAndRunMultipleServers, | 9 | flushAndRunMultipleServers, |
@@ -11,18 +12,18 @@ import { | |||
11 | unfollow, | 12 | unfollow, |
12 | updateVideo, | 13 | updateVideo, |
13 | userLogin | 14 | userLogin |
14 | } from '../../../../shared/utils' | 15 | } from '../../../../shared/extra-utils' |
15 | import { killallServers, ServerInfo, uploadVideo } from '../../../../shared/utils/index' | 16 | import { killallServers, ServerInfo, uploadVideo } from '../../../../shared/extra-utils/index' |
16 | import { setAccessTokensToServers } from '../../../../shared/utils/users/login' | 17 | import { setAccessTokensToServers } from '../../../../shared/extra-utils/users/login' |
17 | import { Video, VideoChannel } from '../../../../shared/models/videos' | 18 | import { Video, VideoChannel } from '../../../../shared/models/videos' |
18 | import { waitJobs } from '../../../../shared/utils/server/jobs' | 19 | import { waitJobs } from '../../../../shared/extra-utils/server/jobs' |
19 | import { | 20 | import { |
20 | addUserSubscription, | 21 | addUserSubscription, |
21 | listUserSubscriptions, | 22 | listUserSubscriptions, |
22 | listUserSubscriptionVideos, | 23 | listUserSubscriptionVideos, |
23 | removeUserSubscription, | 24 | removeUserSubscription, |
24 | getUserSubscription, areSubscriptionsExist | 25 | getUserSubscription, areSubscriptionsExist |
25 | } from '../../../../shared/utils/users/user-subscriptions' | 26 | } from '../../../../shared/extra-utils/users/user-subscriptions' |
26 | 27 | ||
27 | const expect = chai.expect | 28 | const expect = chai.expect |
28 | 29 | ||
@@ -45,7 +46,7 @@ describe('Test users subscriptions', function () { | |||
45 | { | 46 | { |
46 | for (const server of servers) { | 47 | for (const server of servers) { |
47 | const user = { username: 'user' + server.serverNumber, password: 'password' } | 48 | const user = { username: 'user' + server.serverNumber, password: 'password' } |
48 | await createUser(server.url, server.accessToken, user.username, user.password) | 49 | await createUser({ url: server.url, accessToken: server.accessToken, username: user.username, password: user.password }) |
49 | 50 | ||
50 | const accessToken = await userLogin(server, user) | 51 | const accessToken = await userLogin(server, user) |
51 | users.push({ accessToken }) | 52 | users.push({ accessToken }) |
@@ -369,6 +370,6 @@ describe('Test users subscriptions', function () { | |||
369 | }) | 370 | }) |
370 | 371 | ||
371 | after(async function () { | 372 | after(async function () { |
372 | killallServers(servers) | 373 | await cleanupTests(servers) |
373 | }) | 374 | }) |
374 | }) | 375 | }) |
diff --git a/server/tests/api/users/users-multiple-servers.ts b/server/tests/api/users/users-multiple-servers.ts index 006d6cdf0..9a971adb3 100644 --- a/server/tests/api/users/users-multiple-servers.ts +++ b/server/tests/api/users/users-multiple-servers.ts | |||
@@ -4,7 +4,8 @@ import * as chai from 'chai' | |||
4 | import 'mocha' | 4 | import 'mocha' |
5 | import { Account } from '../../../../shared/models/actors' | 5 | import { Account } from '../../../../shared/models/actors' |
6 | import { | 6 | import { |
7 | checkVideoFilesWereRemoved, | 7 | checkTmpIsEmpty, |
8 | checkVideoFilesWereRemoved, cleanupTests, | ||
8 | createUser, | 9 | createUser, |
9 | doubleFollow, | 10 | doubleFollow, |
10 | flushAndRunMultipleServers, | 11 | flushAndRunMultipleServers, |
@@ -13,13 +14,20 @@ import { | |||
13 | removeUser, | 14 | removeUser, |
14 | updateMyUser, | 15 | updateMyUser, |
15 | userLogin | 16 | userLogin |
16 | } from '../../../../shared/utils' | 17 | } from '../../../../shared/extra-utils' |
17 | import { getMyUserInformation, killallServers, ServerInfo, testImage, updateMyAvatar, uploadVideo } from '../../../../shared/utils/index' | 18 | import { |
18 | import { checkActorFilesWereRemoved, getAccount, getAccountsList } from '../../../../shared/utils/users/accounts' | 19 | getMyUserInformation, |
19 | import { setAccessTokensToServers } from '../../../../shared/utils/users/login' | 20 | killallServers, |
21 | ServerInfo, | ||
22 | testImage, | ||
23 | updateMyAvatar, | ||
24 | uploadVideo | ||
25 | } from '../../../../shared/extra-utils/index' | ||
26 | import { checkActorFilesWereRemoved, getAccount, getAccountsList } from '../../../../shared/extra-utils/users/accounts' | ||
27 | import { setAccessTokensToServers } from '../../../../shared/extra-utils/users/login' | ||
20 | import { User } from '../../../../shared/models/users' | 28 | import { User } from '../../../../shared/models/users' |
21 | import { VideoChannel } from '../../../../shared/models/videos' | 29 | import { VideoChannel } from '../../../../shared/models/videos' |
22 | import { waitJobs } from '../../../../shared/utils/server/jobs' | 30 | import { waitJobs } from '../../../../shared/extra-utils/server/jobs' |
23 | 31 | ||
24 | const expect = chai.expect | 32 | const expect = chai.expect |
25 | 33 | ||
@@ -56,7 +64,12 @@ describe('Test users with multiple servers', function () { | |||
56 | username: 'user1', | 64 | username: 'user1', |
57 | password: 'password' | 65 | password: 'password' |
58 | } | 66 | } |
59 | const res = await createUser(servers[ 0 ].url, servers[ 0 ].accessToken, user.username, user.password) | 67 | const res = await createUser({ |
68 | url: servers[ 0 ].url, | ||
69 | accessToken: servers[ 0 ].accessToken, | ||
70 | username: user.username, | ||
71 | password: user.password | ||
72 | }) | ||
60 | userId = res.body.user.id | 73 | userId = res.body.user.id |
61 | userAccessToken = await userLogin(servers[ 0 ], user) | 74 | userAccessToken = await userLogin(servers[ 0 ], user) |
62 | } | 75 | } |
@@ -216,7 +229,13 @@ describe('Test users with multiple servers', function () { | |||
216 | } | 229 | } |
217 | }) | 230 | }) |
218 | 231 | ||
232 | it('Should have an empty tmp directory', async function () { | ||
233 | for (const server of servers) { | ||
234 | await checkTmpIsEmpty(server) | ||
235 | } | ||
236 | }) | ||
237 | |||
219 | after(async function () { | 238 | after(async function () { |
220 | killallServers(servers) | 239 | await cleanupTests(servers) |
221 | }) | 240 | }) |
222 | }) | 241 | }) |
diff --git a/server/tests/api/users/users-verification.ts b/server/tests/api/users/users-verification.ts index babeda2b8..514acf2e7 100644 --- a/server/tests/api/users/users-verification.ts +++ b/server/tests/api/users/users-verification.ts | |||
@@ -4,11 +4,11 @@ import * as chai from 'chai' | |||
4 | import 'mocha' | 4 | import 'mocha' |
5 | import { | 5 | import { |
6 | registerUser, flushTests, getUserInformation, getMyUserInformation, killallServers, | 6 | registerUser, flushTests, getUserInformation, getMyUserInformation, killallServers, |
7 | userLogin, login, runServer, ServerInfo, verifyEmail, updateCustomSubConfig, wait | 7 | userLogin, login, flushAndRunServer, ServerInfo, verifyEmail, updateCustomSubConfig, wait, cleanupTests |
8 | } from '../../../../shared/utils' | 8 | } from '../../../../shared/extra-utils' |
9 | import { setAccessTokensToServers } from '../../../../shared/utils/users/login' | 9 | import { setAccessTokensToServers } from '../../../../shared/extra-utils/users/login' |
10 | import { MockSmtpServer } from '../../../../shared/utils/miscs/email' | 10 | import { MockSmtpServer } from '../../../../shared/extra-utils/miscs/email' |
11 | import { waitJobs } from '../../../../shared/utils/server/jobs' | 11 | import { waitJobs } from '../../../../shared/extra-utils/server/jobs' |
12 | 12 | ||
13 | const expect = chai.expect | 13 | const expect = chai.expect |
14 | 14 | ||
@@ -32,14 +32,12 @@ describe('Test users account verification', function () { | |||
32 | 32 | ||
33 | await MockSmtpServer.Instance.collectEmails(emails) | 33 | await MockSmtpServer.Instance.collectEmails(emails) |
34 | 34 | ||
35 | await flushTests() | ||
36 | |||
37 | const overrideConfig = { | 35 | const overrideConfig = { |
38 | smtp: { | 36 | smtp: { |
39 | hostname: 'localhost' | 37 | hostname: 'localhost' |
40 | } | 38 | } |
41 | } | 39 | } |
42 | server = await runServer(1, overrideConfig) | 40 | server = await flushAndRunServer(1, overrideConfig) |
43 | 41 | ||
44 | await setAccessTokensToServers([ server ]) | 42 | await setAccessTokensToServers([ server ]) |
45 | }) | 43 | }) |
@@ -124,11 +122,7 @@ describe('Test users account verification', function () { | |||
124 | 122 | ||
125 | after(async function () { | 123 | after(async function () { |
126 | MockSmtpServer.Instance.kill() | 124 | MockSmtpServer.Instance.kill() |
127 | killallServers([ server ]) | ||
128 | 125 | ||
129 | // Keep the logs if the test failed | 126 | await cleanupTests([ server ]) |
130 | if (this[ 'ok' ]) { | ||
131 | await flushTests() | ||
132 | } | ||
133 | }) | 127 | }) |
134 | }) | 128 | }) |
diff --git a/server/tests/api/users/users.ts b/server/tests/api/users/users.ts index ad98ab1c7..c8e32f3f5 100644 --- a/server/tests/api/users/users.ts +++ b/server/tests/api/users/users.ts | |||
@@ -2,12 +2,14 @@ | |||
2 | 2 | ||
3 | import * as chai from 'chai' | 3 | import * as chai from 'chai' |
4 | import 'mocha' | 4 | import 'mocha' |
5 | import { User, UserRole } from '../../../../shared/index' | 5 | import { User, UserRole, Video } from '../../../../shared/index' |
6 | import { | 6 | import { |
7 | blockUser, | 7 | blockUser, |
8 | cleanupTests, | ||
8 | createUser, | 9 | createUser, |
9 | deleteMe, | 10 | deleteMe, |
10 | flushTests, | 11 | flushAndRunServer, |
12 | getAccountRatings, | ||
11 | getBlacklistedVideosList, | 13 | getBlacklistedVideosList, |
12 | getMyUserInformation, | 14 | getMyUserInformation, |
13 | getMyUserVideoQuotaUsed, | 15 | getMyUserVideoQuotaUsed, |
@@ -16,14 +18,12 @@ import { | |||
16 | getUsersList, | 18 | getUsersList, |
17 | getUsersListPaginationAndSort, | 19 | getUsersListPaginationAndSort, |
18 | getVideosList, | 20 | getVideosList, |
19 | killallServers, | ||
20 | login, | 21 | login, |
21 | makePutBodyRequest, | 22 | makePutBodyRequest, |
22 | rateVideo, | 23 | rateVideo, |
23 | registerUser, | 24 | registerUser, |
24 | removeUser, | 25 | removeUser, |
25 | removeVideo, | 26 | removeVideo, |
26 | runServer, | ||
27 | ServerInfo, | 27 | ServerInfo, |
28 | testImage, | 28 | testImage, |
29 | unblockUser, | 29 | unblockUser, |
@@ -32,10 +32,11 @@ import { | |||
32 | updateUser, | 32 | updateUser, |
33 | uploadVideo, | 33 | uploadVideo, |
34 | userLogin | 34 | userLogin |
35 | } from '../../../../shared/utils/index' | 35 | } from '../../../../shared/extra-utils' |
36 | import { follow } from '../../../../shared/utils/server/follows' | 36 | import { follow } from '../../../../shared/extra-utils/server/follows' |
37 | import { setAccessTokensToServers } from '../../../../shared/utils/users/login' | 37 | import { setAccessTokensToServers } from '../../../../shared/extra-utils/users/login' |
38 | import { getMyVideos } from '../../../../shared/utils/videos/videos' | 38 | import { getMyVideos } from '../../../../shared/extra-utils/videos/videos' |
39 | import { UserAdminFlag } from '../../../../shared/models/users/user-flag.model' | ||
39 | 40 | ||
40 | const expect = chai.expect | 41 | const expect = chai.expect |
41 | 42 | ||
@@ -52,537 +53,633 @@ describe('Test users', function () { | |||
52 | 53 | ||
53 | before(async function () { | 54 | before(async function () { |
54 | this.timeout(30000) | 55 | this.timeout(30000) |
55 | 56 | server = await flushAndRunServer(1) | |
56 | await flushTests() | ||
57 | server = await runServer(1) | ||
58 | 57 | ||
59 | await setAccessTokensToServers([ server ]) | 58 | await setAccessTokensToServers([ server ]) |
60 | }) | 59 | }) |
61 | 60 | ||
62 | it('Should create a new client') | 61 | describe('OAuth client', function () { |
62 | it('Should create a new client') | ||
63 | 63 | ||
64 | it('Should return the first client') | 64 | it('Should return the first client') |
65 | 65 | ||
66 | it('Should remove the last client') | 66 | it('Should remove the last client') |
67 | 67 | ||
68 | it('Should not login with an invalid client id', async function () { | 68 | it('Should not login with an invalid client id', async function () { |
69 | const client = { id: 'client', secret: server.client.secret } | 69 | const client = { id: 'client', secret: server.client.secret } |
70 | const res = await login(server.url, client, server.user, 400) | 70 | const res = await login(server.url, client, server.user, 400) |
71 | 71 | ||
72 | expect(res.body.error).to.contain('client is invalid') | 72 | expect(res.body.error).to.contain('client is invalid') |
73 | }) | 73 | }) |
74 | 74 | ||
75 | it('Should not login with an invalid client secret', async function () { | 75 | it('Should not login with an invalid client secret', async function () { |
76 | const client = { id: server.client.id, secret: 'coucou' } | 76 | const client = { id: server.client.id, secret: 'coucou' } |
77 | const res = await login(server.url, client, server.user, 400) | 77 | const res = await login(server.url, client, server.user, 400) |
78 | 78 | ||
79 | expect(res.body.error).to.contain('client is invalid') | 79 | expect(res.body.error).to.contain('client is invalid') |
80 | }) | ||
80 | }) | 81 | }) |
81 | 82 | ||
82 | it('Should not login with an invalid username', async function () { | 83 | describe('Login', function () { |
83 | const user = { username: 'captain crochet', password: server.user.password } | ||
84 | const res = await login(server.url, server.client, user, 400) | ||
85 | 84 | ||
86 | expect(res.body.error).to.contain('credentials are invalid') | 85 | it('Should not login with an invalid username', async function () { |
87 | }) | 86 | const user = { username: 'captain crochet', password: server.user.password } |
88 | 87 | const res = await login(server.url, server.client, user, 400) | |
89 | it('Should not login with an invalid password', async function () { | ||
90 | const user = { username: server.user.username, password: 'mew_three' } | ||
91 | const res = await login(server.url, server.client, user, 400) | ||
92 | 88 | ||
93 | expect(res.body.error).to.contain('credentials are invalid') | 89 | expect(res.body.error).to.contain('credentials are invalid') |
94 | }) | 90 | }) |
95 | 91 | ||
96 | it('Should not be able to upload a video', async function () { | 92 | it('Should not login with an invalid password', async function () { |
97 | accessToken = 'my_super_token' | 93 | const user = { username: server.user.username, password: 'mew_three' } |
94 | const res = await login(server.url, server.client, user, 400) | ||
98 | 95 | ||
99 | const videoAttributes = {} | 96 | expect(res.body.error).to.contain('credentials are invalid') |
100 | await uploadVideo(server.url, accessToken, videoAttributes, 401) | 97 | }) |
101 | }) | ||
102 | 98 | ||
103 | it('Should not be able to follow', async function () { | 99 | it('Should not be able to upload a video', async function () { |
104 | accessToken = 'my_super_token' | 100 | accessToken = 'my_super_token' |
105 | await follow(server.url, [ 'http://example.com' ], accessToken, 401) | ||
106 | }) | ||
107 | 101 | ||
108 | it('Should not be able to unfollow') | 102 | const videoAttributes = {} |
103 | await uploadVideo(server.url, accessToken, videoAttributes, 401) | ||
104 | }) | ||
109 | 105 | ||
110 | it('Should be able to login', async function () { | 106 | it('Should not be able to follow', async function () { |
111 | const res = await login(server.url, server.client, server.user, 200) | 107 | accessToken = 'my_super_token' |
108 | await follow(server.url, [ 'http://example.com' ], accessToken, 401) | ||
109 | }) | ||
112 | 110 | ||
113 | accessToken = res.body.access_token | 111 | it('Should not be able to unfollow') |
114 | }) | ||
115 | 112 | ||
116 | it('Should upload the video with the correct token', async function () { | 113 | it('Should be able to login', async function () { |
117 | const videoAttributes = {} | 114 | const res = await login(server.url, server.client, server.user, 200) |
118 | await uploadVideo(server.url, accessToken, videoAttributes) | ||
119 | const res = await getVideosList(server.url) | ||
120 | const video = res.body.data[ 0 ] | ||
121 | 115 | ||
122 | expect(video.account.name).to.equal('root') | 116 | accessToken = res.body.access_token |
123 | videoId = video.id | 117 | }) |
124 | }) | 118 | }) |
125 | 119 | ||
126 | it('Should upload the video again with the correct token', async function () { | 120 | describe('Upload', function () { |
127 | const videoAttributes = {} | ||
128 | await uploadVideo(server.url, accessToken, videoAttributes) | ||
129 | }) | ||
130 | 121 | ||
131 | it('Should retrieve a video rating', async function () { | 122 | it('Should upload the video with the correct token', async function () { |
132 | await rateVideo(server.url, accessToken, videoId, 'like') | 123 | const videoAttributes = {} |
133 | const res = await getMyUserVideoRating(server.url, accessToken, videoId) | 124 | await uploadVideo(server.url, accessToken, videoAttributes) |
134 | const rating = res.body | 125 | const res = await getVideosList(server.url) |
126 | const video = res.body.data[ 0 ] | ||
135 | 127 | ||
136 | expect(rating.videoId).to.equal(videoId) | 128 | expect(video.account.name).to.equal('root') |
137 | expect(rating.rating).to.equal('like') | 129 | videoId = video.id |
138 | }) | 130 | }) |
139 | 131 | ||
140 | it('Should not be able to remove the video with an incorrect token', async function () { | 132 | it('Should upload the video again with the correct token', async function () { |
141 | await removeVideo(server.url, 'bad_token', videoId, 401) | 133 | const videoAttributes = {} |
134 | await uploadVideo(server.url, accessToken, videoAttributes) | ||
135 | }) | ||
142 | }) | 136 | }) |
143 | 137 | ||
144 | it('Should not be able to remove the video with the token of another account') | 138 | describe('Ratings', function () { |
145 | 139 | ||
146 | it('Should be able to remove the video with the correct token', async function () { | 140 | it('Should retrieve a video rating', async function () { |
147 | await removeVideo(server.url, accessToken, videoId) | 141 | await rateVideo(server.url, accessToken, videoId, 'like') |
148 | }) | 142 | const res = await getMyUserVideoRating(server.url, accessToken, videoId) |
143 | const rating = res.body | ||
149 | 144 | ||
150 | it('Should logout (revoke token)') | 145 | expect(rating.videoId).to.equal(videoId) |
151 | 146 | expect(rating.rating).to.equal('like') | |
152 | it('Should not be able to get the user information') | 147 | }) |
153 | 148 | ||
154 | it('Should not be able to upload a video') | 149 | it('Should retrieve ratings list', async function () { |
150 | await rateVideo(server.url, accessToken, videoId, 'like') | ||
155 | 151 | ||
156 | it('Should not be able to remove a video') | 152 | const res = await getAccountRatings(server.url, server.user.username, server.accessToken, null, 200) |
153 | const ratings = res.body | ||
157 | 154 | ||
158 | it('Should not be able to rate a video', async function () { | 155 | expect(ratings.total).to.equal(1) |
159 | const path = '/api/v1/videos/' | 156 | expect(ratings.data[ 0 ].video.id).to.equal(videoId) |
160 | const data = { | 157 | expect(ratings.data[ 0 ].rating).to.equal('like') |
161 | rating: 'likes' | 158 | }) |
162 | } | ||
163 | 159 | ||
164 | const options = { | 160 | it('Should retrieve ratings list by rating type', async function () { |
165 | url: server.url, | 161 | { |
166 | path: path + videoId, | 162 | const res = await getAccountRatings(server.url, server.user.username, server.accessToken, 'like') |
167 | token: 'wrong token', | 163 | const ratings = res.body |
168 | fields: data, | 164 | expect(ratings.data.length).to.equal(1) |
169 | statusCodeExpected: 401 | 165 | } |
170 | } | 166 | |
171 | await makePutBodyRequest(options) | 167 | { |
168 | const res = await getAccountRatings(server.url, server.user.username, server.accessToken, 'dislike') | ||
169 | const ratings = res.body | ||
170 | expect(ratings.data.length).to.equal(0) | ||
171 | } | ||
172 | }) | ||
172 | }) | 173 | }) |
173 | 174 | ||
174 | it('Should be able to login again') | 175 | describe('Remove video', function () { |
176 | it('Should not be able to remove the video with an incorrect token', async function () { | ||
177 | await removeVideo(server.url, 'bad_token', videoId, 401) | ||
178 | }) | ||
175 | 179 | ||
176 | it('Should have an expired access token') | 180 | it('Should not be able to remove the video with the token of another account') |
177 | 181 | ||
178 | it('Should refresh the token') | 182 | it('Should be able to remove the video with the correct token', async function () { |
183 | await removeVideo(server.url, accessToken, videoId) | ||
184 | }) | ||
185 | }) | ||
179 | 186 | ||
180 | it('Should be able to upload a video again') | 187 | describe('Logout', function () { |
188 | it('Should logout (revoke token)') | ||
181 | 189 | ||
182 | it('Should be able to create a new user', async function () { | 190 | it('Should not be able to get the user information') |
183 | await createUser(server.url, accessToken, user.username, user.password, 2 * 1024 * 1024) | ||
184 | }) | ||
185 | 191 | ||
186 | it('Should be able to login with this user', async function () { | 192 | it('Should not be able to upload a video') |
187 | accessTokenUser = await userLogin(server, user) | ||
188 | }) | ||
189 | 193 | ||
190 | it('Should be able to get the user information', async function () { | 194 | it('Should not be able to remove a video') |
191 | const res = await getMyUserInformation(server.url, accessTokenUser) | ||
192 | const user = res.body | ||
193 | |||
194 | expect(user.username).to.equal('user_1') | ||
195 | expect(user.email).to.equal('user_1@example.com') | ||
196 | expect(user.nsfwPolicy).to.equal('display') | ||
197 | expect(user.videoQuota).to.equal(2 * 1024 * 1024) | ||
198 | expect(user.roleLabel).to.equal('User') | ||
199 | expect(user.id).to.be.a('number') | ||
200 | expect(user.account.displayName).to.equal('user_1') | ||
201 | expect(user.account.description).to.be.null | ||
202 | }) | ||
203 | 195 | ||
204 | it('Should be able to upload a video with this user', async function () { | 196 | it('Should not be able to rate a video', async function () { |
205 | this.timeout(5000) | 197 | const path = '/api/v1/videos/' |
198 | const data = { | ||
199 | rating: 'likes' | ||
200 | } | ||
206 | 201 | ||
207 | const videoAttributes = { | 202 | const options = { |
208 | name: 'super user video', | 203 | url: server.url, |
209 | fixture: 'video_short.webm' | 204 | path: path + videoId, |
210 | } | 205 | token: 'wrong token', |
211 | await uploadVideo(server.url, accessTokenUser, videoAttributes) | 206 | fields: data, |
212 | }) | 207 | statusCodeExpected: 401 |
208 | } | ||
209 | await makePutBodyRequest(options) | ||
210 | }) | ||
213 | 211 | ||
214 | it('Should have video quota updated', async function () { | 212 | it('Should be able to login again') |
215 | const res = await getMyUserVideoQuotaUsed(server.url, accessTokenUser) | ||
216 | const data = res.body | ||
217 | 213 | ||
218 | expect(data.videoQuotaUsed).to.equal(218910) | 214 | it('Should have an expired access token') |
219 | 215 | ||
220 | const resUsers = await getUsersList(server.url, server.accessToken) | 216 | it('Should refresh the token') |
221 | 217 | ||
222 | const users: User[] = resUsers.body.data | 218 | it('Should be able to upload a video again') |
223 | const tmpUser = users.find(u => u.username === user.username) | ||
224 | expect(tmpUser.videoQuotaUsed).to.equal(218910) | ||
225 | }) | 219 | }) |
226 | 220 | ||
227 | it('Should be able to list my videos', async function () { | 221 | describe('Creating a user', function () { |
228 | const res = await getMyVideos(server.url, accessTokenUser, 0, 5) | ||
229 | expect(res.body.total).to.equal(1) | ||
230 | 222 | ||
231 | const videos = res.body.data | 223 | it('Should be able to create a new user', async function () { |
232 | expect(videos).to.have.lengthOf(1) | 224 | await createUser({ |
225 | url: server.url, | ||
226 | accessToken: accessToken, | ||
227 | username: user.username, | ||
228 | password: user.password, | ||
229 | videoQuota: 2 * 1024 * 1024, | ||
230 | adminFlags: UserAdminFlag.BY_PASS_VIDEO_AUTO_BLACKLIST | ||
231 | }) | ||
232 | }) | ||
233 | 233 | ||
234 | expect(videos[ 0 ].name).to.equal('super user video') | 234 | it('Should be able to login with this user', async function () { |
235 | accessTokenUser = await userLogin(server, user) | ||
236 | }) | ||
237 | |||
238 | it('Should be able to get user information', async function () { | ||
239 | const res1 = await getMyUserInformation(server.url, accessTokenUser) | ||
240 | const userMe: User = res1.body | ||
241 | |||
242 | const res2 = await getUserInformation(server.url, server.accessToken, userMe.id) | ||
243 | const userGet: User = res2.body | ||
244 | |||
245 | for (const user of [ userMe, userGet ]) { | ||
246 | expect(user.username).to.equal('user_1') | ||
247 | expect(user.email).to.equal('user_1@example.com') | ||
248 | expect(user.nsfwPolicy).to.equal('display') | ||
249 | expect(user.videoQuota).to.equal(2 * 1024 * 1024) | ||
250 | expect(user.roleLabel).to.equal('User') | ||
251 | expect(user.id).to.be.a('number') | ||
252 | expect(user.account.displayName).to.equal('user_1') | ||
253 | expect(user.account.description).to.be.null | ||
254 | } | ||
255 | |||
256 | expect(userMe.adminFlags).to.be.undefined | ||
257 | expect(userGet.adminFlags).to.equal(UserAdminFlag.BY_PASS_VIDEO_AUTO_BLACKLIST) | ||
258 | }) | ||
235 | }) | 259 | }) |
236 | 260 | ||
237 | it('Should list all the users', async function () { | 261 | describe('My videos & quotas', function () { |
238 | const res = await getUsersList(server.url, server.accessToken) | ||
239 | const result = res.body | ||
240 | const total = result.total | ||
241 | const users = result.data | ||
242 | 262 | ||
243 | expect(total).to.equal(2) | 263 | it('Should be able to upload a video with this user', async function () { |
244 | expect(users).to.be.an('array') | 264 | this.timeout(5000) |
245 | expect(users.length).to.equal(2) | ||
246 | 265 | ||
247 | const user = users[ 0 ] | 266 | const videoAttributes = { |
248 | expect(user.username).to.equal('user_1') | 267 | name: 'super user video', |
249 | expect(user.email).to.equal('user_1@example.com') | 268 | fixture: 'video_short.webm' |
250 | expect(user.nsfwPolicy).to.equal('display') | 269 | } |
270 | await uploadVideo(server.url, accessTokenUser, videoAttributes) | ||
271 | }) | ||
251 | 272 | ||
252 | const rootUser = users[ 1 ] | 273 | it('Should have video quota updated', async function () { |
253 | expect(rootUser.username).to.equal('root') | 274 | const res = await getMyUserVideoQuotaUsed(server.url, accessTokenUser) |
254 | expect(rootUser.email).to.equal('admin1@example.com') | 275 | const data = res.body |
255 | expect(user.nsfwPolicy).to.equal('display') | ||
256 | 276 | ||
257 | userId = user.id | 277 | expect(data.videoQuotaUsed).to.equal(218910) |
258 | }) | ||
259 | 278 | ||
260 | it('Should list only the first user by username asc', async function () { | 279 | const resUsers = await getUsersList(server.url, server.accessToken) |
261 | const res = await getUsersListPaginationAndSort(server.url, server.accessToken, 0, 1, 'username') | ||
262 | 280 | ||
263 | const result = res.body | 281 | const users: User[] = resUsers.body.data |
264 | const total = result.total | 282 | const tmpUser = users.find(u => u.username === user.username) |
265 | const users = result.data | 283 | expect(tmpUser.videoQuotaUsed).to.equal(218910) |
284 | }) | ||
266 | 285 | ||
267 | expect(total).to.equal(2) | 286 | it('Should be able to list my videos', async function () { |
268 | expect(users.length).to.equal(1) | 287 | const res = await getMyVideos(server.url, accessTokenUser, 0, 5) |
288 | expect(res.body.total).to.equal(1) | ||
289 | |||
290 | const videos = res.body.data | ||
291 | expect(videos).to.have.lengthOf(1) | ||
269 | 292 | ||
270 | const user = users[ 0 ] | 293 | const video: Video = videos[ 0 ] |
271 | expect(user.username).to.equal('root') | 294 | expect(video.name).to.equal('super user video') |
272 | expect(user.email).to.equal('admin1@example.com') | 295 | expect(video.thumbnailPath).to.not.be.null |
273 | expect(user.roleLabel).to.equal('Administrator') | 296 | expect(video.previewPath).to.not.be.null |
274 | expect(user.nsfwPolicy).to.equal('display') | 297 | }) |
275 | }) | 298 | }) |
276 | 299 | ||
277 | it('Should list only the first user by username desc', async function () { | 300 | describe('Users listing', function () { |
278 | const res = await getUsersListPaginationAndSort(server.url, server.accessToken, 0, 1, '-username') | ||
279 | const result = res.body | ||
280 | const total = result.total | ||
281 | const users = result.data | ||
282 | 301 | ||
283 | expect(total).to.equal(2) | 302 | it('Should list all the users', async function () { |
284 | expect(users.length).to.equal(1) | 303 | const res = await getUsersList(server.url, server.accessToken) |
304 | const result = res.body | ||
305 | const total = result.total | ||
306 | const users = result.data | ||
285 | 307 | ||
286 | const user = users[ 0 ] | 308 | expect(total).to.equal(2) |
287 | expect(user.username).to.equal('user_1') | 309 | expect(users).to.be.an('array') |
288 | expect(user.email).to.equal('user_1@example.com') | 310 | expect(users.length).to.equal(2) |
289 | expect(user.nsfwPolicy).to.equal('display') | ||
290 | }) | ||
291 | 311 | ||
292 | it('Should list only the second user by createdAt desc', async function () { | 312 | const user = users[ 0 ] |
293 | const res = await getUsersListPaginationAndSort(server.url, server.accessToken, 0, 1, '-createdAt') | 313 | expect(user.username).to.equal('user_1') |
294 | const result = res.body | 314 | expect(user.email).to.equal('user_1@example.com') |
295 | const total = result.total | 315 | expect(user.nsfwPolicy).to.equal('display') |
296 | const users = result.data | ||
297 | 316 | ||
298 | expect(total).to.equal(2) | 317 | const rootUser = users[ 1 ] |
299 | expect(users.length).to.equal(1) | 318 | expect(rootUser.username).to.equal('root') |
319 | expect(rootUser.email).to.equal('admin1@example.com') | ||
320 | expect(user.nsfwPolicy).to.equal('display') | ||
300 | 321 | ||
301 | const user = users[ 0 ] | 322 | userId = user.id |
302 | expect(user.username).to.equal('user_1') | 323 | }) |
303 | expect(user.email).to.equal('user_1@example.com') | ||
304 | expect(user.nsfwPolicy).to.equal('display') | ||
305 | }) | ||
306 | 324 | ||
307 | it('Should list all the users by createdAt asc', async function () { | 325 | it('Should list only the first user by username asc', async function () { |
308 | const res = await getUsersListPaginationAndSort(server.url, server.accessToken, 0, 2, 'createdAt') | 326 | const res = await getUsersListPaginationAndSort(server.url, server.accessToken, 0, 1, 'username') |
309 | const result = res.body | ||
310 | const total = result.total | ||
311 | const users = result.data | ||
312 | 327 | ||
313 | expect(total).to.equal(2) | 328 | const result = res.body |
314 | expect(users.length).to.equal(2) | 329 | const total = result.total |
330 | const users = result.data | ||
315 | 331 | ||
316 | expect(users[ 0 ].username).to.equal('root') | 332 | expect(total).to.equal(2) |
317 | expect(users[ 0 ].email).to.equal('admin1@example.com') | 333 | expect(users.length).to.equal(1) |
318 | expect(users[ 0 ].nsfwPolicy).to.equal('display') | ||
319 | 334 | ||
320 | expect(users[ 1 ].username).to.equal('user_1') | 335 | const user = users[ 0 ] |
321 | expect(users[ 1 ].email).to.equal('user_1@example.com') | 336 | expect(user.username).to.equal('root') |
322 | expect(users[ 1 ].nsfwPolicy).to.equal('display') | 337 | expect(user.email).to.equal('admin1@example.com') |
323 | }) | 338 | expect(user.roleLabel).to.equal('Administrator') |
339 | expect(user.nsfwPolicy).to.equal('display') | ||
340 | }) | ||
324 | 341 | ||
325 | it('Should search user by username', async function () { | 342 | it('Should list only the first user by username desc', async function () { |
326 | const res = await getUsersListPaginationAndSort(server.url, server.accessToken, 0, 2, 'createdAt', 'oot') | 343 | const res = await getUsersListPaginationAndSort(server.url, server.accessToken, 0, 1, '-username') |
327 | const users = res.body.data as User[] | 344 | const result = res.body |
345 | const total = result.total | ||
346 | const users = result.data | ||
328 | 347 | ||
329 | expect(res.body.total).to.equal(1) | 348 | expect(total).to.equal(2) |
330 | expect(users.length).to.equal(1) | 349 | expect(users.length).to.equal(1) |
331 | 350 | ||
332 | expect(users[ 0 ].username).to.equal('root') | 351 | const user = users[ 0 ] |
333 | }) | 352 | expect(user.username).to.equal('user_1') |
353 | expect(user.email).to.equal('user_1@example.com') | ||
354 | expect(user.nsfwPolicy).to.equal('display') | ||
355 | }) | ||
334 | 356 | ||
335 | it('Should search user by email', async function () { | 357 | it('Should list only the second user by createdAt desc', async function () { |
336 | { | 358 | const res = await getUsersListPaginationAndSort(server.url, server.accessToken, 0, 1, '-createdAt') |
337 | const res = await getUsersListPaginationAndSort(server.url, server.accessToken, 0, 2, 'createdAt', 'r_1@exam') | 359 | const result = res.body |
338 | const users = res.body.data as User[] | 360 | const total = result.total |
361 | const users = result.data | ||
339 | 362 | ||
340 | expect(res.body.total).to.equal(1) | 363 | expect(total).to.equal(2) |
341 | expect(users.length).to.equal(1) | 364 | expect(users.length).to.equal(1) |
342 | 365 | ||
343 | expect(users[ 0 ].username).to.equal('user_1') | 366 | const user = users[ 0 ] |
344 | expect(users[ 0 ].email).to.equal('user_1@example.com') | 367 | expect(user.username).to.equal('user_1') |
345 | } | 368 | expect(user.email).to.equal('user_1@example.com') |
369 | expect(user.nsfwPolicy).to.equal('display') | ||
370 | }) | ||
346 | 371 | ||
347 | { | 372 | it('Should list all the users by createdAt asc', async function () { |
348 | const res = await getUsersListPaginationAndSort(server.url, server.accessToken, 0, 2, 'createdAt', 'example') | 373 | const res = await getUsersListPaginationAndSort(server.url, server.accessToken, 0, 2, 'createdAt') |
349 | const users = res.body.data as User[] | 374 | const result = res.body |
375 | const total = result.total | ||
376 | const users = result.data | ||
350 | 377 | ||
351 | expect(res.body.total).to.equal(2) | 378 | expect(total).to.equal(2) |
352 | expect(users.length).to.equal(2) | 379 | expect(users.length).to.equal(2) |
353 | 380 | ||
354 | expect(users[ 0 ].username).to.equal('root') | 381 | expect(users[ 0 ].username).to.equal('root') |
355 | expect(users[ 1 ].username).to.equal('user_1') | 382 | expect(users[ 0 ].email).to.equal('admin1@example.com') |
356 | } | 383 | expect(users[ 0 ].nsfwPolicy).to.equal('display') |
357 | }) | ||
358 | 384 | ||
359 | it('Should update my password', async function () { | 385 | expect(users[ 1 ].username).to.equal('user_1') |
360 | await updateMyUser({ | 386 | expect(users[ 1 ].email).to.equal('user_1@example.com') |
361 | url: server.url, | 387 | expect(users[ 1 ].nsfwPolicy).to.equal('display') |
362 | accessToken: accessTokenUser, | ||
363 | currentPassword: 'super password', | ||
364 | newPassword: 'new password' | ||
365 | }) | 388 | }) |
366 | user.password = 'new password' | ||
367 | 389 | ||
368 | await userLogin(server, user, 200) | 390 | it('Should search user by username', async function () { |
369 | }) | 391 | const res = await getUsersListPaginationAndSort(server.url, server.accessToken, 0, 2, 'createdAt', 'oot') |
392 | const users = res.body.data as User[] | ||
393 | |||
394 | expect(res.body.total).to.equal(1) | ||
395 | expect(users.length).to.equal(1) | ||
370 | 396 | ||
371 | it('Should be able to change the NSFW display attribute', async function () { | 397 | expect(users[ 0 ].username).to.equal('root') |
372 | await updateMyUser({ | ||
373 | url: server.url, | ||
374 | accessToken: accessTokenUser, | ||
375 | nsfwPolicy: 'do_not_list' | ||
376 | }) | 398 | }) |
377 | 399 | ||
378 | const res = await getMyUserInformation(server.url, accessTokenUser) | 400 | it('Should search user by email', async function () { |
379 | const user = res.body | 401 | { |
402 | const res = await getUsersListPaginationAndSort(server.url, server.accessToken, 0, 2, 'createdAt', 'r_1@exam') | ||
403 | const users = res.body.data as User[] | ||
380 | 404 | ||
381 | expect(user.username).to.equal('user_1') | 405 | expect(res.body.total).to.equal(1) |
382 | expect(user.email).to.equal('user_1@example.com') | 406 | expect(users.length).to.equal(1) |
383 | expect(user.nsfwPolicy).to.equal('do_not_list') | ||
384 | expect(user.videoQuota).to.equal(2 * 1024 * 1024) | ||
385 | expect(user.id).to.be.a('number') | ||
386 | expect(user.account.displayName).to.equal('user_1') | ||
387 | expect(user.account.description).to.be.null | ||
388 | }) | ||
389 | 407 | ||
390 | it('Should be able to change the autoPlayVideo attribute', async function () { | 408 | expect(users[ 0 ].username).to.equal('user_1') |
391 | await updateMyUser({ | 409 | expect(users[ 0 ].email).to.equal('user_1@example.com') |
392 | url: server.url, | 410 | } |
393 | accessToken: accessTokenUser, | ||
394 | autoPlayVideo: false | ||
395 | }) | ||
396 | 411 | ||
397 | const res = await getMyUserInformation(server.url, accessTokenUser) | 412 | { |
398 | const user = res.body | 413 | const res = await getUsersListPaginationAndSort(server.url, server.accessToken, 0, 2, 'createdAt', 'example') |
414 | const users = res.body.data as User[] | ||
399 | 415 | ||
400 | expect(user.autoPlayVideo).to.be.false | 416 | expect(res.body.total).to.equal(2) |
417 | expect(users.length).to.equal(2) | ||
418 | |||
419 | expect(users[ 0 ].username).to.equal('root') | ||
420 | expect(users[ 1 ].username).to.equal('user_1') | ||
421 | } | ||
422 | }) | ||
401 | }) | 423 | }) |
402 | 424 | ||
403 | it('Should be able to change the email display attribute', async function () { | 425 | describe('Update my account', function () { |
404 | await updateMyUser({ | 426 | it('Should update my password', async function () { |
405 | url: server.url, | 427 | await updateMyUser({ |
406 | accessToken: accessTokenUser, | 428 | url: server.url, |
407 | email: 'updated@example.com' | 429 | accessToken: accessTokenUser, |
430 | currentPassword: 'super password', | ||
431 | newPassword: 'new password' | ||
432 | }) | ||
433 | user.password = 'new password' | ||
434 | |||
435 | await userLogin(server, user, 200) | ||
408 | }) | 436 | }) |
409 | 437 | ||
410 | const res = await getMyUserInformation(server.url, accessTokenUser) | 438 | it('Should be able to change the NSFW display attribute', async function () { |
411 | const user = res.body | 439 | await updateMyUser({ |
440 | url: server.url, | ||
441 | accessToken: accessTokenUser, | ||
442 | nsfwPolicy: 'do_not_list' | ||
443 | }) | ||
444 | |||
445 | const res = await getMyUserInformation(server.url, accessTokenUser) | ||
446 | const user = res.body | ||
447 | |||
448 | expect(user.username).to.equal('user_1') | ||
449 | expect(user.email).to.equal('user_1@example.com') | ||
450 | expect(user.nsfwPolicy).to.equal('do_not_list') | ||
451 | expect(user.videoQuota).to.equal(2 * 1024 * 1024) | ||
452 | expect(user.id).to.be.a('number') | ||
453 | expect(user.account.displayName).to.equal('user_1') | ||
454 | expect(user.account.description).to.be.null | ||
455 | }) | ||
412 | 456 | ||
413 | expect(user.username).to.equal('user_1') | 457 | it('Should be able to change the autoPlayVideo attribute', async function () { |
414 | expect(user.email).to.equal('updated@example.com') | 458 | await updateMyUser({ |
415 | expect(user.nsfwPolicy).to.equal('do_not_list') | 459 | url: server.url, |
416 | expect(user.videoQuota).to.equal(2 * 1024 * 1024) | 460 | accessToken: accessTokenUser, |
417 | expect(user.id).to.be.a('number') | 461 | autoPlayVideo: false |
418 | expect(user.account.displayName).to.equal('user_1') | 462 | }) |
419 | expect(user.account.description).to.be.null | 463 | |
420 | }) | 464 | const res = await getMyUserInformation(server.url, accessTokenUser) |
465 | const user = res.body | ||
421 | 466 | ||
422 | it('Should be able to update my avatar', async function () { | 467 | expect(user.autoPlayVideo).to.be.false |
423 | const fixture = 'avatar.png' | 468 | }) |
424 | 469 | ||
425 | await updateMyAvatar({ | 470 | it('Should be able to change the email display attribute', async function () { |
426 | url: server.url, | 471 | await updateMyUser({ |
427 | accessToken: accessTokenUser, | 472 | url: server.url, |
428 | fixture | 473 | accessToken: accessTokenUser, |
474 | email: 'updated@example.com' | ||
475 | }) | ||
476 | |||
477 | const res = await getMyUserInformation(server.url, accessTokenUser) | ||
478 | const user = res.body | ||
479 | |||
480 | expect(user.username).to.equal('user_1') | ||
481 | expect(user.email).to.equal('updated@example.com') | ||
482 | expect(user.nsfwPolicy).to.equal('do_not_list') | ||
483 | expect(user.videoQuota).to.equal(2 * 1024 * 1024) | ||
484 | expect(user.id).to.be.a('number') | ||
485 | expect(user.account.displayName).to.equal('user_1') | ||
486 | expect(user.account.description).to.be.null | ||
429 | }) | 487 | }) |
430 | 488 | ||
431 | const res = await getMyUserInformation(server.url, accessTokenUser) | 489 | it('Should be able to update my avatar', async function () { |
432 | const user = res.body | 490 | const fixture = 'avatar.png' |
433 | 491 | ||
434 | await testImage(server.url, 'avatar-resized', user.account.avatar.path, '.png') | 492 | await updateMyAvatar({ |
435 | }) | 493 | url: server.url, |
494 | accessToken: accessTokenUser, | ||
495 | fixture | ||
496 | }) | ||
497 | |||
498 | const res = await getMyUserInformation(server.url, accessTokenUser) | ||
499 | const user = res.body | ||
436 | 500 | ||
437 | it('Should be able to update my display name', async function () { | 501 | await testImage(server.url, 'avatar-resized', user.account.avatar.path, '.png') |
438 | await updateMyUser({ | ||
439 | url: server.url, | ||
440 | accessToken: accessTokenUser, | ||
441 | displayName: 'new display name' | ||
442 | }) | 502 | }) |
443 | 503 | ||
444 | const res = await getMyUserInformation(server.url, accessTokenUser) | 504 | it('Should be able to update my display name', async function () { |
445 | const user = res.body | 505 | await updateMyUser({ |
506 | url: server.url, | ||
507 | accessToken: accessTokenUser, | ||
508 | displayName: 'new display name' | ||
509 | }) | ||
510 | |||
511 | const res = await getMyUserInformation(server.url, accessTokenUser) | ||
512 | const user = res.body | ||
513 | |||
514 | expect(user.username).to.equal('user_1') | ||
515 | expect(user.email).to.equal('updated@example.com') | ||
516 | expect(user.nsfwPolicy).to.equal('do_not_list') | ||
517 | expect(user.videoQuota).to.equal(2 * 1024 * 1024) | ||
518 | expect(user.id).to.be.a('number') | ||
519 | expect(user.account.displayName).to.equal('new display name') | ||
520 | expect(user.account.description).to.be.null | ||
521 | }) | ||
446 | 522 | ||
447 | expect(user.username).to.equal('user_1') | 523 | it('Should be able to update my description', async function () { |
448 | expect(user.email).to.equal('updated@example.com') | 524 | await updateMyUser({ |
449 | expect(user.nsfwPolicy).to.equal('do_not_list') | 525 | url: server.url, |
450 | expect(user.videoQuota).to.equal(2 * 1024 * 1024) | 526 | accessToken: accessTokenUser, |
451 | expect(user.id).to.be.a('number') | 527 | description: 'my super description updated' |
452 | expect(user.account.displayName).to.equal('new display name') | 528 | }) |
453 | expect(user.account.description).to.be.null | 529 | |
530 | const res = await getMyUserInformation(server.url, accessTokenUser) | ||
531 | const user = res.body | ||
532 | |||
533 | expect(user.username).to.equal('user_1') | ||
534 | expect(user.email).to.equal('updated@example.com') | ||
535 | expect(user.nsfwPolicy).to.equal('do_not_list') | ||
536 | expect(user.videoQuota).to.equal(2 * 1024 * 1024) | ||
537 | expect(user.id).to.be.a('number') | ||
538 | expect(user.account.displayName).to.equal('new display name') | ||
539 | expect(user.account.description).to.equal('my super description updated') | ||
540 | }) | ||
454 | }) | 541 | }) |
455 | 542 | ||
456 | it('Should be able to update my description', async function () { | 543 | describe('Updating another user', function () { |
457 | await updateMyUser({ | 544 | |
458 | url: server.url, | 545 | it('Should be able to update another user', async function () { |
459 | accessToken: accessTokenUser, | 546 | await updateUser({ |
460 | description: 'my super description updated' | 547 | url: server.url, |
548 | userId, | ||
549 | accessToken, | ||
550 | email: 'updated2@example.com', | ||
551 | emailVerified: true, | ||
552 | videoQuota: 42, | ||
553 | role: UserRole.MODERATOR, | ||
554 | adminFlags: UserAdminFlag.NONE | ||
555 | }) | ||
556 | |||
557 | const res = await getUserInformation(server.url, accessToken, userId) | ||
558 | const user = res.body | ||
559 | |||
560 | expect(user.username).to.equal('user_1') | ||
561 | expect(user.email).to.equal('updated2@example.com') | ||
562 | expect(user.emailVerified).to.be.true | ||
563 | expect(user.nsfwPolicy).to.equal('do_not_list') | ||
564 | expect(user.videoQuota).to.equal(42) | ||
565 | expect(user.roleLabel).to.equal('Moderator') | ||
566 | expect(user.id).to.be.a('number') | ||
567 | expect(user.adminFlags).to.equal(UserAdminFlag.NONE) | ||
461 | }) | 568 | }) |
462 | 569 | ||
463 | const res = await getMyUserInformation(server.url, accessTokenUser) | 570 | it('Should have removed the user token', async function () { |
464 | const user = res.body | 571 | await getMyUserVideoQuotaUsed(server.url, accessTokenUser, 401) |
465 | 572 | ||
466 | expect(user.username).to.equal('user_1') | 573 | accessTokenUser = await userLogin(server, user) |
467 | expect(user.email).to.equal('updated@example.com') | 574 | }) |
468 | expect(user.nsfwPolicy).to.equal('do_not_list') | ||
469 | expect(user.videoQuota).to.equal(2 * 1024 * 1024) | ||
470 | expect(user.id).to.be.a('number') | ||
471 | expect(user.account.displayName).to.equal('new display name') | ||
472 | expect(user.account.description).to.equal('my super description updated') | ||
473 | }) | ||
474 | 575 | ||
475 | it('Should be able to update another user', async function () { | 576 | it('Should be able to update another user password', async function () { |
476 | await updateUser({ | 577 | await updateUser({ |
477 | url: server.url, | 578 | url: server.url, |
478 | userId, | 579 | userId, |
479 | accessToken, | 580 | accessToken, |
480 | email: 'updated2@example.com', | 581 | password: 'password updated' |
481 | emailVerified: true, | 582 | }) |
482 | videoQuota: 42, | ||
483 | role: UserRole.MODERATOR | ||
484 | }) | ||
485 | |||
486 | const res = await getUserInformation(server.url, accessToken, userId) | ||
487 | const user = res.body | ||
488 | |||
489 | expect(user.username).to.equal('user_1') | ||
490 | expect(user.email).to.equal('updated2@example.com') | ||
491 | expect(user.emailVerified).to.be.true | ||
492 | expect(user.nsfwPolicy).to.equal('do_not_list') | ||
493 | expect(user.videoQuota).to.equal(42) | ||
494 | expect(user.roleLabel).to.equal('Moderator') | ||
495 | expect(user.id).to.be.a('number') | ||
496 | }) | ||
497 | 583 | ||
498 | it('Should have removed the user token', async function () { | 584 | await getMyUserVideoQuotaUsed(server.url, accessTokenUser, 401) |
499 | await getMyUserVideoQuotaUsed(server.url, accessTokenUser, 401) | ||
500 | 585 | ||
501 | accessTokenUser = await userLogin(server, user) | 586 | await userLogin(server, user, 400) |
502 | }) | ||
503 | 587 | ||
504 | it('Should be able to list video blacklist by a moderator', async function () { | 588 | user.password = 'password updated' |
505 | await getBlacklistedVideosList(server.url, accessTokenUser) | 589 | accessTokenUser = await userLogin(server, user) |
590 | }) | ||
506 | }) | 591 | }) |
507 | 592 | ||
508 | it('Should be able to remove this user', async function () { | 593 | describe('Video blacklists', function () { |
509 | await removeUser(server.url, userId, accessToken) | 594 | it('Should be able to list video blacklist by a moderator', async function () { |
595 | await getBlacklistedVideosList({ url: server.url, token: accessTokenUser }) | ||
596 | }) | ||
510 | }) | 597 | }) |
511 | 598 | ||
512 | it('Should not be able to login with this user', async function () { | 599 | describe('Remove a user', function () { |
513 | await userLogin(server, user, 400) | 600 | it('Should be able to remove this user', async function () { |
514 | }) | 601 | await removeUser(server.url, userId, accessToken) |
602 | }) | ||
515 | 603 | ||
516 | it('Should not have videos of this user', async function () { | 604 | it('Should not be able to login with this user', async function () { |
517 | const res = await getVideosList(server.url) | 605 | await userLogin(server, user, 400) |
606 | }) | ||
518 | 607 | ||
519 | expect(res.body.total).to.equal(1) | 608 | it('Should not have videos of this user', async function () { |
609 | const res = await getVideosList(server.url) | ||
520 | 610 | ||
521 | const video = res.body.data[ 0 ] | 611 | expect(res.body.total).to.equal(1) |
522 | expect(video.account.name).to.equal('root') | ||
523 | }) | ||
524 | 612 | ||
525 | it('Should register a new user', async function () { | 613 | const video = res.body.data[ 0 ] |
526 | await registerUser(server.url, 'user_15', 'my super password') | 614 | expect(video.account.name).to.equal('root') |
615 | }) | ||
527 | }) | 616 | }) |
528 | 617 | ||
529 | it('Should be able to login with this registered user', async function () { | 618 | describe('Registering a new user', function () { |
530 | const user15 = { | 619 | it('Should register a new user', async function () { |
531 | username: 'user_15', | 620 | await registerUser(server.url, 'user_15', 'my super password') |
532 | password: 'my super password' | 621 | }) |
533 | } | ||
534 | 622 | ||
535 | accessToken = await userLogin(server, user15) | 623 | it('Should be able to login with this registered user', async function () { |
536 | }) | 624 | const user15 = { |
625 | username: 'user_15', | ||
626 | password: 'my super password' | ||
627 | } | ||
537 | 628 | ||
538 | it('Should have the correct video quota', async function () { | 629 | accessToken = await userLogin(server, user15) |
539 | const res = await getMyUserInformation(server.url, accessToken) | 630 | }) |
540 | const user = res.body | ||
541 | 631 | ||
542 | expect(user.videoQuota).to.equal(5 * 1024 * 1024) | 632 | it('Should have the correct video quota', async function () { |
543 | }) | 633 | const res = await getMyUserInformation(server.url, accessToken) |
634 | const user = res.body | ||
544 | 635 | ||
545 | it('Should remove me', async function () { | 636 | expect(user.videoQuota).to.equal(5 * 1024 * 1024) |
546 | { | 637 | }) |
547 | const res = await getUsersList(server.url, server.accessToken) | ||
548 | expect(res.body.data.find(u => u.username === 'user_15')).to.not.be.undefined | ||
549 | } | ||
550 | 638 | ||
551 | await deleteMe(server.url, accessToken) | 639 | it('Should remove me', async function () { |
640 | { | ||
641 | const res = await getUsersList(server.url, server.accessToken) | ||
642 | expect(res.body.data.find(u => u.username === 'user_15')).to.not.be.undefined | ||
643 | } | ||
552 | 644 | ||
553 | { | 645 | await deleteMe(server.url, accessToken) |
554 | const res = await getUsersList(server.url, server.accessToken) | 646 | |
555 | expect(res.body.data.find(u => u.username === 'user_15')).to.be.undefined | 647 | { |
556 | } | 648 | const res = await getUsersList(server.url, server.accessToken) |
649 | expect(res.body.data.find(u => u.username === 'user_15')).to.be.undefined | ||
650 | } | ||
651 | }) | ||
557 | }) | 652 | }) |
558 | 653 | ||
559 | it('Should block and unblock a user', async function () { | 654 | describe('User blocking', function () { |
560 | const user16 = { | 655 | it('Should block and unblock a user', async function () { |
561 | username: 'user_16', | 656 | const user16 = { |
562 | password: 'my super password' | 657 | username: 'user_16', |
563 | } | 658 | password: 'my super password' |
564 | const resUser = await createUser(server.url, server.accessToken, user16.username, user16.password) | 659 | } |
565 | const user16Id = resUser.body.user.id | 660 | const resUser = await createUser({ |
661 | url: server.url, | ||
662 | accessToken: server.accessToken, | ||
663 | username: user16.username, | ||
664 | password: user16.password | ||
665 | }) | ||
666 | const user16Id = resUser.body.user.id | ||
566 | 667 | ||
567 | accessToken = await userLogin(server, user16) | 668 | accessToken = await userLogin(server, user16) |
568 | 669 | ||
569 | await getMyUserInformation(server.url, accessToken, 200) | 670 | await getMyUserInformation(server.url, accessToken, 200) |
570 | await blockUser(server.url, user16Id, server.accessToken) | 671 | await blockUser(server.url, user16Id, server.accessToken) |
571 | 672 | ||
572 | await getMyUserInformation(server.url, accessToken, 401) | 673 | await getMyUserInformation(server.url, accessToken, 401) |
573 | await userLogin(server, user16, 400) | 674 | await userLogin(server, user16, 400) |
574 | 675 | ||
575 | await unblockUser(server.url, user16Id, server.accessToken) | 676 | await unblockUser(server.url, user16Id, server.accessToken) |
576 | accessToken = await userLogin(server, user16) | 677 | accessToken = await userLogin(server, user16) |
577 | await getMyUserInformation(server.url, accessToken, 200) | 678 | await getMyUserInformation(server.url, accessToken, 200) |
679 | }) | ||
578 | }) | 680 | }) |
579 | 681 | ||
580 | after(async function () { | 682 | after(async function () { |
581 | killallServers([ server ]) | 683 | await cleanupTests([ server ]) |
582 | |||
583 | // Keep the logs if the test failed | ||
584 | if (this[ 'ok' ]) { | ||
585 | await flushTests() | ||
586 | } | ||
587 | }) | 684 | }) |
588 | }) | 685 | }) |
diff --git a/server/tests/api/videos/index.ts b/server/tests/api/videos/index.ts index 97f467aae..93e1f3e98 100644 --- a/server/tests/api/videos/index.ts +++ b/server/tests/api/videos/index.ts | |||
@@ -8,11 +8,14 @@ import './video-change-ownership' | |||
8 | import './video-channels' | 8 | import './video-channels' |
9 | import './video-comments' | 9 | import './video-comments' |
10 | import './video-description' | 10 | import './video-description' |
11 | import './video-hls' | ||
11 | import './video-imports' | 12 | import './video-imports' |
12 | import './video-nsfw' | 13 | import './video-nsfw' |
14 | import './video-playlists' | ||
13 | import './video-privacy' | 15 | import './video-privacy' |
14 | import './video-schedule-update' | 16 | import './video-schedule-update' |
15 | import './video-transcoder' | 17 | import './video-transcoder' |
16 | import './videos-filter' | 18 | import './videos-filter' |
17 | import './videos-history' | 19 | import './videos-history' |
18 | import './videos-overview' | 20 | import './videos-overview' |
21 | import './videos-views-cleaner' | ||
diff --git a/server/tests/api/videos/multiple-servers.ts b/server/tests/api/videos/multiple-servers.ts index 6c281e49e..68c1e9a8d 100644 --- a/server/tests/api/videos/multiple-servers.ts +++ b/server/tests/api/videos/multiple-servers.ts | |||
@@ -9,7 +9,7 @@ import { VideoComment, VideoCommentThreadTree } from '../../../../shared/models/ | |||
9 | import { | 9 | import { |
10 | addVideoChannel, | 10 | addVideoChannel, |
11 | checkTmpIsEmpty, | 11 | checkTmpIsEmpty, |
12 | checkVideoFilesWereRemoved, | 12 | checkVideoFilesWereRemoved, cleanupTests, |
13 | completeVideoCheck, | 13 | completeVideoCheck, |
14 | createUser, | 14 | createUser, |
15 | dateIsValid, | 15 | dateIsValid, |
@@ -32,15 +32,15 @@ import { | |||
32 | viewVideo, | 32 | viewVideo, |
33 | wait, | 33 | wait, |
34 | webtorrentAdd | 34 | webtorrentAdd |
35 | } from '../../../../shared/utils' | 35 | } from '../../../../shared/extra-utils' |
36 | import { | 36 | import { |
37 | addVideoCommentReply, | 37 | addVideoCommentReply, |
38 | addVideoCommentThread, | 38 | addVideoCommentThread, |
39 | deleteVideoComment, | 39 | deleteVideoComment, |
40 | getVideoCommentThreads, | 40 | getVideoCommentThreads, |
41 | getVideoThreadComments | 41 | getVideoThreadComments |
42 | } from '../../../../shared/utils/videos/video-comments' | 42 | } from '../../../../shared/extra-utils/videos/video-comments' |
43 | import { waitJobs } from '../../../../shared/utils/server/jobs' | 43 | import { waitJobs } from '../../../../shared/extra-utils/server/jobs' |
44 | 44 | ||
45 | const expect = chai.expect | 45 | const expect = chai.expect |
46 | 46 | ||
@@ -98,6 +98,7 @@ describe('Test multiple servers', function () { | |||
98 | nsfw: true, | 98 | nsfw: true, |
99 | description: 'my super description for server 1', | 99 | description: 'my super description for server 1', |
100 | support: 'my super support text for server 1', | 100 | support: 'my super support text for server 1', |
101 | originallyPublishedAt: '2019-02-10T13:38:14.449Z', | ||
101 | tags: [ 'tag1p1', 'tag2p1' ], | 102 | tags: [ 'tag1p1', 'tag2p1' ], |
102 | channelId: videoChannelId, | 103 | channelId: videoChannelId, |
103 | fixture: 'video_short1.webm' | 104 | fixture: 'video_short1.webm' |
@@ -118,6 +119,7 @@ describe('Test multiple servers', function () { | |||
118 | nsfw: true, | 119 | nsfw: true, |
119 | description: 'my super description for server 1', | 120 | description: 'my super description for server 1', |
120 | support: 'my super support text for server 1', | 121 | support: 'my super support text for server 1', |
122 | originallyPublishedAt: '2019-02-10T13:38:14.449Z', | ||
121 | account: { | 123 | account: { |
122 | name: 'root', | 124 | name: 'root', |
123 | host: 'localhost:9001' | 125 | host: 'localhost:9001' |
@@ -128,6 +130,7 @@ describe('Test multiple servers', function () { | |||
128 | tags: [ 'tag1p1', 'tag2p1' ], | 130 | tags: [ 'tag1p1', 'tag2p1' ], |
129 | privacy: VideoPrivacy.PUBLIC, | 131 | privacy: VideoPrivacy.PUBLIC, |
130 | commentsEnabled: true, | 132 | commentsEnabled: true, |
133 | downloadEnabled: true, | ||
131 | channel: { | 134 | channel: { |
132 | displayName: 'my channel', | 135 | displayName: 'my channel', |
133 | name: 'super_channel_name', | 136 | name: 'super_channel_name', |
@@ -161,7 +164,7 @@ describe('Test multiple servers', function () { | |||
161 | username: 'user1', | 164 | username: 'user1', |
162 | password: 'super_password' | 165 | password: 'super_password' |
163 | } | 166 | } |
164 | await createUser(servers[1].url, servers[1].accessToken, user.username, user.password) | 167 | await createUser({ url: servers[ 1 ].url, accessToken: servers[ 1 ].accessToken, username: user.username, password: user.password }) |
165 | const userAccessToken = await userLogin(servers[1], user) | 168 | const userAccessToken = await userLogin(servers[1], user) |
166 | 169 | ||
167 | const videoAttributes = { | 170 | const videoAttributes = { |
@@ -199,6 +202,7 @@ describe('Test multiple servers', function () { | |||
199 | }, | 202 | }, |
200 | isLocal, | 203 | isLocal, |
201 | commentsEnabled: true, | 204 | commentsEnabled: true, |
205 | downloadEnabled: true, | ||
202 | duration: 5, | 206 | duration: 5, |
203 | tags: [ 'tag1p2', 'tag2p2', 'tag3p2' ], | 207 | tags: [ 'tag1p2', 'tag2p2', 'tag3p2' ], |
204 | privacy: VideoPrivacy.PUBLIC, | 208 | privacy: VideoPrivacy.PUBLIC, |
@@ -307,6 +311,7 @@ describe('Test multiple servers', function () { | |||
307 | isLocal, | 311 | isLocal, |
308 | duration: 5, | 312 | duration: 5, |
309 | commentsEnabled: true, | 313 | commentsEnabled: true, |
314 | downloadEnabled: true, | ||
310 | tags: [ 'tag1p3' ], | 315 | tags: [ 'tag1p3' ], |
311 | privacy: VideoPrivacy.PUBLIC, | 316 | privacy: VideoPrivacy.PUBLIC, |
312 | channel: { | 317 | channel: { |
@@ -338,6 +343,7 @@ describe('Test multiple servers', function () { | |||
338 | host: 'localhost:9003' | 343 | host: 'localhost:9003' |
339 | }, | 344 | }, |
340 | commentsEnabled: true, | 345 | commentsEnabled: true, |
346 | downloadEnabled: true, | ||
341 | isLocal, | 347 | isLocal, |
342 | duration: 5, | 348 | duration: 5, |
343 | tags: [ 'tag2p3', 'tag3p3', 'tag4p3' ], | 349 | tags: [ 'tag2p3', 'tag3p3', 'tag4p3' ], |
@@ -573,15 +579,15 @@ describe('Test multiple servers', function () { | |||
573 | this.timeout(20000) | 579 | this.timeout(20000) |
574 | 580 | ||
575 | await rateVideo(servers[0].url, servers[0].accessToken, remoteVideosServer1[0], 'like') | 581 | await rateVideo(servers[0].url, servers[0].accessToken, remoteVideosServer1[0], 'like') |
576 | await wait(200) | 582 | await wait(500) |
577 | await rateVideo(servers[0].url, servers[0].accessToken, remoteVideosServer1[0], 'dislike') | 583 | await rateVideo(servers[0].url, servers[0].accessToken, remoteVideosServer1[0], 'dislike') |
578 | await wait(200) | 584 | await wait(500) |
579 | await rateVideo(servers[0].url, servers[0].accessToken, remoteVideosServer1[0], 'like') | 585 | await rateVideo(servers[0].url, servers[0].accessToken, remoteVideosServer1[0], 'like') |
580 | await rateVideo(servers[2].url, servers[2].accessToken, localVideosServer3[1], 'like') | 586 | await rateVideo(servers[2].url, servers[2].accessToken, localVideosServer3[1], 'like') |
581 | await wait(200) | 587 | await wait(500) |
582 | await rateVideo(servers[2].url, servers[2].accessToken, localVideosServer3[1], 'dislike') | 588 | await rateVideo(servers[2].url, servers[2].accessToken, localVideosServer3[1], 'dislike') |
583 | await rateVideo(servers[2].url, servers[2].accessToken, remoteVideosServer3[1], 'dislike') | 589 | await rateVideo(servers[2].url, servers[2].accessToken, remoteVideosServer3[1], 'dislike') |
584 | await wait(200) | 590 | await wait(500) |
585 | await rateVideo(servers[2].url, servers[2].accessToken, remoteVideosServer3[0], 'like') | 591 | await rateVideo(servers[2].url, servers[2].accessToken, remoteVideosServer3[0], 'like') |
586 | 592 | ||
587 | await waitJobs(servers) | 593 | await waitJobs(servers) |
@@ -621,6 +627,7 @@ describe('Test multiple servers', function () { | |||
621 | support: 'my super support text updated', | 627 | support: 'my super support text updated', |
622 | tags: [ 'tag_up_1', 'tag_up_2' ], | 628 | tags: [ 'tag_up_1', 'tag_up_2' ], |
623 | thumbnailfile: 'thumbnail.jpg', | 629 | thumbnailfile: 'thumbnail.jpg', |
630 | originallyPublishedAt: '2019-02-11T13:38:14.449Z', | ||
624 | previewfile: 'preview.jpg' | 631 | previewfile: 'preview.jpg' |
625 | } | 632 | } |
626 | 633 | ||
@@ -648,6 +655,7 @@ describe('Test multiple servers', function () { | |||
648 | nsfw: true, | 655 | nsfw: true, |
649 | description: 'my super description updated', | 656 | description: 'my super description updated', |
650 | support: 'my super support text updated', | 657 | support: 'my super support text updated', |
658 | originallyPublishedAt: '2019-02-11T13:38:14.449Z', | ||
651 | account: { | 659 | account: { |
652 | name: 'root', | 660 | name: 'root', |
653 | host: 'localhost:9003' | 661 | host: 'localhost:9003' |
@@ -655,6 +663,7 @@ describe('Test multiple servers', function () { | |||
655 | isLocal, | 663 | isLocal, |
656 | duration: 5, | 664 | duration: 5, |
657 | commentsEnabled: true, | 665 | commentsEnabled: true, |
666 | downloadEnabled: true, | ||
658 | tags: [ 'tag_up_1', 'tag_up_2' ], | 667 | tags: [ 'tag_up_1', 'tag_up_2' ], |
659 | privacy: VideoPrivacy.PUBLIC, | 668 | privacy: VideoPrivacy.PUBLIC, |
660 | channel: { | 669 | channel: { |
@@ -914,11 +923,12 @@ describe('Test multiple servers', function () { | |||
914 | } | 923 | } |
915 | }) | 924 | }) |
916 | 925 | ||
917 | it('Should disable comments', async function () { | 926 | it('Should disable comments and download', async function () { |
918 | this.timeout(20000) | 927 | this.timeout(20000) |
919 | 928 | ||
920 | const attributes = { | 929 | const attributes = { |
921 | commentsEnabled: false | 930 | commentsEnabled: false, |
931 | downloadEnabled: false | ||
922 | } | 932 | } |
923 | 933 | ||
924 | await updateVideo(servers[0].url, servers[0].accessToken, videoUUID, attributes) | 934 | await updateVideo(servers[0].url, servers[0].accessToken, videoUUID, attributes) |
@@ -928,6 +938,7 @@ describe('Test multiple servers', function () { | |||
928 | for (const server of servers) { | 938 | for (const server of servers) { |
929 | const res = await getVideo(server.url, videoUUID) | 939 | const res = await getVideo(server.url, videoUUID) |
930 | expect(res.body.commentsEnabled).to.be.false | 940 | expect(res.body.commentsEnabled).to.be.false |
941 | expect(res.body.downloadEnabled).to.be.false | ||
931 | 942 | ||
932 | const text = 'my super forbidden comment' | 943 | const text = 'my super forbidden comment' |
933 | await addVideoCommentThread(server.url, server.accessToken, videoUUID, text, 409) | 944 | await addVideoCommentThread(server.url, server.accessToken, videoUUID, text, 409) |
@@ -976,6 +987,7 @@ describe('Test multiple servers', function () { | |||
976 | isLocal, | 987 | isLocal, |
977 | duration: 5, | 988 | duration: 5, |
978 | commentsEnabled: false, | 989 | commentsEnabled: false, |
990 | downloadEnabled: true, | ||
979 | tags: [ ], | 991 | tags: [ ], |
980 | privacy: VideoPrivacy.PUBLIC, | 992 | privacy: VideoPrivacy.PUBLIC, |
981 | channel: { | 993 | channel: { |
@@ -1018,11 +1030,6 @@ describe('Test multiple servers', function () { | |||
1018 | }) | 1030 | }) |
1019 | 1031 | ||
1020 | after(async function () { | 1032 | after(async function () { |
1021 | killallServers(servers) | 1033 | await cleanupTests(servers) |
1022 | |||
1023 | // Keep the logs if the test failed | ||
1024 | if (this['ok']) { | ||
1025 | await flushTests() | ||
1026 | } | ||
1027 | }) | 1034 | }) |
1028 | }) | 1035 | }) |
diff --git a/server/tests/api/videos/services.ts b/server/tests/api/videos/services.ts index 2da86964f..e9ad947b2 100644 --- a/server/tests/api/videos/services.ts +++ b/server/tests/api/videos/services.ts | |||
@@ -2,16 +2,8 @@ | |||
2 | 2 | ||
3 | import * as chai from 'chai' | 3 | import * as chai from 'chai' |
4 | import 'mocha' | 4 | import 'mocha' |
5 | import { | 5 | import { getOEmbed, getVideosList, ServerInfo, setAccessTokensToServers, uploadVideo } from '../../../../shared/extra-utils/index' |
6 | flushTests, | 6 | import { cleanupTests, flushAndRunServer } from '../../../../shared/extra-utils/server/servers' |
7 | getOEmbed, | ||
8 | getVideosList, | ||
9 | killallServers, | ||
10 | ServerInfo, | ||
11 | setAccessTokensToServers, | ||
12 | uploadVideo | ||
13 | } from '../../../../shared/utils/index' | ||
14 | import { runServer } from '../../../../shared/utils/server/servers' | ||
15 | 7 | ||
16 | const expect = chai.expect | 8 | const expect = chai.expect |
17 | 9 | ||
@@ -21,9 +13,7 @@ describe('Test services', function () { | |||
21 | before(async function () { | 13 | before(async function () { |
22 | this.timeout(30000) | 14 | this.timeout(30000) |
23 | 15 | ||
24 | await flushTests() | 16 | server = await flushAndRunServer(1) |
25 | |||
26 | server = await runServer(1) | ||
27 | 17 | ||
28 | await setAccessTokensToServers([ server ]) | 18 | await setAccessTokensToServers([ server ]) |
29 | 19 | ||
@@ -77,6 +67,6 @@ describe('Test services', function () { | |||
77 | }) | 67 | }) |
78 | 68 | ||
79 | after(async function () { | 69 | after(async function () { |
80 | killallServers([ server ]) | 70 | await cleanupTests([ server ]) |
81 | }) | 71 | }) |
82 | }) | 72 | }) |
diff --git a/server/tests/api/videos/single-server.ts b/server/tests/api/videos/single-server.ts index 069dec67c..1f366b642 100644 --- a/server/tests/api/videos/single-server.ts +++ b/server/tests/api/videos/single-server.ts | |||
@@ -6,8 +6,9 @@ import 'mocha' | |||
6 | import { VideoPrivacy } from '../../../../shared/models/videos' | 6 | import { VideoPrivacy } from '../../../../shared/models/videos' |
7 | import { | 7 | import { |
8 | checkVideoFilesWereRemoved, | 8 | checkVideoFilesWereRemoved, |
9 | cleanupTests, | ||
9 | completeVideoCheck, | 10 | completeVideoCheck, |
10 | flushTests, | 11 | flushAndRunServer, |
11 | getVideo, | 12 | getVideo, |
12 | getVideoCategories, | 13 | getVideoCategories, |
13 | getVideoLanguages, | 14 | getVideoLanguages, |
@@ -17,10 +18,8 @@ import { | |||
17 | getVideosListPagination, | 18 | getVideosListPagination, |
18 | getVideosListSort, | 19 | getVideosListSort, |
19 | getVideosWithFilters, | 20 | getVideosWithFilters, |
20 | killallServers, | ||
21 | rateVideo, | 21 | rateVideo, |
22 | removeVideo, | 22 | removeVideo, |
23 | runServer, | ||
24 | ServerInfo, | 23 | ServerInfo, |
25 | setAccessTokensToServers, | 24 | setAccessTokensToServers, |
26 | testImage, | 25 | testImage, |
@@ -28,7 +27,7 @@ import { | |||
28 | uploadVideo, | 27 | uploadVideo, |
29 | viewVideo, | 28 | viewVideo, |
30 | wait | 29 | wait |
31 | } from '../../../../shared/utils' | 30 | } from '../../../../shared/extra-utils' |
32 | 31 | ||
33 | const expect = chai.expect | 32 | const expect = chai.expect |
34 | 33 | ||
@@ -55,6 +54,7 @@ describe('Test a single server', function () { | |||
55 | tags: [ 'tag1', 'tag2', 'tag3' ], | 54 | tags: [ 'tag1', 'tag2', 'tag3' ], |
56 | privacy: VideoPrivacy.PUBLIC, | 55 | privacy: VideoPrivacy.PUBLIC, |
57 | commentsEnabled: true, | 56 | commentsEnabled: true, |
57 | downloadEnabled: true, | ||
58 | channel: { | 58 | channel: { |
59 | displayName: 'Main root channel', | 59 | displayName: 'Main root channel', |
60 | name: 'root_channel', | 60 | name: 'root_channel', |
@@ -87,6 +87,7 @@ describe('Test a single server', function () { | |||
87 | privacy: VideoPrivacy.PUBLIC, | 87 | privacy: VideoPrivacy.PUBLIC, |
88 | duration: 5, | 88 | duration: 5, |
89 | commentsEnabled: false, | 89 | commentsEnabled: false, |
90 | downloadEnabled: false, | ||
90 | channel: { | 91 | channel: { |
91 | name: 'root_channel', | 92 | name: 'root_channel', |
92 | displayName: 'Main root channel', | 93 | displayName: 'Main root channel', |
@@ -105,9 +106,7 @@ describe('Test a single server', function () { | |||
105 | before(async function () { | 106 | before(async function () { |
106 | this.timeout(30000) | 107 | this.timeout(30000) |
107 | 108 | ||
108 | await flushTests() | 109 | server = await flushAndRunServer(1) |
109 | |||
110 | server = await runServer(1) | ||
111 | 110 | ||
112 | await setAccessTokensToServers([ server ]) | 111 | await setAccessTokensToServers([ server ]) |
113 | }) | 112 | }) |
@@ -356,6 +355,7 @@ describe('Test a single server', function () { | |||
356 | nsfw: false, | 355 | nsfw: false, |
357 | description: 'my super description updated', | 356 | description: 'my super description updated', |
358 | commentsEnabled: false, | 357 | commentsEnabled: false, |
358 | downloadEnabled: false, | ||
359 | tags: [ 'tagup1', 'tagup2' ] | 359 | tags: [ 'tagup1', 'tagup2' ] |
360 | } | 360 | } |
361 | await updateVideo(server.url, server.accessToken, videoId, attributes) | 361 | await updateVideo(server.url, server.accessToken, videoId, attributes) |
@@ -424,11 +424,6 @@ describe('Test a single server', function () { | |||
424 | }) | 424 | }) |
425 | 425 | ||
426 | after(async function () { | 426 | after(async function () { |
427 | killallServers([ server ]) | 427 | await cleanupTests([ server ]) |
428 | |||
429 | // Keep the logs if the test failed | ||
430 | if (this['ok']) { | ||
431 | await flushTests() | ||
432 | } | ||
433 | }) | 428 | }) |
434 | }) | 429 | }) |
diff --git a/server/tests/api/videos/video-abuse.ts b/server/tests/api/videos/video-abuse.ts index 3a7b623da..7318497d5 100644 --- a/server/tests/api/videos/video-abuse.ts +++ b/server/tests/api/videos/video-abuse.ts | |||
@@ -4,6 +4,7 @@ import * as chai from 'chai' | |||
4 | import 'mocha' | 4 | import 'mocha' |
5 | import { VideoAbuse, VideoAbuseState } from '../../../../shared/models/videos' | 5 | import { VideoAbuse, VideoAbuseState } from '../../../../shared/models/videos' |
6 | import { | 6 | import { |
7 | cleanupTests, | ||
7 | deleteVideoAbuse, | 8 | deleteVideoAbuse, |
8 | flushAndRunMultipleServers, | 9 | flushAndRunMultipleServers, |
9 | getVideoAbusesList, | 10 | getVideoAbusesList, |
@@ -14,9 +15,9 @@ import { | |||
14 | setAccessTokensToServers, | 15 | setAccessTokensToServers, |
15 | updateVideoAbuse, | 16 | updateVideoAbuse, |
16 | uploadVideo | 17 | uploadVideo |
17 | } from '../../../../shared/utils/index' | 18 | } from '../../../../shared/extra-utils/index' |
18 | import { doubleFollow } from '../../../../shared/utils/server/follows' | 19 | import { doubleFollow } from '../../../../shared/extra-utils/server/follows' |
19 | import { waitJobs } from '../../../../shared/utils/server/jobs' | 20 | import { waitJobs } from '../../../../shared/extra-utils/server/jobs' |
20 | 21 | ||
21 | const expect = chai.expect | 22 | const expect = chai.expect |
22 | 23 | ||
@@ -173,6 +174,6 @@ describe('Test video abuses', function () { | |||
173 | }) | 174 | }) |
174 | 175 | ||
175 | after(async function () { | 176 | after(async function () { |
176 | killallServers(servers) | 177 | await cleanupTests(servers) |
177 | }) | 178 | }) |
178 | }) | 179 | }) |
diff --git a/server/tests/api/videos/video-blacklist.ts b/server/tests/api/videos/video-blacklist.ts index d39ad63b4..e907bbdc0 100644 --- a/server/tests/api/videos/video-blacklist.ts +++ b/server/tests/api/videos/video-blacklist.ts | |||
@@ -4,29 +4,32 @@ import * as chai from 'chai' | |||
4 | import { orderBy } from 'lodash' | 4 | import { orderBy } from 'lodash' |
5 | import 'mocha' | 5 | import 'mocha' |
6 | import { | 6 | import { |
7 | addVideoToBlacklist, | 7 | addVideoToBlacklist, cleanupTests, |
8 | createUser, | ||
8 | flushAndRunMultipleServers, | 9 | flushAndRunMultipleServers, |
9 | getBlacklistedVideosList, | 10 | getBlacklistedVideosList, |
10 | getMyVideos, | 11 | getMyVideos, |
11 | getSortedBlacklistedVideosList, | ||
12 | getVideosList, | 12 | getVideosList, |
13 | killallServers, | 13 | killallServers, |
14 | removeVideoFromBlacklist, | 14 | removeVideoFromBlacklist, |
15 | reRunServer, | ||
15 | searchVideo, | 16 | searchVideo, |
16 | ServerInfo, | 17 | ServerInfo, |
17 | setAccessTokensToServers, | 18 | setAccessTokensToServers, |
18 | updateVideo, | 19 | updateVideo, |
19 | updateVideoBlacklist, | 20 | updateVideoBlacklist, |
20 | uploadVideo, | 21 | uploadVideo, |
21 | viewVideo | 22 | userLogin |
22 | } from '../../../../shared/utils/index' | 23 | } from '../../../../shared/extra-utils/index' |
23 | import { doubleFollow } from '../../../../shared/utils/server/follows' | 24 | import { doubleFollow } from '../../../../shared/extra-utils/server/follows' |
24 | import { waitJobs } from '../../../../shared/utils/server/jobs' | 25 | import { waitJobs } from '../../../../shared/extra-utils/server/jobs' |
25 | import { VideoBlacklist } from '../../../../shared/models/videos' | 26 | import { VideoBlacklist, VideoBlacklistType } from '../../../../shared/models/videos' |
27 | import { UserAdminFlag } from '../../../../shared/models/users/user-flag.model' | ||
28 | import { UserRole } from '../../../../shared/models/users' | ||
26 | 29 | ||
27 | const expect = chai.expect | 30 | const expect = chai.expect |
28 | 31 | ||
29 | describe('Test video blacklist management', function () { | 32 | describe('Test video blacklist', function () { |
30 | let servers: ServerInfo[] = [] | 33 | let servers: ServerInfo[] = [] |
31 | let videoId: number | 34 | let videoId: number |
32 | 35 | ||
@@ -101,9 +104,9 @@ describe('Test video blacklist management', function () { | |||
101 | }) | 104 | }) |
102 | }) | 105 | }) |
103 | 106 | ||
104 | describe('When listing blacklisted videos', function () { | 107 | describe('When listing manually blacklisted videos', function () { |
105 | it('Should display all the blacklisted videos', async function () { | 108 | it('Should display all the blacklisted videos', async function () { |
106 | const res = await getBlacklistedVideosList(servers[0].url, servers[0].accessToken) | 109 | const res = await getBlacklistedVideosList({ url: servers[0].url, token: servers[0].accessToken }) |
107 | 110 | ||
108 | expect(res.body.total).to.equal(2) | 111 | expect(res.body.total).to.equal(2) |
109 | 112 | ||
@@ -117,8 +120,36 @@ describe('Test video blacklist management', function () { | |||
117 | } | 120 | } |
118 | }) | 121 | }) |
119 | 122 | ||
123 | it('Should display all the blacklisted videos when applying manual type filter', async function () { | ||
124 | const res = await getBlacklistedVideosList({ | ||
125 | url: servers[ 0 ].url, | ||
126 | token: servers[ 0 ].accessToken, | ||
127 | type: VideoBlacklistType.MANUAL | ||
128 | }) | ||
129 | |||
130 | expect(res.body.total).to.equal(2) | ||
131 | |||
132 | const blacklistedVideos = res.body.data | ||
133 | expect(blacklistedVideos).to.be.an('array') | ||
134 | expect(blacklistedVideos.length).to.equal(2) | ||
135 | }) | ||
136 | |||
137 | it('Should display nothing when applying automatic type filter', async function () { | ||
138 | const res = await getBlacklistedVideosList({ | ||
139 | url: servers[ 0 ].url, | ||
140 | token: servers[ 0 ].accessToken, | ||
141 | type: VideoBlacklistType.AUTO_BEFORE_PUBLISHED | ||
142 | }) | ||
143 | |||
144 | expect(res.body.total).to.equal(0) | ||
145 | |||
146 | const blacklistedVideos = res.body.data | ||
147 | expect(blacklistedVideos).to.be.an('array') | ||
148 | expect(blacklistedVideos.length).to.equal(0) | ||
149 | }) | ||
150 | |||
120 | it('Should get the correct sort when sorting by descending id', async function () { | 151 | it('Should get the correct sort when sorting by descending id', async function () { |
121 | const res = await getSortedBlacklistedVideosList(servers[0].url, servers[0].accessToken, '-id') | 152 | const res = await getBlacklistedVideosList({ url: servers[ 0 ].url, token: servers[ 0 ].accessToken, sort: '-id' }) |
122 | expect(res.body.total).to.equal(2) | 153 | expect(res.body.total).to.equal(2) |
123 | 154 | ||
124 | const blacklistedVideos = res.body.data | 155 | const blacklistedVideos = res.body.data |
@@ -131,7 +162,7 @@ describe('Test video blacklist management', function () { | |||
131 | }) | 162 | }) |
132 | 163 | ||
133 | it('Should get the correct sort when sorting by descending video name', async function () { | 164 | it('Should get the correct sort when sorting by descending video name', async function () { |
134 | const res = await getSortedBlacklistedVideosList(servers[0].url, servers[0].accessToken, '-name') | 165 | const res = await getBlacklistedVideosList({ url: servers[ 0 ].url, token: servers[ 0 ].accessToken, sort: '-name' }) |
135 | expect(res.body.total).to.equal(2) | 166 | expect(res.body.total).to.equal(2) |
136 | 167 | ||
137 | const blacklistedVideos = res.body.data | 168 | const blacklistedVideos = res.body.data |
@@ -144,7 +175,7 @@ describe('Test video blacklist management', function () { | |||
144 | }) | 175 | }) |
145 | 176 | ||
146 | it('Should get the correct sort when sorting by ascending creation date', async function () { | 177 | it('Should get the correct sort when sorting by ascending creation date', async function () { |
147 | const res = await getSortedBlacklistedVideosList(servers[0].url, servers[0].accessToken, 'createdAt') | 178 | const res = await getBlacklistedVideosList({ url: servers[ 0 ].url, token: servers[ 0 ].accessToken, sort: 'createdAt' }) |
148 | expect(res.body.total).to.equal(2) | 179 | expect(res.body.total).to.equal(2) |
149 | 180 | ||
150 | const blacklistedVideos = res.body.data | 181 | const blacklistedVideos = res.body.data |
@@ -161,7 +192,7 @@ describe('Test video blacklist management', function () { | |||
161 | it('Should change the reason', async function () { | 192 | it('Should change the reason', async function () { |
162 | await updateVideoBlacklist(servers[0].url, servers[0].accessToken, videoId, 'my super reason updated') | 193 | await updateVideoBlacklist(servers[0].url, servers[0].accessToken, videoId, 'my super reason updated') |
163 | 194 | ||
164 | const res = await getSortedBlacklistedVideosList(servers[0].url, servers[0].accessToken, '-name') | 195 | const res = await getBlacklistedVideosList({ url: servers[ 0 ].url, token: servers[ 0 ].accessToken, sort: '-name' }) |
165 | const video = res.body.data.find(b => b.video.id === videoId) | 196 | const video = res.body.data.find(b => b.video.id === videoId) |
166 | 197 | ||
167 | expect(video.reason).to.equal('my super reason updated') | 198 | expect(video.reason).to.equal('my super reason updated') |
@@ -197,7 +228,7 @@ describe('Test video blacklist management', function () { | |||
197 | 228 | ||
198 | it('Should remove a video from the blacklist on server 1', async function () { | 229 | it('Should remove a video from the blacklist on server 1', async function () { |
199 | // Get one video in the blacklist | 230 | // Get one video in the blacklist |
200 | const res = await getSortedBlacklistedVideosList(servers[0].url, servers[0].accessToken, '-name') | 231 | const res = await getBlacklistedVideosList({ url: servers[ 0 ].url, token: servers[ 0 ].accessToken, sort: '-name' }) |
201 | videoToRemove = res.body.data[0] | 232 | videoToRemove = res.body.data[0] |
202 | blacklist = res.body.data.slice(1) | 233 | blacklist = res.body.data.slice(1) |
203 | 234 | ||
@@ -218,7 +249,7 @@ describe('Test video blacklist management', function () { | |||
218 | }) | 249 | }) |
219 | 250 | ||
220 | it('Should not have the ex-blacklisted video in videos blacklist list on server 1', async function () { | 251 | it('Should not have the ex-blacklisted video in videos blacklist list on server 1', async function () { |
221 | const res = await getSortedBlacklistedVideosList(servers[0].url, servers[0].accessToken, '-name') | 252 | const res = await getBlacklistedVideosList({ url: servers[ 0 ].url, token: servers[ 0 ].accessToken, sort: '-name' }) |
222 | expect(res.body.total).to.equal(1) | 253 | expect(res.body.total).to.equal(1) |
223 | 254 | ||
224 | const videos = res.body.data | 255 | const videos = res.body.data |
@@ -292,7 +323,7 @@ describe('Test video blacklist management', function () { | |||
292 | }) | 323 | }) |
293 | 324 | ||
294 | it('Should have the correct video blacklist unfederate attribute', async function () { | 325 | it('Should have the correct video blacklist unfederate attribute', async function () { |
295 | const res = await getSortedBlacklistedVideosList(servers[0].url, servers[0].accessToken, 'createdAt') | 326 | const res = await getBlacklistedVideosList({ url: servers[ 0 ].url, token: servers[ 0 ].accessToken, sort: 'createdAt' }) |
296 | 327 | ||
297 | const blacklistedVideos: VideoBlacklist[] = res.body.data | 328 | const blacklistedVideos: VideoBlacklist[] = res.body.data |
298 | const video3Blacklisted = blacklistedVideos.find(b => b.video.uuid === video3UUID) | 329 | const video3Blacklisted = blacklistedVideos.find(b => b.video.uuid === video3UUID) |
@@ -317,7 +348,84 @@ describe('Test video blacklist management', function () { | |||
317 | 348 | ||
318 | }) | 349 | }) |
319 | 350 | ||
351 | describe('When auto blacklist videos', function () { | ||
352 | let userWithoutFlag: string | ||
353 | let userWithFlag: string | ||
354 | |||
355 | before(async function () { | ||
356 | this.timeout(20000) | ||
357 | |||
358 | killallServers([ servers[0] ]) | ||
359 | |||
360 | const config = { | ||
361 | 'auto_blacklist': { | ||
362 | videos: { | ||
363 | 'of_users': { | ||
364 | enabled: true | ||
365 | } | ||
366 | } | ||
367 | } | ||
368 | } | ||
369 | await reRunServer(servers[0], config) | ||
370 | |||
371 | { | ||
372 | const user = { username: 'user_without_flag', password: 'password' } | ||
373 | await createUser({ | ||
374 | url: servers[ 0 ].url, | ||
375 | accessToken: servers[ 0 ].accessToken, | ||
376 | username: user.username, | ||
377 | adminFlags: UserAdminFlag.NONE, | ||
378 | password: user.password, | ||
379 | role: UserRole.USER | ||
380 | }) | ||
381 | |||
382 | userWithoutFlag = await userLogin(servers[0], user) | ||
383 | } | ||
384 | |||
385 | { | ||
386 | const user = { username: 'user_with_flag', password: 'password' } | ||
387 | await createUser({ | ||
388 | url: servers[ 0 ].url, | ||
389 | accessToken: servers[ 0 ].accessToken, | ||
390 | username: user.username, | ||
391 | adminFlags: UserAdminFlag.BY_PASS_VIDEO_AUTO_BLACKLIST, | ||
392 | password: user.password, | ||
393 | role: UserRole.USER | ||
394 | }) | ||
395 | |||
396 | userWithFlag = await userLogin(servers[0], user) | ||
397 | } | ||
398 | |||
399 | await waitJobs(servers) | ||
400 | }) | ||
401 | |||
402 | it('Should auto blacklist a video', async function () { | ||
403 | await uploadVideo(servers[0].url, userWithoutFlag, { name: 'blacklisted' }) | ||
404 | |||
405 | const res = await getBlacklistedVideosList({ | ||
406 | url: servers[ 0 ].url, | ||
407 | token: servers[ 0 ].accessToken, | ||
408 | type: VideoBlacklistType.AUTO_BEFORE_PUBLISHED | ||
409 | }) | ||
410 | |||
411 | expect(res.body.total).to.equal(1) | ||
412 | expect(res.body.data[0].video.name).to.equal('blacklisted') | ||
413 | }) | ||
414 | |||
415 | it('Should not auto blacklist a video', async function () { | ||
416 | await uploadVideo(servers[0].url, userWithFlag, { name: 'not blacklisted' }) | ||
417 | |||
418 | const res = await getBlacklistedVideosList({ | ||
419 | url: servers[ 0 ].url, | ||
420 | token: servers[ 0 ].accessToken, | ||
421 | type: VideoBlacklistType.AUTO_BEFORE_PUBLISHED | ||
422 | }) | ||
423 | |||
424 | expect(res.body.total).to.equal(1) | ||
425 | }) | ||
426 | }) | ||
427 | |||
320 | after(async function () { | 428 | after(async function () { |
321 | killallServers(servers) | 429 | await cleanupTests(servers) |
322 | }) | 430 | }) |
323 | }) | 431 | }) |
diff --git a/server/tests/api/videos/video-captions.ts b/server/tests/api/videos/video-captions.ts index 57bee713f..5e13f5949 100644 --- a/server/tests/api/videos/video-captions.ts +++ b/server/tests/api/videos/video-captions.ts | |||
@@ -3,16 +3,21 @@ | |||
3 | import * as chai from 'chai' | 3 | import * as chai from 'chai' |
4 | import 'mocha' | 4 | import 'mocha' |
5 | import { | 5 | import { |
6 | checkVideoFilesWereRemoved, | 6 | checkVideoFilesWereRemoved, cleanupTests, |
7 | doubleFollow, | 7 | doubleFollow, |
8 | flushAndRunMultipleServers, | 8 | flushAndRunMultipleServers, |
9 | removeVideo, | 9 | removeVideo, |
10 | uploadVideo, | 10 | uploadVideo, |
11 | wait | 11 | wait |
12 | } from '../../../../shared/utils' | 12 | } from '../../../../shared/extra-utils' |
13 | import { flushTests, killallServers, ServerInfo, setAccessTokensToServers } from '../../../../shared/utils/index' | 13 | import { flushTests, killallServers, ServerInfo, setAccessTokensToServers } from '../../../../shared/extra-utils/index' |
14 | import { waitJobs } from '../../../../shared/utils/server/jobs' | 14 | import { waitJobs } from '../../../../shared/extra-utils/server/jobs' |
15 | import { createVideoCaption, deleteVideoCaption, listVideoCaptions, testCaptionFile } from '../../../../shared/utils/videos/video-captions' | 15 | import { |
16 | createVideoCaption, | ||
17 | deleteVideoCaption, | ||
18 | listVideoCaptions, | ||
19 | testCaptionFile | ||
20 | } from '../../../../shared/extra-utils/videos/video-captions' | ||
16 | import { VideoCaption } from '../../../../shared/models/videos/caption/video-caption.model' | 21 | import { VideoCaption } from '../../../../shared/models/videos/caption/video-caption.model' |
17 | 22 | ||
18 | const expect = chai.expect | 23 | const expect = chai.expect |
@@ -24,8 +29,6 @@ describe('Test video captions', function () { | |||
24 | before(async function () { | 29 | before(async function () { |
25 | this.timeout(30000) | 30 | this.timeout(30000) |
26 | 31 | ||
27 | await flushTests() | ||
28 | |||
29 | servers = await flushAndRunMultipleServers(2) | 32 | servers = await flushAndRunMultipleServers(2) |
30 | 33 | ||
31 | await setAccessTokensToServers(servers) | 34 | await setAccessTokensToServers(servers) |
@@ -193,6 +196,6 @@ describe('Test video captions', function () { | |||
193 | }) | 196 | }) |
194 | 197 | ||
195 | after(async function () { | 198 | after(async function () { |
196 | killallServers(servers) | 199 | await cleanupTests(servers) |
197 | }) | 200 | }) |
198 | }) | 201 | }) |
diff --git a/server/tests/api/videos/video-change-ownership.ts b/server/tests/api/videos/video-change-ownership.ts index 25675a966..1c0327d40 100644 --- a/server/tests/api/videos/video-change-ownership.ts +++ b/server/tests/api/videos/video-change-ownership.ts | |||
@@ -4,22 +4,23 @@ import * as chai from 'chai' | |||
4 | import 'mocha' | 4 | import 'mocha' |
5 | import { | 5 | import { |
6 | acceptChangeOwnership, | 6 | acceptChangeOwnership, |
7 | changeVideoOwnership, | 7 | changeVideoOwnership, cleanupTests, |
8 | createUser, doubleFollow, flushAndRunMultipleServers, | 8 | createUser, |
9 | flushTests, | 9 | doubleFollow, |
10 | flushAndRunMultipleServers, | ||
11 | flushAndRunServer, | ||
10 | getMyUserInformation, | 12 | getMyUserInformation, |
13 | getVideo, | ||
11 | getVideoChangeOwnershipList, | 14 | getVideoChangeOwnershipList, |
12 | getVideosList, | 15 | getVideosList, |
13 | killallServers, | 16 | killallServers, |
14 | refuseChangeOwnership, | 17 | refuseChangeOwnership, |
15 | runServer, | ||
16 | ServerInfo, | 18 | ServerInfo, |
17 | setAccessTokensToServers, | 19 | setAccessTokensToServers, |
18 | uploadVideo, | 20 | uploadVideo, |
19 | userLogin, | 21 | userLogin |
20 | getVideo | 22 | } from '../../../../shared/extra-utils' |
21 | } from '../../../../shared/utils' | 23 | import { waitJobs } from '../../../../shared/extra-utils/server/jobs' |
22 | import { waitJobs } from '../../../../shared/utils/server/jobs' | ||
23 | import { User } from '../../../../shared/models/users' | 24 | import { User } from '../../../../shared/models/users' |
24 | import { VideoDetails } from '../../../../shared/models/videos' | 25 | import { VideoDetails } from '../../../../shared/models/videos' |
25 | 26 | ||
@@ -46,8 +47,20 @@ describe('Test video change ownership - nominal', function () { | |||
46 | await setAccessTokensToServers(servers) | 47 | await setAccessTokensToServers(servers) |
47 | 48 | ||
48 | const videoQuota = 42000000 | 49 | const videoQuota = 42000000 |
49 | await createUser(servers[0].url, servers[0].accessToken, firstUser.username, firstUser.password, videoQuota) | 50 | await createUser({ |
50 | await createUser(servers[0].url, servers[0].accessToken, secondUser.username, secondUser.password, videoQuota) | 51 | url: servers[ 0 ].url, |
52 | accessToken: servers[ 0 ].accessToken, | ||
53 | username: firstUser.username, | ||
54 | password: firstUser.password, | ||
55 | videoQuota: videoQuota | ||
56 | }) | ||
57 | await createUser({ | ||
58 | url: servers[ 0 ].url, | ||
59 | accessToken: servers[ 0 ].accessToken, | ||
60 | username: secondUser.username, | ||
61 | password: secondUser.password, | ||
62 | videoQuota: videoQuota | ||
63 | }) | ||
51 | 64 | ||
52 | firstUserAccessToken = await userLogin(servers[0], firstUser) | 65 | firstUserAccessToken = await userLogin(servers[0], firstUser) |
53 | secondUserAccessToken = await userLogin(servers[0], secondUser) | 66 | secondUserAccessToken = await userLogin(servers[0], secondUser) |
@@ -190,7 +203,7 @@ describe('Test video change ownership - nominal', function () { | |||
190 | } | 203 | } |
191 | }) | 204 | }) |
192 | 205 | ||
193 | after(async function () { | 206 | after(function () { |
194 | killallServers(servers) | 207 | killallServers(servers) |
195 | }) | 208 | }) |
196 | }) | 209 | }) |
@@ -213,14 +226,25 @@ describe('Test video change ownership - quota too small', function () { | |||
213 | this.timeout(50000) | 226 | this.timeout(50000) |
214 | 227 | ||
215 | // Run one server | 228 | // Run one server |
216 | await flushTests() | 229 | server = await flushAndRunServer(1) |
217 | server = await runServer(1) | ||
218 | await setAccessTokensToServers([server]) | 230 | await setAccessTokensToServers([server]) |
219 | 231 | ||
220 | const videoQuota = 42000000 | 232 | const videoQuota = 42000000 |
221 | const limitedVideoQuota = 10 | 233 | const limitedVideoQuota = 10 |
222 | await createUser(server.url, server.accessToken, firstUser.username, firstUser.password, videoQuota) | 234 | await createUser({ |
223 | await createUser(server.url, server.accessToken, secondUser.username, secondUser.password, limitedVideoQuota) | 235 | url: server.url, |
236 | accessToken: server.accessToken, | ||
237 | username: firstUser.username, | ||
238 | password: firstUser.password, | ||
239 | videoQuota: videoQuota | ||
240 | }) | ||
241 | await createUser({ | ||
242 | url: server.url, | ||
243 | accessToken: server.accessToken, | ||
244 | username: secondUser.username, | ||
245 | password: secondUser.password, | ||
246 | videoQuota: limitedVideoQuota | ||
247 | }) | ||
224 | 248 | ||
225 | firstUserAccessToken = await userLogin(server, firstUser) | 249 | firstUserAccessToken = await userLogin(server, firstUser) |
226 | secondUserAccessToken = await userLogin(server, secondUser) | 250 | secondUserAccessToken = await userLogin(server, secondUser) |
@@ -274,6 +298,6 @@ describe('Test video change ownership - quota too small', function () { | |||
274 | }) | 298 | }) |
275 | 299 | ||
276 | after(async function () { | 300 | after(async function () { |
277 | killallServers([server]) | 301 | await cleanupTests([ server ]) |
278 | }) | 302 | }) |
279 | }) | 303 | }) |
diff --git a/server/tests/api/videos/video-channels.ts b/server/tests/api/videos/video-channels.ts index 63514d69c..345e96f43 100644 --- a/server/tests/api/videos/video-channels.ts +++ b/server/tests/api/videos/video-channels.ts | |||
@@ -4,6 +4,7 @@ import * as chai from 'chai' | |||
4 | import 'mocha' | 4 | import 'mocha' |
5 | import { User, Video } from '../../../../shared/index' | 5 | import { User, Video } from '../../../../shared/index' |
6 | import { | 6 | import { |
7 | cleanupTests, | ||
7 | createUser, | 8 | createUser, |
8 | doubleFollow, | 9 | doubleFollow, |
9 | flushAndRunMultipleServers, | 10 | flushAndRunMultipleServers, |
@@ -13,7 +14,7 @@ import { | |||
13 | updateVideoChannelAvatar, | 14 | updateVideoChannelAvatar, |
14 | uploadVideo, | 15 | uploadVideo, |
15 | userLogin | 16 | userLogin |
16 | } from '../../../../shared/utils' | 17 | } from '../../../../shared/extra-utils' |
17 | import { | 18 | import { |
18 | addVideoChannel, | 19 | addVideoChannel, |
19 | deleteVideoChannel, | 20 | deleteVideoChannel, |
@@ -26,8 +27,8 @@ import { | |||
26 | ServerInfo, | 27 | ServerInfo, |
27 | setAccessTokensToServers, | 28 | setAccessTokensToServers, |
28 | updateVideoChannel | 29 | updateVideoChannel |
29 | } from '../../../../shared/utils/index' | 30 | } from '../../../../shared/extra-utils/index' |
30 | import { waitJobs } from '../../../../shared/utils/server/jobs' | 31 | import { waitJobs } from '../../../../shared/extra-utils/server/jobs' |
31 | 32 | ||
32 | const expect = chai.expect | 33 | const expect = chai.expect |
33 | 34 | ||
@@ -42,8 +43,6 @@ describe('Test video channels', function () { | |||
42 | before(async function () { | 43 | before(async function () { |
43 | this.timeout(30000) | 44 | this.timeout(30000) |
44 | 45 | ||
45 | await flushTests() | ||
46 | |||
47 | servers = await flushAndRunMultipleServers(2) | 46 | servers = await flushAndRunMultipleServers(2) |
48 | 47 | ||
49 | await setAccessTokensToServers(servers) | 48 | await setAccessTokensToServers(servers) |
@@ -270,7 +269,7 @@ describe('Test video channels', function () { | |||
270 | } | 269 | } |
271 | 270 | ||
272 | { | 271 | { |
273 | await createUser(servers[ 0 ].url, servers[ 0 ].accessToken, 'toto', 'password') | 272 | await createUser({ url: servers[ 0 ].url, accessToken: servers[ 0 ].accessToken, username: 'toto', password: 'password' }) |
274 | const accessToken = await userLogin(servers[ 0 ], { username: 'toto', password: 'password' }) | 273 | const accessToken = await userLogin(servers[ 0 ], { username: 'toto', password: 'password' }) |
275 | 274 | ||
276 | const res = await getMyUserInformation(servers[ 0 ].url, accessToken) | 275 | const res = await getMyUserInformation(servers[ 0 ].url, accessToken) |
@@ -280,6 +279,6 @@ describe('Test video channels', function () { | |||
280 | }) | 279 | }) |
281 | 280 | ||
282 | after(async function () { | 281 | after(async function () { |
283 | killallServers(servers) | 282 | await cleanupTests(servers) |
284 | }) | 283 | }) |
285 | }) | 284 | }) |
diff --git a/server/tests/api/videos/video-comments.ts b/server/tests/api/videos/video-comments.ts index ce1b17e35..22fd8c058 100644 --- a/server/tests/api/videos/video-comments.ts +++ b/server/tests/api/videos/video-comments.ts | |||
@@ -3,24 +3,22 @@ | |||
3 | import * as chai from 'chai' | 3 | import * as chai from 'chai' |
4 | import 'mocha' | 4 | import 'mocha' |
5 | import { VideoComment, VideoCommentThreadTree } from '../../../../shared/models/videos/video-comment.model' | 5 | import { VideoComment, VideoCommentThreadTree } from '../../../../shared/models/videos/video-comment.model' |
6 | import { testImage } from '../../../../shared/utils' | 6 | import { cleanupTests, testImage } from '../../../../shared/extra-utils' |
7 | import { | 7 | import { |
8 | dateIsValid, | 8 | dateIsValid, |
9 | flushTests, | 9 | flushAndRunServer, |
10 | killallServers, | ||
11 | runServer, | ||
12 | ServerInfo, | 10 | ServerInfo, |
13 | setAccessTokensToServers, | 11 | setAccessTokensToServers, |
14 | updateMyAvatar, | 12 | updateMyAvatar, |
15 | uploadVideo | 13 | uploadVideo |
16 | } from '../../../../shared/utils/index' | 14 | } from '../../../../shared/extra-utils/index' |
17 | import { | 15 | import { |
18 | addVideoCommentReply, | 16 | addVideoCommentReply, |
19 | addVideoCommentThread, | 17 | addVideoCommentThread, |
20 | deleteVideoComment, | 18 | deleteVideoComment, |
21 | getVideoCommentThreads, | 19 | getVideoCommentThreads, |
22 | getVideoThreadComments | 20 | getVideoThreadComments |
23 | } from '../../../../shared/utils/videos/video-comments' | 21 | } from '../../../../shared/extra-utils/videos/video-comments' |
24 | 22 | ||
25 | const expect = chai.expect | 23 | const expect = chai.expect |
26 | 24 | ||
@@ -34,9 +32,7 @@ describe('Test video comments', function () { | |||
34 | before(async function () { | 32 | before(async function () { |
35 | this.timeout(30000) | 33 | this.timeout(30000) |
36 | 34 | ||
37 | await flushTests() | 35 | server = await flushAndRunServer(1) |
38 | |||
39 | server = await runServer(1) | ||
40 | 36 | ||
41 | await setAccessTokensToServers([ server ]) | 37 | await setAccessTokensToServers([ server ]) |
42 | 38 | ||
@@ -202,6 +198,6 @@ describe('Test video comments', function () { | |||
202 | }) | 198 | }) |
203 | 199 | ||
204 | after(async function () { | 200 | after(async function () { |
205 | killallServers([ server ]) | 201 | await cleanupTests([ server ]) |
206 | }) | 202 | }) |
207 | }) | 203 | }) |
diff --git a/server/tests/api/videos/video-description.ts b/server/tests/api/videos/video-description.ts index cbda0b9a6..db4d278bf 100644 --- a/server/tests/api/videos/video-description.ts +++ b/server/tests/api/videos/video-description.ts | |||
@@ -3,6 +3,7 @@ | |||
3 | import * as chai from 'chai' | 3 | import * as chai from 'chai' |
4 | import 'mocha' | 4 | import 'mocha' |
5 | import { | 5 | import { |
6 | cleanupTests, | ||
6 | flushAndRunMultipleServers, | 7 | flushAndRunMultipleServers, |
7 | getVideo, | 8 | getVideo, |
8 | getVideoDescription, | 9 | getVideoDescription, |
@@ -12,9 +13,9 @@ import { | |||
12 | setAccessTokensToServers, | 13 | setAccessTokensToServers, |
13 | updateVideo, | 14 | updateVideo, |
14 | uploadVideo | 15 | uploadVideo |
15 | } from '../../../../shared/utils/index' | 16 | } from '../../../../shared/extra-utils/index' |
16 | import { doubleFollow } from '../../../../shared/utils/server/follows' | 17 | import { doubleFollow } from '../../../../shared/extra-utils/server/follows' |
17 | import { waitJobs } from '../../../../shared/utils/server/jobs' | 18 | import { waitJobs } from '../../../../shared/extra-utils/server/jobs' |
18 | 19 | ||
19 | const expect = chai.expect | 20 | const expect = chai.expect |
20 | 21 | ||
@@ -100,6 +101,6 @@ describe('Test video description', function () { | |||
100 | }) | 101 | }) |
101 | 102 | ||
102 | after(async function () { | 103 | after(async function () { |
103 | killallServers(servers) | 104 | await cleanupTests(servers) |
104 | }) | 105 | }) |
105 | }) | 106 | }) |
diff --git a/server/tests/api/videos/video-hls.ts b/server/tests/api/videos/video-hls.ts new file mode 100644 index 000000000..22031c18b --- /dev/null +++ b/server/tests/api/videos/video-hls.ts | |||
@@ -0,0 +1,134 @@ | |||
1 | /* tslint:disable:no-unused-expression */ | ||
2 | |||
3 | import * as chai from 'chai' | ||
4 | import 'mocha' | ||
5 | import { | ||
6 | checkDirectoryIsEmpty, | ||
7 | checkSegmentHash, | ||
8 | checkTmpIsEmpty, cleanupTests, | ||
9 | doubleFollow, | ||
10 | flushAndRunMultipleServers, | ||
11 | flushTests, | ||
12 | getPlaylist, | ||
13 | getVideo, | ||
14 | killallServers, | ||
15 | removeVideo, | ||
16 | ServerInfo, | ||
17 | setAccessTokensToServers, | ||
18 | updateVideo, | ||
19 | uploadVideo, | ||
20 | waitJobs | ||
21 | } from '../../../../shared/extra-utils' | ||
22 | import { VideoDetails } from '../../../../shared/models/videos' | ||
23 | import { VideoStreamingPlaylistType } from '../../../../shared/models/videos/video-streaming-playlist.type' | ||
24 | import { join } from 'path' | ||
25 | |||
26 | const expect = chai.expect | ||
27 | |||
28 | async function checkHlsPlaylist (servers: ServerInfo[], videoUUID: string) { | ||
29 | const resolutions = [ 240, 360, 480, 720 ] | ||
30 | |||
31 | for (const server of servers) { | ||
32 | const res = await getVideo(server.url, videoUUID) | ||
33 | const videoDetails: VideoDetails = res.body | ||
34 | |||
35 | expect(videoDetails.streamingPlaylists).to.have.lengthOf(1) | ||
36 | |||
37 | const hlsPlaylist = videoDetails.streamingPlaylists.find(p => p.type === VideoStreamingPlaylistType.HLS) | ||
38 | expect(hlsPlaylist).to.not.be.undefined | ||
39 | |||
40 | { | ||
41 | const res2 = await getPlaylist(hlsPlaylist.playlistUrl) | ||
42 | |||
43 | const masterPlaylist = res2.text | ||
44 | |||
45 | expect(masterPlaylist).to.contain('#EXT-X-STREAM-INF:BANDWIDTH=55472,RESOLUTION=640x360,FRAME-RATE=25') | ||
46 | |||
47 | for (const resolution of resolutions) { | ||
48 | expect(masterPlaylist).to.contain(`${resolution}.m3u8`) | ||
49 | } | ||
50 | } | ||
51 | |||
52 | { | ||
53 | for (const resolution of resolutions) { | ||
54 | const res2 = await getPlaylist(`http://localhost:9001/static/streaming-playlists/hls/${videoUUID}/${resolution}.m3u8`) | ||
55 | |||
56 | const subPlaylist = res2.text | ||
57 | expect(subPlaylist).to.contain(`${videoUUID}-${resolution}-fragmented.mp4`) | ||
58 | } | ||
59 | } | ||
60 | |||
61 | { | ||
62 | const baseUrl = 'http://localhost:9001/static/streaming-playlists/hls' | ||
63 | |||
64 | for (const resolution of resolutions) { | ||
65 | await checkSegmentHash(baseUrl, baseUrl, videoUUID, resolution, hlsPlaylist) | ||
66 | } | ||
67 | } | ||
68 | } | ||
69 | } | ||
70 | |||
71 | describe('Test HLS videos', function () { | ||
72 | let servers: ServerInfo[] = [] | ||
73 | let videoUUID = '' | ||
74 | |||
75 | before(async function () { | ||
76 | this.timeout(120000) | ||
77 | |||
78 | servers = await flushAndRunMultipleServers(2, { transcoding: { enabled: true, hls: { enabled: true } } }) | ||
79 | |||
80 | // Get the access tokens | ||
81 | await setAccessTokensToServers(servers) | ||
82 | |||
83 | // Server 1 and server 2 follow each other | ||
84 | await doubleFollow(servers[0], servers[1]) | ||
85 | }) | ||
86 | |||
87 | it('Should upload a video and transcode it to HLS', async function () { | ||
88 | this.timeout(120000) | ||
89 | |||
90 | { | ||
91 | const res = await uploadVideo(servers[ 0 ].url, servers[ 0 ].accessToken, { name: 'video 1', fixture: 'video_short.webm' }) | ||
92 | videoUUID = res.body.video.uuid | ||
93 | } | ||
94 | |||
95 | await waitJobs(servers) | ||
96 | |||
97 | await checkHlsPlaylist(servers, videoUUID) | ||
98 | }) | ||
99 | |||
100 | it('Should update the video', async function () { | ||
101 | await updateVideo(servers[0].url, servers[0].accessToken, videoUUID, { name: 'video 1 updated' }) | ||
102 | |||
103 | await waitJobs(servers) | ||
104 | |||
105 | await checkHlsPlaylist(servers, videoUUID) | ||
106 | }) | ||
107 | |||
108 | it('Should delete the video', async function () { | ||
109 | await removeVideo(servers[0].url, servers[0].accessToken, videoUUID) | ||
110 | |||
111 | await waitJobs(servers) | ||
112 | |||
113 | for (const server of servers) { | ||
114 | await getVideo(server.url, videoUUID, 404) | ||
115 | } | ||
116 | }) | ||
117 | |||
118 | it('Should have the playlists/segment deleted from the disk', async function () { | ||
119 | for (const server of servers) { | ||
120 | await checkDirectoryIsEmpty(server, 'videos') | ||
121 | await checkDirectoryIsEmpty(server, join('streaming-playlists', 'hls')) | ||
122 | } | ||
123 | }) | ||
124 | |||
125 | it('Should have an empty tmp directory', async function () { | ||
126 | for (const server of servers) { | ||
127 | await checkTmpIsEmpty(server) | ||
128 | } | ||
129 | }) | ||
130 | |||
131 | after(async function () { | ||
132 | await cleanupTests(servers) | ||
133 | }) | ||
134 | }) | ||
diff --git a/server/tests/api/videos/video-imports.ts b/server/tests/api/videos/video-imports.ts index cd4988553..1233ed6eb 100644 --- a/server/tests/api/videos/video-imports.ts +++ b/server/tests/api/videos/video-imports.ts | |||
@@ -4,6 +4,7 @@ import * as chai from 'chai' | |||
4 | import 'mocha' | 4 | import 'mocha' |
5 | import { VideoDetails, VideoImport, VideoPrivacy } from '../../../../shared/models/videos' | 5 | import { VideoDetails, VideoImport, VideoPrivacy } from '../../../../shared/models/videos' |
6 | import { | 6 | import { |
7 | cleanupTests, | ||
7 | doubleFollow, | 8 | doubleFollow, |
8 | flushAndRunMultipleServers, | 9 | flushAndRunMultipleServers, |
9 | getMyUserInformation, | 10 | getMyUserInformation, |
@@ -14,9 +15,9 @@ import { | |||
14 | killallServers, | 15 | killallServers, |
15 | ServerInfo, | 16 | ServerInfo, |
16 | setAccessTokensToServers | 17 | setAccessTokensToServers |
17 | } from '../../../../shared/utils' | 18 | } from '../../../../shared/extra-utils' |
18 | import { waitJobs } from '../../../../shared/utils/server/jobs' | 19 | import { waitJobs } from '../../../../shared/extra-utils/server/jobs' |
19 | import { getMagnetURI, getYoutubeVideoUrl, importVideo, getMyVideoImports } from '../../../../shared/utils/videos/video-imports' | 20 | import { getMagnetURI, getYoutubeVideoUrl, importVideo, getMyVideoImports } from '../../../../shared/extra-utils/videos/video-imports' |
20 | 21 | ||
21 | const expect = chai.expect | 22 | const expect = chai.expect |
22 | 23 | ||
@@ -38,6 +39,11 @@ describe('Test video imports', function () { | |||
38 | expect(videoHttp.tags).to.deep.equal([ 'tag1', 'tag2' ]) | 39 | expect(videoHttp.tags).to.deep.equal([ 'tag1', 'tag2' ]) |
39 | expect(videoHttp.files).to.have.lengthOf(1) | 40 | expect(videoHttp.files).to.have.lengthOf(1) |
40 | 41 | ||
42 | const originallyPublishedAt = new Date(videoHttp.originallyPublishedAt) | ||
43 | expect(originallyPublishedAt.getDate()).to.equal(14) | ||
44 | expect(originallyPublishedAt.getMonth()).to.equal(0) | ||
45 | expect(originallyPublishedAt.getFullYear()).to.equal(2019) | ||
46 | |||
41 | const resMagnet = await getVideo(url, idMagnet) | 47 | const resMagnet = await getVideo(url, idMagnet) |
42 | const videoMagnet: VideoDetails = resMagnet.body | 48 | const videoMagnet: VideoDetails = resMagnet.body |
43 | const resTorrent = await getVideo(url, idTorrent) | 49 | const resTorrent = await getVideo(url, idTorrent) |
@@ -237,6 +243,6 @@ describe('Test video imports', function () { | |||
237 | }) | 243 | }) |
238 | 244 | ||
239 | after(async function () { | 245 | after(async function () { |
240 | killallServers(servers) | 246 | await cleanupTests(servers) |
241 | }) | 247 | }) |
242 | }) | 248 | }) |
diff --git a/server/tests/api/videos/video-nsfw.ts b/server/tests/api/videos/video-nsfw.ts index df1ee2eb9..ad6a4b43f 100644 --- a/server/tests/api/videos/video-nsfw.ts +++ b/server/tests/api/videos/video-nsfw.ts | |||
@@ -2,30 +2,23 @@ | |||
2 | 2 | ||
3 | import * as chai from 'chai' | 3 | import * as chai from 'chai' |
4 | import 'mocha' | 4 | import 'mocha' |
5 | import { cleanupTests, getVideosList, ServerInfo, setAccessTokensToServers, uploadVideo } from '../../../../shared/extra-utils/index' | ||
6 | import { userLogin } from '../../../../shared/extra-utils/users/login' | ||
7 | import { createUser } from '../../../../shared/extra-utils/users/users' | ||
8 | import { getMyVideos } from '../../../../shared/extra-utils/videos/videos' | ||
5 | import { | 9 | import { |
6 | flushTests, | 10 | flushAndRunServer, |
7 | getVideosList, | ||
8 | killallServers, | ||
9 | ServerInfo, | ||
10 | setAccessTokensToServers, | ||
11 | uploadVideo | ||
12 | } from '../../../../shared/utils/index' | ||
13 | import { userLogin } from '../../../../shared/utils/users/login' | ||
14 | import { createUser } from '../../../../shared/utils/users/users' | ||
15 | import { getMyVideos } from '../../../../shared/utils/videos/videos' | ||
16 | import { | ||
17 | getAccountVideos, | 11 | getAccountVideos, |
18 | getConfig, | 12 | getConfig, |
19 | getCustomConfig, | 13 | getCustomConfig, |
20 | getMyUserInformation, | 14 | getMyUserInformation, |
21 | getVideoChannelVideos, | 15 | getVideoChannelVideos, |
22 | getVideosListWithToken, | 16 | getVideosListWithToken, |
23 | runServer, | ||
24 | searchVideo, | 17 | searchVideo, |
25 | searchVideoWithToken, | 18 | searchVideoWithToken, |
26 | updateCustomConfig, | 19 | updateCustomConfig, |
27 | updateMyUser | 20 | updateMyUser |
28 | } from '../../../../shared/utils' | 21 | } from '../../../../shared/extra-utils' |
29 | import { ServerConfig } from '../../../../shared/models' | 22 | import { ServerConfig } from '../../../../shared/models' |
30 | import { CustomConfig } from '../../../../shared/models/server/custom-config.model' | 23 | import { CustomConfig } from '../../../../shared/models/server/custom-config.model' |
31 | import { User } from '../../../../shared/models/users' | 24 | import { User } from '../../../../shared/models/users' |
@@ -64,9 +57,7 @@ describe('Test video NSFW policy', function () { | |||
64 | 57 | ||
65 | before(async function () { | 58 | before(async function () { |
66 | this.timeout(50000) | 59 | this.timeout(50000) |
67 | 60 | server = await flushAndRunServer(1) | |
68 | await flushTests() | ||
69 | server = await runServer(1) | ||
70 | 61 | ||
71 | // Get the access tokens | 62 | // Get the access tokens |
72 | await setAccessTokensToServers([ server ]) | 63 | await setAccessTokensToServers([ server ]) |
@@ -144,7 +135,7 @@ describe('Test video NSFW policy', function () { | |||
144 | it('Should create a user having the default nsfw policy', async function () { | 135 | it('Should create a user having the default nsfw policy', async function () { |
145 | const username = 'user1' | 136 | const username = 'user1' |
146 | const password = 'my super password' | 137 | const password = 'my super password' |
147 | await createUser(server.url, server.accessToken, username, password) | 138 | await createUser({ url: server.url, accessToken: server.accessToken, username: username, password: password }) |
148 | 139 | ||
149 | userAccessToken = await userLogin(server, { username, password }) | 140 | userAccessToken = await userLogin(server, { username, password }) |
150 | 141 | ||
@@ -244,6 +235,6 @@ describe('Test video NSFW policy', function () { | |||
244 | }) | 235 | }) |
245 | 236 | ||
246 | after(async function () { | 237 | after(async function () { |
247 | killallServers([ server ]) | 238 | await cleanupTests([ server ]) |
248 | }) | 239 | }) |
249 | }) | 240 | }) |
diff --git a/server/tests/api/videos/video-playlists.ts b/server/tests/api/videos/video-playlists.ts new file mode 100644 index 000000000..e4d817ff8 --- /dev/null +++ b/server/tests/api/videos/video-playlists.ts | |||
@@ -0,0 +1,867 @@ | |||
1 | /* tslint:disable:no-unused-expression */ | ||
2 | |||
3 | import * as chai from 'chai' | ||
4 | import 'mocha' | ||
5 | import { | ||
6 | addVideoChannel, | ||
7 | addVideoInPlaylist, | ||
8 | checkPlaylistFilesWereRemoved, | ||
9 | cleanupTests, | ||
10 | createUser, | ||
11 | createVideoPlaylist, | ||
12 | deleteVideoChannel, | ||
13 | deleteVideoPlaylist, | ||
14 | doubleFollow, | ||
15 | doVideosExistInMyPlaylist, | ||
16 | flushAndRunMultipleServers, | ||
17 | getAccountPlaylistsList, | ||
18 | getAccountPlaylistsListWithToken, | ||
19 | getMyUserInformation, | ||
20 | getPlaylistVideos, | ||
21 | getVideoChannelPlaylistsList, | ||
22 | getVideoPlaylist, | ||
23 | getVideoPlaylistPrivacies, | ||
24 | getVideoPlaylistsList, | ||
25 | getVideoPlaylistWithToken, | ||
26 | removeUser, | ||
27 | removeVideoFromPlaylist, | ||
28 | reorderVideosPlaylist, | ||
29 | ServerInfo, | ||
30 | setAccessTokensToServers, | ||
31 | setDefaultVideoChannel, | ||
32 | testImage, | ||
33 | unfollow, | ||
34 | updateVideoPlaylist, | ||
35 | updateVideoPlaylistElement, | ||
36 | uploadVideo, | ||
37 | uploadVideoAndGetId, | ||
38 | userLogin, | ||
39 | waitJobs | ||
40 | } from '../../../../shared/extra-utils' | ||
41 | import { VideoPlaylistPrivacy } from '../../../../shared/models/videos/playlist/video-playlist-privacy.model' | ||
42 | import { VideoPlaylist } from '../../../../shared/models/videos/playlist/video-playlist.model' | ||
43 | import { Video } from '../../../../shared/models/videos' | ||
44 | import { VideoPlaylistType } from '../../../../shared/models/videos/playlist/video-playlist-type.model' | ||
45 | import { VideoExistInPlaylist } from '../../../../shared/models/videos/playlist/video-exist-in-playlist.model' | ||
46 | import { User } from '../../../../shared/models/users' | ||
47 | |||
48 | const expect = chai.expect | ||
49 | |||
50 | describe('Test video playlists', function () { | ||
51 | let servers: ServerInfo[] = [] | ||
52 | |||
53 | let playlistServer2Id1: number | ||
54 | let playlistServer2Id2: number | ||
55 | let playlistServer2UUID2: number | ||
56 | |||
57 | let playlistServer1Id: number | ||
58 | let playlistServer1UUID: string | ||
59 | |||
60 | let nsfwVideoServer1: number | ||
61 | |||
62 | before(async function () { | ||
63 | this.timeout(120000) | ||
64 | |||
65 | servers = await flushAndRunMultipleServers(3, { transcoding: { enabled: false } }) | ||
66 | |||
67 | // Get the access tokens | ||
68 | await setAccessTokensToServers(servers) | ||
69 | await setDefaultVideoChannel(servers) | ||
70 | |||
71 | // Server 1 and server 2 follow each other | ||
72 | await doubleFollow(servers[0], servers[1]) | ||
73 | // Server 1 and server 3 follow each other | ||
74 | await doubleFollow(servers[0], servers[2]) | ||
75 | |||
76 | { | ||
77 | const serverPromises: Promise<any>[][] = [] | ||
78 | |||
79 | for (const server of servers) { | ||
80 | const videoPromises: Promise<any>[] = [] | ||
81 | |||
82 | for (let i = 0; i < 7; i++) { | ||
83 | videoPromises.push( | ||
84 | uploadVideo(server.url, server.accessToken, { name: `video ${i} server ${server.serverNumber}`, nsfw: false }) | ||
85 | .then(res => res.body.video) | ||
86 | ) | ||
87 | } | ||
88 | |||
89 | serverPromises.push(videoPromises) | ||
90 | } | ||
91 | |||
92 | servers[0].videos = await Promise.all(serverPromises[0]) | ||
93 | servers[1].videos = await Promise.all(serverPromises[1]) | ||
94 | servers[2].videos = await Promise.all(serverPromises[2]) | ||
95 | } | ||
96 | |||
97 | nsfwVideoServer1 = (await uploadVideoAndGetId({ server: servers[ 0 ], videoName: 'NSFW video', nsfw: true })).id | ||
98 | |||
99 | await waitJobs(servers) | ||
100 | }) | ||
101 | |||
102 | it('Should list video playlist privacies', async function () { | ||
103 | const res = await getVideoPlaylistPrivacies(servers[0].url) | ||
104 | |||
105 | const privacies = res.body | ||
106 | expect(Object.keys(privacies)).to.have.length.at.least(3) | ||
107 | |||
108 | expect(privacies[3]).to.equal('Private') | ||
109 | }) | ||
110 | |||
111 | it('Should list watch later playlist', async function () { | ||
112 | const url = servers[ 0 ].url | ||
113 | const accessToken = servers[ 0 ].accessToken | ||
114 | |||
115 | { | ||
116 | const res = await getAccountPlaylistsListWithToken(url, accessToken, 'root', 0, 5, VideoPlaylistType.WATCH_LATER) | ||
117 | |||
118 | expect(res.body.total).to.equal(1) | ||
119 | expect(res.body.data).to.have.lengthOf(1) | ||
120 | |||
121 | const playlist: VideoPlaylist = res.body.data[ 0 ] | ||
122 | expect(playlist.displayName).to.equal('Watch later') | ||
123 | expect(playlist.type.id).to.equal(VideoPlaylistType.WATCH_LATER) | ||
124 | expect(playlist.type.label).to.equal('Watch later') | ||
125 | } | ||
126 | |||
127 | { | ||
128 | const res = await getAccountPlaylistsListWithToken(url, accessToken, 'root', 0, 5, VideoPlaylistType.REGULAR) | ||
129 | |||
130 | expect(res.body.total).to.equal(0) | ||
131 | expect(res.body.data).to.have.lengthOf(0) | ||
132 | } | ||
133 | |||
134 | { | ||
135 | const res = await getAccountPlaylistsList(url, 'root', 0, 5) | ||
136 | expect(res.body.total).to.equal(0) | ||
137 | expect(res.body.data).to.have.lengthOf(0) | ||
138 | } | ||
139 | }) | ||
140 | |||
141 | it('Should create a playlist on server 1 and have the playlist on server 2 and 3', async function () { | ||
142 | this.timeout(30000) | ||
143 | |||
144 | await createVideoPlaylist({ | ||
145 | url: servers[0].url, | ||
146 | token: servers[0].accessToken, | ||
147 | playlistAttrs: { | ||
148 | displayName: 'my super playlist', | ||
149 | privacy: VideoPlaylistPrivacy.PUBLIC, | ||
150 | description: 'my super description', | ||
151 | thumbnailfile: 'thumbnail.jpg', | ||
152 | videoChannelId: servers[0].videoChannel.id | ||
153 | } | ||
154 | }) | ||
155 | |||
156 | await waitJobs(servers) | ||
157 | |||
158 | for (const server of servers) { | ||
159 | const res = await getVideoPlaylistsList(server.url, 0, 5) | ||
160 | expect(res.body.total).to.equal(1) | ||
161 | expect(res.body.data).to.have.lengthOf(1) | ||
162 | |||
163 | const playlistFromList = res.body.data[0] as VideoPlaylist | ||
164 | |||
165 | const res2 = await getVideoPlaylist(server.url, playlistFromList.uuid) | ||
166 | const playlistFromGet = res2.body | ||
167 | |||
168 | for (const playlist of [ playlistFromGet, playlistFromList ]) { | ||
169 | expect(playlist.id).to.be.a('number') | ||
170 | expect(playlist.uuid).to.be.a('string') | ||
171 | |||
172 | expect(playlist.isLocal).to.equal(server.serverNumber === 1) | ||
173 | |||
174 | expect(playlist.displayName).to.equal('my super playlist') | ||
175 | expect(playlist.description).to.equal('my super description') | ||
176 | expect(playlist.privacy.id).to.equal(VideoPlaylistPrivacy.PUBLIC) | ||
177 | expect(playlist.privacy.label).to.equal('Public') | ||
178 | expect(playlist.type.id).to.equal(VideoPlaylistType.REGULAR) | ||
179 | expect(playlist.type.label).to.equal('Regular') | ||
180 | |||
181 | expect(playlist.videosLength).to.equal(0) | ||
182 | |||
183 | expect(playlist.ownerAccount.name).to.equal('root') | ||
184 | expect(playlist.ownerAccount.displayName).to.equal('root') | ||
185 | expect(playlist.videoChannel.name).to.equal('root_channel') | ||
186 | expect(playlist.videoChannel.displayName).to.equal('Main root channel') | ||
187 | } | ||
188 | } | ||
189 | }) | ||
190 | |||
191 | it('Should create a playlist on server 2 and have the playlist on server 1 but not on server 3', async function () { | ||
192 | this.timeout(30000) | ||
193 | |||
194 | { | ||
195 | const res = await createVideoPlaylist({ | ||
196 | url: servers[1].url, | ||
197 | token: servers[1].accessToken, | ||
198 | playlistAttrs: { | ||
199 | displayName: 'playlist 2', | ||
200 | privacy: VideoPlaylistPrivacy.PUBLIC, | ||
201 | videoChannelId: servers[1].videoChannel.id | ||
202 | } | ||
203 | }) | ||
204 | playlistServer2Id1 = res.body.videoPlaylist.id | ||
205 | } | ||
206 | |||
207 | { | ||
208 | const res = await createVideoPlaylist({ | ||
209 | url: servers[ 1 ].url, | ||
210 | token: servers[ 1 ].accessToken, | ||
211 | playlistAttrs: { | ||
212 | displayName: 'playlist 3', | ||
213 | privacy: VideoPlaylistPrivacy.PUBLIC, | ||
214 | thumbnailfile: 'thumbnail.jpg', | ||
215 | videoChannelId: servers[1].videoChannel.id | ||
216 | } | ||
217 | }) | ||
218 | |||
219 | playlistServer2Id2 = res.body.videoPlaylist.id | ||
220 | playlistServer2UUID2 = res.body.videoPlaylist.uuid | ||
221 | } | ||
222 | |||
223 | for (let id of [ playlistServer2Id1, playlistServer2Id2 ]) { | ||
224 | await addVideoInPlaylist({ | ||
225 | url: servers[ 1 ].url, | ||
226 | token: servers[ 1 ].accessToken, | ||
227 | playlistId: id, | ||
228 | elementAttrs: { videoId: servers[ 1 ].videos[ 0 ].id, startTimestamp: 1, stopTimestamp: 2 } | ||
229 | }) | ||
230 | await addVideoInPlaylist({ | ||
231 | url: servers[ 1 ].url, | ||
232 | token: servers[ 1 ].accessToken, | ||
233 | playlistId: id, | ||
234 | elementAttrs: { videoId: servers[ 1 ].videos[ 1 ].id } | ||
235 | }) | ||
236 | } | ||
237 | |||
238 | await waitJobs(servers) | ||
239 | |||
240 | for (const server of [ servers[0], servers[1] ]) { | ||
241 | const res = await getVideoPlaylistsList(server.url, 0, 5) | ||
242 | |||
243 | const playlist2 = res.body.data.find(p => p.displayName === 'playlist 2') | ||
244 | expect(playlist2).to.not.be.undefined | ||
245 | await testImage(server.url, 'thumbnail-playlist', playlist2.thumbnailPath) | ||
246 | |||
247 | const playlist3 = res.body.data.find(p => p.displayName === 'playlist 3') | ||
248 | expect(playlist3).to.not.be.undefined | ||
249 | await testImage(server.url, 'thumbnail', playlist3.thumbnailPath) | ||
250 | } | ||
251 | |||
252 | const res = await getVideoPlaylistsList(servers[2].url, 0, 5) | ||
253 | expect(res.body.data.find(p => p.displayName === 'playlist 2')).to.be.undefined | ||
254 | expect(res.body.data.find(p => p.displayName === 'playlist 3')).to.be.undefined | ||
255 | }) | ||
256 | |||
257 | it('Should have the playlist on server 3 after a new follow', async function () { | ||
258 | this.timeout(30000) | ||
259 | |||
260 | // Server 2 and server 3 follow each other | ||
261 | await doubleFollow(servers[1], servers[2]) | ||
262 | |||
263 | const res = await getVideoPlaylistsList(servers[2].url, 0, 5) | ||
264 | |||
265 | const playlist2 = res.body.data.find(p => p.displayName === 'playlist 2') | ||
266 | expect(playlist2).to.not.be.undefined | ||
267 | await testImage(servers[2].url, 'thumbnail-playlist', playlist2.thumbnailPath) | ||
268 | |||
269 | expect(res.body.data.find(p => p.displayName === 'playlist 3')).to.not.be.undefined | ||
270 | }) | ||
271 | |||
272 | it('Should correctly list the playlists', async function () { | ||
273 | this.timeout(30000) | ||
274 | |||
275 | { | ||
276 | const res = await getVideoPlaylistsList(servers[ 2 ].url, 1, 2, 'createdAt') | ||
277 | |||
278 | expect(res.body.total).to.equal(3) | ||
279 | |||
280 | const data: VideoPlaylist[] = res.body.data | ||
281 | expect(data).to.have.lengthOf(2) | ||
282 | expect(data[ 0 ].displayName).to.equal('playlist 2') | ||
283 | expect(data[ 1 ].displayName).to.equal('playlist 3') | ||
284 | } | ||
285 | |||
286 | { | ||
287 | const res = await getVideoPlaylistsList(servers[ 2 ].url, 1, 2, '-createdAt') | ||
288 | |||
289 | expect(res.body.total).to.equal(3) | ||
290 | |||
291 | const data: VideoPlaylist[] = res.body.data | ||
292 | expect(data).to.have.lengthOf(2) | ||
293 | expect(data[ 0 ].displayName).to.equal('playlist 2') | ||
294 | expect(data[ 1 ].displayName).to.equal('my super playlist') | ||
295 | } | ||
296 | }) | ||
297 | |||
298 | it('Should list video channel playlists', async function () { | ||
299 | this.timeout(30000) | ||
300 | |||
301 | { | ||
302 | const res = await getVideoChannelPlaylistsList(servers[ 0 ].url, 'root_channel', 0, 2, '-createdAt') | ||
303 | |||
304 | expect(res.body.total).to.equal(1) | ||
305 | |||
306 | const data: VideoPlaylist[] = res.body.data | ||
307 | expect(data).to.have.lengthOf(1) | ||
308 | expect(data[ 0 ].displayName).to.equal('my super playlist') | ||
309 | } | ||
310 | }) | ||
311 | |||
312 | it('Should list account playlists', async function () { | ||
313 | this.timeout(30000) | ||
314 | |||
315 | { | ||
316 | const res = await getAccountPlaylistsList(servers[ 1 ].url, 'root', 1, 2, '-createdAt') | ||
317 | |||
318 | expect(res.body.total).to.equal(2) | ||
319 | |||
320 | const data: VideoPlaylist[] = res.body.data | ||
321 | expect(data).to.have.lengthOf(1) | ||
322 | expect(data[ 0 ].displayName).to.equal('playlist 2') | ||
323 | } | ||
324 | |||
325 | { | ||
326 | const res = await getAccountPlaylistsList(servers[ 1 ].url, 'root', 1, 2, 'createdAt') | ||
327 | |||
328 | expect(res.body.total).to.equal(2) | ||
329 | |||
330 | const data: VideoPlaylist[] = res.body.data | ||
331 | expect(data).to.have.lengthOf(1) | ||
332 | expect(data[ 0 ].displayName).to.equal('playlist 3') | ||
333 | } | ||
334 | }) | ||
335 | |||
336 | it('Should not list unlisted or private playlists', async function () { | ||
337 | this.timeout(30000) | ||
338 | |||
339 | await createVideoPlaylist({ | ||
340 | url: servers[ 1 ].url, | ||
341 | token: servers[ 1 ].accessToken, | ||
342 | playlistAttrs: { | ||
343 | displayName: 'playlist unlisted', | ||
344 | privacy: VideoPlaylistPrivacy.UNLISTED | ||
345 | } | ||
346 | }) | ||
347 | |||
348 | await createVideoPlaylist({ | ||
349 | url: servers[ 1 ].url, | ||
350 | token: servers[ 1 ].accessToken, | ||
351 | playlistAttrs: { | ||
352 | displayName: 'playlist private', | ||
353 | privacy: VideoPlaylistPrivacy.PRIVATE | ||
354 | } | ||
355 | }) | ||
356 | |||
357 | await waitJobs(servers) | ||
358 | |||
359 | for (const server of servers) { | ||
360 | const results = [ | ||
361 | await getAccountPlaylistsList(server.url, 'root@localhost:9002', 0, 5, '-createdAt'), | ||
362 | await getVideoPlaylistsList(server.url, 0, 2, '-createdAt') | ||
363 | ] | ||
364 | |||
365 | expect(results[0].body.total).to.equal(2) | ||
366 | expect(results[1].body.total).to.equal(3) | ||
367 | |||
368 | for (const res of results) { | ||
369 | const data: VideoPlaylist[] = res.body.data | ||
370 | expect(data).to.have.lengthOf(2) | ||
371 | expect(data[ 0 ].displayName).to.equal('playlist 3') | ||
372 | expect(data[ 1 ].displayName).to.equal('playlist 2') | ||
373 | } | ||
374 | } | ||
375 | }) | ||
376 | |||
377 | it('Should update a playlist', async function () { | ||
378 | this.timeout(30000) | ||
379 | |||
380 | await updateVideoPlaylist({ | ||
381 | url: servers[1].url, | ||
382 | token: servers[1].accessToken, | ||
383 | playlistAttrs: { | ||
384 | displayName: 'playlist 3 updated', | ||
385 | description: 'description updated', | ||
386 | privacy: VideoPlaylistPrivacy.UNLISTED, | ||
387 | thumbnailfile: 'thumbnail.jpg', | ||
388 | videoChannelId: servers[1].videoChannel.id | ||
389 | }, | ||
390 | playlistId: playlistServer2Id2 | ||
391 | }) | ||
392 | |||
393 | await waitJobs(servers) | ||
394 | |||
395 | for (const server of servers) { | ||
396 | const res = await getVideoPlaylist(server.url, playlistServer2UUID2) | ||
397 | const playlist: VideoPlaylist = res.body | ||
398 | |||
399 | expect(playlist.displayName).to.equal('playlist 3 updated') | ||
400 | expect(playlist.description).to.equal('description updated') | ||
401 | |||
402 | expect(playlist.privacy.id).to.equal(VideoPlaylistPrivacy.UNLISTED) | ||
403 | expect(playlist.privacy.label).to.equal('Unlisted') | ||
404 | |||
405 | expect(playlist.type.id).to.equal(VideoPlaylistType.REGULAR) | ||
406 | expect(playlist.type.label).to.equal('Regular') | ||
407 | |||
408 | expect(playlist.videosLength).to.equal(2) | ||
409 | |||
410 | expect(playlist.ownerAccount.name).to.equal('root') | ||
411 | expect(playlist.ownerAccount.displayName).to.equal('root') | ||
412 | expect(playlist.videoChannel.name).to.equal('root_channel') | ||
413 | expect(playlist.videoChannel.displayName).to.equal('Main root channel') | ||
414 | } | ||
415 | }) | ||
416 | |||
417 | it('Should create a playlist containing different startTimestamp/endTimestamp videos', async function () { | ||
418 | this.timeout(30000) | ||
419 | |||
420 | const addVideo = (elementAttrs: any) => { | ||
421 | return addVideoInPlaylist({ url: servers[0].url, token: servers[0].accessToken, playlistId: playlistServer1Id, elementAttrs }) | ||
422 | } | ||
423 | |||
424 | const res = await createVideoPlaylist({ | ||
425 | url: servers[ 0 ].url, | ||
426 | token: servers[ 0 ].accessToken, | ||
427 | playlistAttrs: { | ||
428 | displayName: 'playlist 4', | ||
429 | privacy: VideoPlaylistPrivacy.PUBLIC, | ||
430 | videoChannelId: servers[0].videoChannel.id | ||
431 | } | ||
432 | }) | ||
433 | |||
434 | playlistServer1Id = res.body.videoPlaylist.id | ||
435 | playlistServer1UUID = res.body.videoPlaylist.uuid | ||
436 | |||
437 | await addVideo({ videoId: servers[0].videos[0].uuid, startTimestamp: 15, stopTimestamp: 28 }) | ||
438 | await addVideo({ videoId: servers[2].videos[1].uuid, startTimestamp: 35 }) | ||
439 | await addVideo({ videoId: servers[2].videos[2].uuid }) | ||
440 | await addVideo({ videoId: servers[0].videos[3].uuid, stopTimestamp: 35 }) | ||
441 | await addVideo({ videoId: servers[0].videos[4].uuid, startTimestamp: 45, stopTimestamp: 60 }) | ||
442 | await addVideo({ videoId: nsfwVideoServer1, startTimestamp: 5 }) | ||
443 | |||
444 | await waitJobs(servers) | ||
445 | }) | ||
446 | |||
447 | it('Should correctly list playlist videos', async function () { | ||
448 | this.timeout(30000) | ||
449 | |||
450 | for (const server of servers) { | ||
451 | const res = await getPlaylistVideos(server.url, server.accessToken, playlistServer1UUID, 0, 10) | ||
452 | |||
453 | expect(res.body.total).to.equal(6) | ||
454 | |||
455 | const videos: Video[] = res.body.data | ||
456 | expect(videos).to.have.lengthOf(6) | ||
457 | |||
458 | expect(videos[0].name).to.equal('video 0 server 1') | ||
459 | expect(videos[0].playlistElement.position).to.equal(1) | ||
460 | expect(videos[0].playlistElement.startTimestamp).to.equal(15) | ||
461 | expect(videos[0].playlistElement.stopTimestamp).to.equal(28) | ||
462 | |||
463 | expect(videos[1].name).to.equal('video 1 server 3') | ||
464 | expect(videos[1].playlistElement.position).to.equal(2) | ||
465 | expect(videos[1].playlistElement.startTimestamp).to.equal(35) | ||
466 | expect(videos[1].playlistElement.stopTimestamp).to.be.null | ||
467 | |||
468 | expect(videos[2].name).to.equal('video 2 server 3') | ||
469 | expect(videos[2].playlistElement.position).to.equal(3) | ||
470 | expect(videos[2].playlistElement.startTimestamp).to.be.null | ||
471 | expect(videos[2].playlistElement.stopTimestamp).to.be.null | ||
472 | |||
473 | expect(videos[3].name).to.equal('video 3 server 1') | ||
474 | expect(videos[3].playlistElement.position).to.equal(4) | ||
475 | expect(videos[3].playlistElement.startTimestamp).to.be.null | ||
476 | expect(videos[3].playlistElement.stopTimestamp).to.equal(35) | ||
477 | |||
478 | expect(videos[4].name).to.equal('video 4 server 1') | ||
479 | expect(videos[4].playlistElement.position).to.equal(5) | ||
480 | expect(videos[4].playlistElement.startTimestamp).to.equal(45) | ||
481 | expect(videos[4].playlistElement.stopTimestamp).to.equal(60) | ||
482 | |||
483 | expect(videos[5].name).to.equal('NSFW video') | ||
484 | expect(videos[5].playlistElement.position).to.equal(6) | ||
485 | expect(videos[5].playlistElement.startTimestamp).to.equal(5) | ||
486 | expect(videos[5].playlistElement.stopTimestamp).to.be.null | ||
487 | |||
488 | const res2 = await getPlaylistVideos(server.url, server.accessToken, playlistServer1UUID, 0, 10, { nsfw: false }) | ||
489 | expect(res2.body.total).to.equal(5) | ||
490 | expect(res2.body.data.find(v => v.name === 'NSFW video')).to.be.undefined | ||
491 | |||
492 | const res3 = await getPlaylistVideos(server.url, server.accessToken, playlistServer1UUID, 0, 2) | ||
493 | expect(res3.body.data).to.have.lengthOf(2) | ||
494 | } | ||
495 | }) | ||
496 | |||
497 | it('Should reorder the playlist', async function () { | ||
498 | this.timeout(30000) | ||
499 | |||
500 | { | ||
501 | await reorderVideosPlaylist({ | ||
502 | url: servers[ 0 ].url, | ||
503 | token: servers[ 0 ].accessToken, | ||
504 | playlistId: playlistServer1Id, | ||
505 | elementAttrs: { | ||
506 | startPosition: 2, | ||
507 | insertAfterPosition: 3 | ||
508 | } | ||
509 | }) | ||
510 | |||
511 | await waitJobs(servers) | ||
512 | |||
513 | for (const server of servers) { | ||
514 | const res = await getPlaylistVideos(server.url, server.accessToken, playlistServer1UUID, 0, 10) | ||
515 | const names = res.body.data.map(v => v.name) | ||
516 | |||
517 | expect(names).to.deep.equal([ | ||
518 | 'video 0 server 1', | ||
519 | 'video 2 server 3', | ||
520 | 'video 1 server 3', | ||
521 | 'video 3 server 1', | ||
522 | 'video 4 server 1', | ||
523 | 'NSFW video' | ||
524 | ]) | ||
525 | } | ||
526 | } | ||
527 | |||
528 | { | ||
529 | await reorderVideosPlaylist({ | ||
530 | url: servers[0].url, | ||
531 | token: servers[0].accessToken, | ||
532 | playlistId: playlistServer1Id, | ||
533 | elementAttrs: { | ||
534 | startPosition: 1, | ||
535 | reorderLength: 3, | ||
536 | insertAfterPosition: 4 | ||
537 | } | ||
538 | }) | ||
539 | |||
540 | await waitJobs(servers) | ||
541 | |||
542 | for (const server of servers) { | ||
543 | const res = await getPlaylistVideos(server.url, server.accessToken, playlistServer1UUID, 0, 10) | ||
544 | const names = res.body.data.map(v => v.name) | ||
545 | |||
546 | expect(names).to.deep.equal([ | ||
547 | 'video 3 server 1', | ||
548 | 'video 0 server 1', | ||
549 | 'video 2 server 3', | ||
550 | 'video 1 server 3', | ||
551 | 'video 4 server 1', | ||
552 | 'NSFW video' | ||
553 | ]) | ||
554 | } | ||
555 | } | ||
556 | |||
557 | { | ||
558 | await reorderVideosPlaylist({ | ||
559 | url: servers[0].url, | ||
560 | token: servers[0].accessToken, | ||
561 | playlistId: playlistServer1Id, | ||
562 | elementAttrs: { | ||
563 | startPosition: 6, | ||
564 | insertAfterPosition: 3 | ||
565 | } | ||
566 | }) | ||
567 | |||
568 | await waitJobs(servers) | ||
569 | |||
570 | for (const server of servers) { | ||
571 | const res = await getPlaylistVideos(server.url, server.accessToken, playlistServer1UUID, 0, 10) | ||
572 | const videos: Video[] = res.body.data | ||
573 | |||
574 | const names = videos.map(v => v.name) | ||
575 | |||
576 | expect(names).to.deep.equal([ | ||
577 | 'video 3 server 1', | ||
578 | 'video 0 server 1', | ||
579 | 'video 2 server 3', | ||
580 | 'NSFW video', | ||
581 | 'video 1 server 3', | ||
582 | 'video 4 server 1' | ||
583 | ]) | ||
584 | |||
585 | for (let i = 1; i <= videos.length; i++) { | ||
586 | expect(videos[i - 1].playlistElement.position).to.equal(i) | ||
587 | } | ||
588 | } | ||
589 | } | ||
590 | }) | ||
591 | |||
592 | it('Should update startTimestamp/endTimestamp of some elements', async function () { | ||
593 | this.timeout(30000) | ||
594 | |||
595 | await updateVideoPlaylistElement({ | ||
596 | url: servers[0].url, | ||
597 | token: servers[0].accessToken, | ||
598 | playlistId: playlistServer1Id, | ||
599 | videoId: servers[0].videos[3].uuid, | ||
600 | elementAttrs: { | ||
601 | startTimestamp: 1 | ||
602 | } | ||
603 | }) | ||
604 | |||
605 | await updateVideoPlaylistElement({ | ||
606 | url: servers[0].url, | ||
607 | token: servers[0].accessToken, | ||
608 | playlistId: playlistServer1Id, | ||
609 | videoId: servers[0].videos[4].uuid, | ||
610 | elementAttrs: { | ||
611 | stopTimestamp: null | ||
612 | } | ||
613 | }) | ||
614 | |||
615 | await waitJobs(servers) | ||
616 | |||
617 | for (const server of servers) { | ||
618 | const res = await getPlaylistVideos(server.url, server.accessToken, playlistServer1UUID, 0, 10) | ||
619 | const videos: Video[] = res.body.data | ||
620 | |||
621 | expect(videos[0].name).to.equal('video 3 server 1') | ||
622 | expect(videos[0].playlistElement.position).to.equal(1) | ||
623 | expect(videos[0].playlistElement.startTimestamp).to.equal(1) | ||
624 | expect(videos[0].playlistElement.stopTimestamp).to.equal(35) | ||
625 | |||
626 | expect(videos[5].name).to.equal('video 4 server 1') | ||
627 | expect(videos[5].playlistElement.position).to.equal(6) | ||
628 | expect(videos[5].playlistElement.startTimestamp).to.equal(45) | ||
629 | expect(videos[5].playlistElement.stopTimestamp).to.be.null | ||
630 | } | ||
631 | }) | ||
632 | |||
633 | it('Should check videos existence in my playlist', async function () { | ||
634 | const videoIds = [ | ||
635 | servers[0].videos[0].id, | ||
636 | 42000, | ||
637 | servers[0].videos[3].id, | ||
638 | 43000, | ||
639 | servers[0].videos[4].id | ||
640 | ] | ||
641 | const res = await doVideosExistInMyPlaylist(servers[ 0 ].url, servers[ 0 ].accessToken, videoIds) | ||
642 | const obj = res.body as VideoExistInPlaylist | ||
643 | |||
644 | { | ||
645 | const elem = obj[servers[0].videos[0].id] | ||
646 | expect(elem).to.have.lengthOf(1) | ||
647 | expect(elem[ 0 ].playlistId).to.equal(playlistServer1Id) | ||
648 | expect(elem[ 0 ].startTimestamp).to.equal(15) | ||
649 | expect(elem[ 0 ].stopTimestamp).to.equal(28) | ||
650 | } | ||
651 | |||
652 | { | ||
653 | const elem = obj[servers[0].videos[3].id] | ||
654 | expect(elem).to.have.lengthOf(1) | ||
655 | expect(elem[ 0 ].playlistId).to.equal(playlistServer1Id) | ||
656 | expect(elem[ 0 ].startTimestamp).to.equal(1) | ||
657 | expect(elem[ 0 ].stopTimestamp).to.equal(35) | ||
658 | } | ||
659 | |||
660 | { | ||
661 | const elem = obj[servers[0].videos[4].id] | ||
662 | expect(elem).to.have.lengthOf(1) | ||
663 | expect(elem[ 0 ].playlistId).to.equal(playlistServer1Id) | ||
664 | expect(elem[ 0 ].startTimestamp).to.equal(45) | ||
665 | expect(elem[ 0 ].stopTimestamp).to.equal(null) | ||
666 | } | ||
667 | |||
668 | expect(obj[42000]).to.have.lengthOf(0) | ||
669 | expect(obj[43000]).to.have.lengthOf(0) | ||
670 | }) | ||
671 | |||
672 | it('Should automatically update updatedAt field of playlists', async function () { | ||
673 | const server = servers[1] | ||
674 | const videoId = servers[1].videos[5].id | ||
675 | |||
676 | async function getPlaylistNames () { | ||
677 | const res = await getAccountPlaylistsListWithToken(server.url, server.accessToken, 'root', 0, 5, undefined, '-updatedAt') | ||
678 | |||
679 | return (res.body.data as VideoPlaylist[]).map(p => p.displayName) | ||
680 | } | ||
681 | |||
682 | const elementAttrs = { videoId } | ||
683 | await addVideoInPlaylist({ url: server.url, token: server.accessToken, playlistId: playlistServer2Id1, elementAttrs }) | ||
684 | await addVideoInPlaylist({ url: server.url, token: server.accessToken, playlistId: playlistServer2Id2, elementAttrs }) | ||
685 | |||
686 | const names1 = await getPlaylistNames() | ||
687 | expect(names1[0]).to.equal('playlist 3 updated') | ||
688 | expect(names1[1]).to.equal('playlist 2') | ||
689 | |||
690 | await removeVideoFromPlaylist({ url: server.url, token: server.accessToken, playlistId: playlistServer2Id1, videoId }) | ||
691 | |||
692 | const names2 = await getPlaylistNames() | ||
693 | expect(names2[0]).to.equal('playlist 2') | ||
694 | expect(names2[1]).to.equal('playlist 3 updated') | ||
695 | |||
696 | await removeVideoFromPlaylist({ url: server.url, token: server.accessToken, playlistId: playlistServer2Id2, videoId }) | ||
697 | |||
698 | const names3 = await getPlaylistNames() | ||
699 | expect(names3[0]).to.equal('playlist 3 updated') | ||
700 | expect(names3[1]).to.equal('playlist 2') | ||
701 | }) | ||
702 | |||
703 | it('Should delete some elements', async function () { | ||
704 | this.timeout(30000) | ||
705 | |||
706 | await removeVideoFromPlaylist({ | ||
707 | url: servers[0].url, | ||
708 | token: servers[0].accessToken, | ||
709 | playlistId: playlistServer1Id, | ||
710 | videoId: servers[0].videos[3].uuid | ||
711 | }) | ||
712 | |||
713 | await removeVideoFromPlaylist({ | ||
714 | url: servers[0].url, | ||
715 | token: servers[0].accessToken, | ||
716 | playlistId: playlistServer1Id, | ||
717 | videoId: nsfwVideoServer1 | ||
718 | }) | ||
719 | |||
720 | await waitJobs(servers) | ||
721 | |||
722 | for (const server of servers) { | ||
723 | const res = await getPlaylistVideos(server.url, server.accessToken, playlistServer1UUID, 0, 10) | ||
724 | |||
725 | expect(res.body.total).to.equal(4) | ||
726 | |||
727 | const videos: Video[] = res.body.data | ||
728 | expect(videos).to.have.lengthOf(4) | ||
729 | |||
730 | expect(videos[ 0 ].name).to.equal('video 0 server 1') | ||
731 | expect(videos[ 0 ].playlistElement.position).to.equal(1) | ||
732 | |||
733 | expect(videos[ 1 ].name).to.equal('video 2 server 3') | ||
734 | expect(videos[ 1 ].playlistElement.position).to.equal(2) | ||
735 | |||
736 | expect(videos[ 2 ].name).to.equal('video 1 server 3') | ||
737 | expect(videos[ 2 ].playlistElement.position).to.equal(3) | ||
738 | |||
739 | expect(videos[ 3 ].name).to.equal('video 4 server 1') | ||
740 | expect(videos[ 3 ].playlistElement.position).to.equal(4) | ||
741 | } | ||
742 | }) | ||
743 | |||
744 | it('Should delete the playlist on server 1 and delete on server 2 and 3', async function () { | ||
745 | this.timeout(30000) | ||
746 | |||
747 | await deleteVideoPlaylist(servers[0].url, servers[0].accessToken, playlistServer1Id) | ||
748 | |||
749 | await waitJobs(servers) | ||
750 | |||
751 | for (const server of servers) { | ||
752 | await getVideoPlaylist(server.url, playlistServer1UUID, 404) | ||
753 | } | ||
754 | }) | ||
755 | |||
756 | it('Should have deleted the thumbnail on server 1, 2 and 3', async function () { | ||
757 | this.timeout(30000) | ||
758 | |||
759 | for (const server of servers) { | ||
760 | await checkPlaylistFilesWereRemoved(playlistServer1UUID, server.serverNumber) | ||
761 | } | ||
762 | }) | ||
763 | |||
764 | it('Should unfollow servers 1 and 2 and hide their playlists', async function () { | ||
765 | this.timeout(30000) | ||
766 | |||
767 | const finder = data => data.find(p => p.displayName === 'my super playlist') | ||
768 | |||
769 | { | ||
770 | const res = await getVideoPlaylistsList(servers[ 2 ].url, 0, 5) | ||
771 | expect(res.body.total).to.equal(2) | ||
772 | expect(finder(res.body.data)).to.not.be.undefined | ||
773 | } | ||
774 | |||
775 | await unfollow(servers[2].url, servers[2].accessToken, servers[0]) | ||
776 | |||
777 | { | ||
778 | const res = await getVideoPlaylistsList(servers[ 2 ].url, 0, 5) | ||
779 | expect(res.body.total).to.equal(1) | ||
780 | |||
781 | expect(finder(res.body.data)).to.be.undefined | ||
782 | } | ||
783 | }) | ||
784 | |||
785 | it('Should delete a channel and put the associated playlist in private mode', async function () { | ||
786 | this.timeout(30000) | ||
787 | |||
788 | const res = await addVideoChannel(servers[0].url, servers[0].accessToken, { name: 'super_channel', displayName: 'super channel' }) | ||
789 | const videoChannelId = res.body.videoChannel.id | ||
790 | |||
791 | const res2 = await createVideoPlaylist({ | ||
792 | url: servers[0].url, | ||
793 | token: servers[0].accessToken, | ||
794 | playlistAttrs: { | ||
795 | displayName: 'channel playlist', | ||
796 | privacy: VideoPlaylistPrivacy.PUBLIC, | ||
797 | videoChannelId | ||
798 | } | ||
799 | }) | ||
800 | const videoPlaylistUUID = res2.body.videoPlaylist.uuid | ||
801 | |||
802 | await waitJobs(servers) | ||
803 | |||
804 | await deleteVideoChannel(servers[0].url, servers[0].accessToken, 'super_channel') | ||
805 | |||
806 | await waitJobs(servers) | ||
807 | |||
808 | const res3 = await getVideoPlaylistWithToken(servers[0].url, servers[0].accessToken, videoPlaylistUUID) | ||
809 | expect(res3.body.displayName).to.equal('channel playlist') | ||
810 | expect(res3.body.privacy.id).to.equal(VideoPlaylistPrivacy.PRIVATE) | ||
811 | |||
812 | await getVideoPlaylist(servers[1].url, videoPlaylistUUID, 404) | ||
813 | }) | ||
814 | |||
815 | it('Should delete an account and delete its playlists', async function () { | ||
816 | this.timeout(30000) | ||
817 | |||
818 | const user = { username: 'user_1', password: 'password' } | ||
819 | const res = await createUser({ | ||
820 | url: servers[ 0 ].url, | ||
821 | accessToken: servers[ 0 ].accessToken, | ||
822 | username: user.username, | ||
823 | password: user.password | ||
824 | }) | ||
825 | |||
826 | const userId = res.body.user.id | ||
827 | const userAccessToken = await userLogin(servers[0], user) | ||
828 | |||
829 | const resChannel = await getMyUserInformation(servers[0].url, userAccessToken) | ||
830 | const userChannel = (resChannel.body as User).videoChannels[0] | ||
831 | |||
832 | await createVideoPlaylist({ | ||
833 | url: servers[0].url, | ||
834 | token: userAccessToken, | ||
835 | playlistAttrs: { | ||
836 | displayName: 'playlist to be deleted', | ||
837 | privacy: VideoPlaylistPrivacy.PUBLIC, | ||
838 | videoChannelId: userChannel.id | ||
839 | } | ||
840 | }) | ||
841 | |||
842 | await waitJobs(servers) | ||
843 | |||
844 | const finder = data => data.find(p => p.displayName === 'playlist to be deleted') | ||
845 | |||
846 | { | ||
847 | for (const server of [ servers[0], servers[1] ]) { | ||
848 | const res = await getVideoPlaylistsList(server.url, 0, 15) | ||
849 | expect(finder(res.body.data)).to.not.be.undefined | ||
850 | } | ||
851 | } | ||
852 | |||
853 | await removeUser(servers[0].url, userId, servers[0].accessToken) | ||
854 | await waitJobs(servers) | ||
855 | |||
856 | { | ||
857 | for (const server of [ servers[0], servers[1] ]) { | ||
858 | const res = await getVideoPlaylistsList(server.url, 0, 15) | ||
859 | expect(finder(res.body.data)).to.be.undefined | ||
860 | } | ||
861 | } | ||
862 | }) | ||
863 | |||
864 | after(async function () { | ||
865 | await cleanupTests(servers) | ||
866 | }) | ||
867 | }) | ||
diff --git a/server/tests/api/videos/video-privacy.ts b/server/tests/api/videos/video-privacy.ts index 0b4e66369..ef1cf0f07 100644 --- a/server/tests/api/videos/video-privacy.ts +++ b/server/tests/api/videos/video-privacy.ts | |||
@@ -4,18 +4,19 @@ import * as chai from 'chai' | |||
4 | import 'mocha' | 4 | import 'mocha' |
5 | import { VideoPrivacy } from '../../../../shared/models/videos/video-privacy.enum' | 5 | import { VideoPrivacy } from '../../../../shared/models/videos/video-privacy.enum' |
6 | import { | 6 | import { |
7 | cleanupTests, | ||
7 | flushAndRunMultipleServers, | 8 | flushAndRunMultipleServers, |
8 | getVideosList, | 9 | getVideosList, |
9 | killallServers, | 10 | killallServers, |
10 | ServerInfo, | 11 | ServerInfo, |
11 | setAccessTokensToServers, | 12 | setAccessTokensToServers, |
12 | uploadVideo | 13 | uploadVideo |
13 | } from '../../../../shared/utils/index' | 14 | } from '../../../../shared/extra-utils/index' |
14 | import { doubleFollow } from '../../../../shared/utils/server/follows' | 15 | import { doubleFollow } from '../../../../shared/extra-utils/server/follows' |
15 | import { userLogin } from '../../../../shared/utils/users/login' | 16 | import { userLogin } from '../../../../shared/extra-utils/users/login' |
16 | import { createUser } from '../../../../shared/utils/users/users' | 17 | import { createUser } from '../../../../shared/extra-utils/users/users' |
17 | import { getMyVideos, getVideo, getVideoWithToken, updateVideo } from '../../../../shared/utils/videos/videos' | 18 | import { getMyVideos, getVideo, getVideoWithToken, updateVideo } from '../../../../shared/extra-utils/videos/videos' |
18 | import { waitJobs } from '../../../../shared/utils/server/jobs' | 19 | import { waitJobs } from '../../../../shared/extra-utils/server/jobs' |
19 | 20 | ||
20 | const expect = chai.expect | 21 | const expect = chai.expect |
21 | 22 | ||
@@ -78,7 +79,7 @@ describe('Test video privacy', function () { | |||
78 | username: 'hello', | 79 | username: 'hello', |
79 | password: 'super password' | 80 | password: 'super password' |
80 | } | 81 | } |
81 | await createUser(servers[0].url, servers[0].accessToken, user.username, user.password) | 82 | await createUser({ url: servers[ 0 ].url, accessToken: servers[ 0 ].accessToken, username: user.username, password: user.password }) |
82 | 83 | ||
83 | const token = await userLogin(servers[0], user) | 84 | const token = await userLogin(servers[0], user) |
84 | await getVideoWithToken(servers[0].url, token, privateVideoUUID, 403) | 85 | await getVideoWithToken(servers[0].url, token, privateVideoUUID, 403) |
@@ -153,6 +154,6 @@ describe('Test video privacy', function () { | |||
153 | }) | 154 | }) |
154 | 155 | ||
155 | after(async function () { | 156 | after(async function () { |
156 | killallServers(servers) | 157 | await cleanupTests(servers) |
157 | }) | 158 | }) |
158 | }) | 159 | }) |
diff --git a/server/tests/api/videos/video-schedule-update.ts b/server/tests/api/videos/video-schedule-update.ts index 632c4244c..64f657780 100644 --- a/server/tests/api/videos/video-schedule-update.ts +++ b/server/tests/api/videos/video-schedule-update.ts | |||
@@ -4,6 +4,7 @@ import * as chai from 'chai' | |||
4 | import 'mocha' | 4 | import 'mocha' |
5 | import { VideoPrivacy } from '../../../../shared/models/videos' | 5 | import { VideoPrivacy } from '../../../../shared/models/videos' |
6 | import { | 6 | import { |
7 | cleanupTests, | ||
7 | doubleFollow, | 8 | doubleFollow, |
8 | flushAndRunMultipleServers, | 9 | flushAndRunMultipleServers, |
9 | getMyVideos, | 10 | getMyVideos, |
@@ -15,8 +16,8 @@ import { | |||
15 | updateVideo, | 16 | updateVideo, |
16 | uploadVideo, | 17 | uploadVideo, |
17 | wait | 18 | wait |
18 | } from '../../../../shared/utils' | 19 | } from '../../../../shared/extra-utils' |
19 | import { waitJobs } from '../../../../shared/utils/server/jobs' | 20 | import { waitJobs } from '../../../../shared/extra-utils/server/jobs' |
20 | 21 | ||
21 | const expect = chai.expect | 22 | const expect = chai.expect |
22 | 23 | ||
@@ -166,6 +167,6 @@ describe('Test video update scheduler', function () { | |||
166 | }) | 167 | }) |
167 | 168 | ||
168 | after(async function () { | 169 | after(async function () { |
169 | killallServers(servers) | 170 | await cleanupTests(servers) |
170 | }) | 171 | }) |
171 | }) | 172 | }) |
diff --git a/server/tests/api/videos/video-transcoder.ts b/server/tests/api/videos/video-transcoder.ts index eefd32ef8..3cd43e99b 100644 --- a/server/tests/api/videos/video-transcoder.ts +++ b/server/tests/api/videos/video-transcoder.ts | |||
@@ -6,7 +6,7 @@ import { omit } from 'lodash' | |||
6 | import { getMaxBitrate, VideoDetails, VideoResolution, VideoState } from '../../../../shared/models/videos' | 6 | import { getMaxBitrate, VideoDetails, VideoResolution, VideoState } from '../../../../shared/models/videos' |
7 | import { audio, getVideoFileBitrate, getVideoFileFPS, getVideoFileResolution } from '../../../helpers/ffmpeg-utils' | 7 | import { audio, getVideoFileBitrate, getVideoFileFPS, getVideoFileResolution } from '../../../helpers/ffmpeg-utils' |
8 | import { | 8 | import { |
9 | buildAbsoluteFixturePath, | 9 | buildAbsoluteFixturePath, cleanupTests, |
10 | doubleFollow, | 10 | doubleFollow, |
11 | flushAndRunMultipleServers, | 11 | flushAndRunMultipleServers, |
12 | generateHighBitrateVideo, | 12 | generateHighBitrateVideo, |
@@ -19,9 +19,9 @@ import { | |||
19 | setAccessTokensToServers, | 19 | setAccessTokensToServers, |
20 | uploadVideo, | 20 | uploadVideo, |
21 | webtorrentAdd | 21 | webtorrentAdd |
22 | } from '../../../../shared/utils' | 22 | } from '../../../../shared/extra-utils' |
23 | import { extname, join } from 'path' | 23 | import { extname, join } from 'path' |
24 | import { waitJobs } from '../../../../shared/utils/server/jobs' | 24 | import { waitJobs } from '../../../../shared/extra-utils/server/jobs' |
25 | import { VIDEO_TRANSCODING_FPS } from '../../../../server/initializers/constants' | 25 | import { VIDEO_TRANSCODING_FPS } from '../../../../server/initializers/constants' |
26 | 26 | ||
27 | const expect = chai.expect | 27 | const expect = chai.expect |
@@ -350,6 +350,6 @@ describe('Test video transcoding', function () { | |||
350 | }) | 350 | }) |
351 | 351 | ||
352 | after(async function () { | 352 | after(async function () { |
353 | killallServers(servers) | 353 | await cleanupTests(servers) |
354 | }) | 354 | }) |
355 | }) | 355 | }) |
diff --git a/server/tests/api/videos/videos-filter.ts b/server/tests/api/videos/videos-filter.ts index 59e37ad86..e1e65260f 100644 --- a/server/tests/api/videos/videos-filter.ts +++ b/server/tests/api/videos/videos-filter.ts | |||
@@ -3,6 +3,7 @@ | |||
3 | import * as chai from 'chai' | 3 | import * as chai from 'chai' |
4 | import 'mocha' | 4 | import 'mocha' |
5 | import { | 5 | import { |
6 | cleanupTests, | ||
6 | createUser, | 7 | createUser, |
7 | doubleFollow, | 8 | doubleFollow, |
8 | flushAndRunMultipleServers, | 9 | flushAndRunMultipleServers, |
@@ -13,7 +14,7 @@ import { | |||
13 | setAccessTokensToServers, | 14 | setAccessTokensToServers, |
14 | uploadVideo, | 15 | uploadVideo, |
15 | userLogin | 16 | userLogin |
16 | } from '../../../../shared/utils' | 17 | } from '../../../../shared/extra-utils' |
17 | import { Video, VideoPrivacy } from '../../../../shared/models/videos' | 18 | import { Video, VideoPrivacy } from '../../../../shared/models/videos' |
18 | import { UserRole } from '../../../../shared/models/users' | 19 | import { UserRole } from '../../../../shared/models/users' |
19 | 20 | ||
@@ -55,8 +56,6 @@ describe('Test videos filter validator', function () { | |||
55 | before(async function () { | 56 | before(async function () { |
56 | this.timeout(120000) | 57 | this.timeout(120000) |
57 | 58 | ||
58 | await flushTests() | ||
59 | |||
60 | servers = await flushAndRunMultipleServers(2) | 59 | servers = await flushAndRunMultipleServers(2) |
61 | 60 | ||
62 | await setAccessTokensToServers(servers) | 61 | await setAccessTokensToServers(servers) |
@@ -64,13 +63,15 @@ describe('Test videos filter validator', function () { | |||
64 | for (const server of servers) { | 63 | for (const server of servers) { |
65 | const moderator = { username: 'moderator', password: 'my super password' } | 64 | const moderator = { username: 'moderator', password: 'my super password' } |
66 | await createUser( | 65 | await createUser( |
67 | server.url, | 66 | { |
68 | server.accessToken, | 67 | url: server.url, |
69 | moderator.username, | 68 | accessToken: server.accessToken, |
70 | moderator.password, | 69 | username: moderator.username, |
71 | undefined, | 70 | password: moderator.password, |
72 | undefined, | 71 | videoQuota: undefined, |
73 | UserRole.MODERATOR | 72 | videoQuotaDaily: undefined, |
73 | role: UserRole.MODERATOR | ||
74 | } | ||
74 | ) | 75 | ) |
75 | server['moderatorAccessToken'] = await userLogin(server, moderator) | 76 | server['moderatorAccessToken'] = await userLogin(server, moderator) |
76 | 77 | ||
@@ -120,11 +121,6 @@ describe('Test videos filter validator', function () { | |||
120 | }) | 121 | }) |
121 | 122 | ||
122 | after(async function () { | 123 | after(async function () { |
123 | killallServers(servers) | 124 | await cleanupTests(servers) |
124 | |||
125 | // Keep the logs if the test failed | ||
126 | if (this['ok']) { | ||
127 | await flushTests() | ||
128 | } | ||
129 | }) | 125 | }) |
130 | }) | 126 | }) |
diff --git a/server/tests/api/videos/videos-history.ts b/server/tests/api/videos/videos-history.ts index f654a422b..c7e55c1ab 100644 --- a/server/tests/api/videos/videos-history.ts +++ b/server/tests/api/videos/videos-history.ts | |||
@@ -3,21 +3,23 @@ | |||
3 | import * as chai from 'chai' | 3 | import * as chai from 'chai' |
4 | import 'mocha' | 4 | import 'mocha' |
5 | import { | 5 | import { |
6 | cleanupTests, | ||
6 | createUser, | 7 | createUser, |
7 | flushTests, | 8 | flushAndRunServer, |
8 | getVideosListWithToken, | 9 | getVideosListWithToken, |
9 | getVideoWithToken, | 10 | getVideoWithToken, |
10 | killallServers, | 11 | killallServers, |
11 | runServer, | 12 | reRunServer, |
12 | searchVideoWithToken, | 13 | searchVideoWithToken, |
13 | ServerInfo, | 14 | ServerInfo, |
14 | setAccessTokensToServers, | 15 | setAccessTokensToServers, |
15 | updateMyUser, | 16 | updateMyUser, |
16 | uploadVideo, | 17 | uploadVideo, |
17 | userLogin | 18 | userLogin, |
18 | } from '../../../../shared/utils' | 19 | wait |
20 | } from '../../../../shared/extra-utils' | ||
19 | import { Video, VideoDetails } from '../../../../shared/models/videos' | 21 | import { Video, VideoDetails } from '../../../../shared/models/videos' |
20 | import { listMyVideosHistory, removeMyVideosHistory, userWatchVideo } from '../../../../shared/utils/videos/video-history' | 22 | import { listMyVideosHistory, removeMyVideosHistory, userWatchVideo } from '../../../../shared/extra-utils/videos/video-history' |
21 | 23 | ||
22 | const expect = chai.expect | 24 | const expect = chai.expect |
23 | 25 | ||
@@ -32,9 +34,7 @@ describe('Test videos history', function () { | |||
32 | before(async function () { | 34 | before(async function () { |
33 | this.timeout(30000) | 35 | this.timeout(30000) |
34 | 36 | ||
35 | await flushTests() | 37 | server = await flushAndRunServer(1) |
36 | |||
37 | server = await runServer(1) | ||
38 | 38 | ||
39 | await setAccessTokensToServers([ server ]) | 39 | await setAccessTokensToServers([ server ]) |
40 | 40 | ||
@@ -57,7 +57,7 @@ describe('Test videos history', function () { | |||
57 | username: 'user_1', | 57 | username: 'user_1', |
58 | password: 'super password' | 58 | password: 'super password' |
59 | } | 59 | } |
60 | await createUser(server.url, server.accessToken, user.username, user.password) | 60 | await createUser({ url: server.url, accessToken: server.accessToken, username: user.username, password: user.password }) |
61 | userAccessToken = await userLogin(server, user) | 61 | userAccessToken = await userLogin(server, user) |
62 | }) | 62 | }) |
63 | 63 | ||
@@ -192,12 +192,36 @@ describe('Test videos history', function () { | |||
192 | expect(videos[1].name).to.equal('video 3') | 192 | expect(videos[1].name).to.equal('video 3') |
193 | }) | 193 | }) |
194 | 194 | ||
195 | after(async function () { | 195 | it('Should not clean old history', async function () { |
196 | this.timeout(50000) | ||
197 | |||
196 | killallServers([ server ]) | 198 | killallServers([ server ]) |
197 | 199 | ||
198 | // Keep the logs if the test failed | 200 | await reRunServer(server, { history: { videos: { max_age: '10 days' } } }) |
199 | if (this['ok']) { | 201 | |
200 | await flushTests() | 202 | await wait(6000) |
201 | } | 203 | |
204 | // Should still have history | ||
205 | |||
206 | const res = await listMyVideosHistory(server.url, server.accessToken) | ||
207 | |||
208 | expect(res.body.total).to.equal(2) | ||
209 | }) | ||
210 | |||
211 | it('Should clean old history', async function () { | ||
212 | this.timeout(50000) | ||
213 | |||
214 | killallServers([ server ]) | ||
215 | |||
216 | await reRunServer(server, { history: { videos: { max_age: '5 seconds' } } }) | ||
217 | |||
218 | await wait(6000) | ||
219 | |||
220 | const res = await listMyVideosHistory(server.url, server.accessToken) | ||
221 | expect(res.body.total).to.equal(0) | ||
222 | }) | ||
223 | |||
224 | after(async function () { | ||
225 | await cleanupTests([ server ]) | ||
202 | }) | 226 | }) |
203 | }) | 227 | }) |
diff --git a/server/tests/api/videos/videos-overview.ts b/server/tests/api/videos/videos-overview.ts index 7221bcae6..975a5c87a 100644 --- a/server/tests/api/videos/videos-overview.ts +++ b/server/tests/api/videos/videos-overview.ts | |||
@@ -2,8 +2,8 @@ | |||
2 | 2 | ||
3 | import * as chai from 'chai' | 3 | import * as chai from 'chai' |
4 | import 'mocha' | 4 | import 'mocha' |
5 | import { flushTests, killallServers, runServer, ServerInfo, setAccessTokensToServers, uploadVideo } from '../../../../shared/utils' | 5 | import { cleanupTests, flushAndRunServer, ServerInfo, setAccessTokensToServers, uploadVideo } from '../../../../shared/extra-utils' |
6 | import { getVideosOverview } from '../../../../shared/utils/overviews/overviews' | 6 | import { getVideosOverview } from '../../../../shared/extra-utils/overviews/overviews' |
7 | import { VideosOverview } from '../../../../shared/models/overviews' | 7 | import { VideosOverview } from '../../../../shared/models/overviews' |
8 | 8 | ||
9 | const expect = chai.expect | 9 | const expect = chai.expect |
@@ -14,9 +14,7 @@ describe('Test a videos overview', function () { | |||
14 | before(async function () { | 14 | before(async function () { |
15 | this.timeout(30000) | 15 | this.timeout(30000) |
16 | 16 | ||
17 | await flushTests() | 17 | server = await flushAndRunServer(1) |
18 | |||
19 | server = await runServer(1) | ||
20 | 18 | ||
21 | await setAccessTokensToServers([ server ]) | 19 | await setAccessTokensToServers([ server ]) |
22 | }) | 20 | }) |
@@ -90,11 +88,6 @@ describe('Test a videos overview', function () { | |||
90 | }) | 88 | }) |
91 | 89 | ||
92 | after(async function () { | 90 | after(async function () { |
93 | killallServers([ server ]) | 91 | await cleanupTests([ server ]) |
94 | |||
95 | // Keep the logs if the test failed | ||
96 | if (this['ok']) { | ||
97 | await flushTests() | ||
98 | } | ||
99 | }) | 92 | }) |
100 | }) | 93 | }) |
diff --git a/server/tests/api/videos/videos-views-cleaner.ts b/server/tests/api/videos/videos-views-cleaner.ts new file mode 100644 index 000000000..c21d46d56 --- /dev/null +++ b/server/tests/api/videos/videos-views-cleaner.ts | |||
@@ -0,0 +1,106 @@ | |||
1 | /* tslint:disable:no-unused-expression */ | ||
2 | |||
3 | import * as chai from 'chai' | ||
4 | import 'mocha' | ||
5 | import { | ||
6 | flushAndRunMultipleServers, | ||
7 | flushTests, | ||
8 | killallServers, | ||
9 | reRunServer, | ||
10 | flushAndRunServer, | ||
11 | ServerInfo, | ||
12 | setAccessTokensToServers, | ||
13 | uploadVideo, uploadVideoAndGetId, viewVideo, wait, countVideoViewsOf, doubleFollow, waitJobs, cleanupTests | ||
14 | } from '../../../../shared/extra-utils' | ||
15 | import { getVideosOverview } from '../../../../shared/extra-utils/overviews/overviews' | ||
16 | import { VideosOverview } from '../../../../shared/models/overviews' | ||
17 | import { listMyVideosHistory } from '../../../../shared/extra-utils/videos/video-history' | ||
18 | |||
19 | const expect = chai.expect | ||
20 | |||
21 | describe('Test video views cleaner', function () { | ||
22 | let servers: ServerInfo[] | ||
23 | |||
24 | let videoIdServer1: string | ||
25 | let videoIdServer2: string | ||
26 | |||
27 | before(async function () { | ||
28 | this.timeout(50000) | ||
29 | |||
30 | servers = await flushAndRunMultipleServers(2) | ||
31 | await setAccessTokensToServers(servers) | ||
32 | |||
33 | await doubleFollow(servers[0], servers[1]) | ||
34 | |||
35 | videoIdServer1 = (await uploadVideoAndGetId({ server: servers[0], videoName: 'video server 1' })).uuid | ||
36 | videoIdServer2 = (await uploadVideoAndGetId({ server: servers[1], videoName: 'video server 2' })).uuid | ||
37 | |||
38 | await waitJobs(servers) | ||
39 | |||
40 | await viewVideo(servers[0].url, videoIdServer1) | ||
41 | await viewVideo(servers[1].url, videoIdServer1) | ||
42 | await viewVideo(servers[0].url, videoIdServer2) | ||
43 | await viewVideo(servers[1].url, videoIdServer2) | ||
44 | |||
45 | await waitJobs(servers) | ||
46 | }) | ||
47 | |||
48 | it('Should not clean old video views', async function () { | ||
49 | this.timeout(50000) | ||
50 | |||
51 | killallServers([ servers[0] ]) | ||
52 | |||
53 | await reRunServer(servers[0], { views: { videos: { remote: { max_age: '10 days' } } } }) | ||
54 | |||
55 | await wait(6000) | ||
56 | |||
57 | // Should still have views | ||
58 | |||
59 | { | ||
60 | for (const server of servers) { | ||
61 | const total = await countVideoViewsOf(server.serverNumber, videoIdServer1) | ||
62 | expect(total).to.equal(2) | ||
63 | } | ||
64 | } | ||
65 | |||
66 | { | ||
67 | for (const server of servers) { | ||
68 | const total = await countVideoViewsOf(server.serverNumber, videoIdServer2) | ||
69 | expect(total).to.equal(2) | ||
70 | } | ||
71 | } | ||
72 | }) | ||
73 | |||
74 | it('Should clean old video views', async function () { | ||
75 | this.timeout(50000) | ||
76 | |||
77 | this.timeout(50000) | ||
78 | |||
79 | killallServers([ servers[0] ]) | ||
80 | |||
81 | await reRunServer(servers[0], { views: { videos: { remote: { max_age: '5 seconds' } } } }) | ||
82 | |||
83 | await wait(6000) | ||
84 | |||
85 | // Should still have views | ||
86 | |||
87 | { | ||
88 | for (const server of servers) { | ||
89 | const total = await countVideoViewsOf(server.serverNumber, videoIdServer1) | ||
90 | expect(total).to.equal(2) | ||
91 | } | ||
92 | } | ||
93 | |||
94 | { | ||
95 | const totalServer1 = await countVideoViewsOf(servers[0].serverNumber, videoIdServer2) | ||
96 | expect(totalServer1).to.equal(0) | ||
97 | |||
98 | const totalServer2 = await countVideoViewsOf(servers[1].serverNumber, videoIdServer2) | ||
99 | expect(totalServer2).to.equal(2) | ||
100 | } | ||
101 | }) | ||
102 | |||
103 | after(async function () { | ||
104 | await cleanupTests(servers) | ||
105 | }) | ||
106 | }) | ||