]>
Commit | Line | Data |
---|---|---|
1 | /* tslint:disable:no-unused-expression */ | |
2 | ||
3 | import 'mocha' | |
4 | import * as chai from 'chai' | |
5 | import { About } from '../../../../shared/models/server/about.model' | |
6 | import { CustomConfig } from '../../../../shared/models/server/custom-config.model' | |
7 | import { | |
8 | cleanupTests, | |
9 | deleteCustomConfig, | |
10 | flushAndRunServer, | |
11 | getAbout, | |
12 | getConfig, | |
13 | getCustomConfig, | |
14 | killallServers, parallelTests, | |
15 | registerUser, | |
16 | reRunServer, ServerInfo, | |
17 | setAccessTokensToServers, | |
18 | updateCustomConfig, uploadVideo | |
19 | } from '../../../../shared/extra-utils' | |
20 | import { ServerConfig } from '../../../../shared/models' | |
21 | ||
22 | const expect = chai.expect | |
23 | ||
24 | function checkInitialConfig (server: ServerInfo, data: CustomConfig) { | |
25 | expect(data.instance.name).to.equal('PeerTube') | |
26 | expect(data.instance.shortDescription).to.equal( | |
27 | 'PeerTube, a federated (ActivityPub) video streaming platform using P2P (BitTorrent) directly in the web browser ' + | |
28 | 'with WebTorrent and Angular.' | |
29 | ) | |
30 | expect(data.instance.description).to.equal('Welcome to this PeerTube instance!') | |
31 | expect(data.instance.terms).to.equal('No terms for now.') | |
32 | expect(data.instance.defaultClientRoute).to.equal('/videos/trending') | |
33 | expect(data.instance.isNSFW).to.be.false | |
34 | expect(data.instance.defaultNSFWPolicy).to.equal('display') | |
35 | expect(data.instance.customizations.css).to.be.empty | |
36 | expect(data.instance.customizations.javascript).to.be.empty | |
37 | ||
38 | expect(data.services.twitter.username).to.equal('@Chocobozzz') | |
39 | expect(data.services.twitter.whitelisted).to.be.false | |
40 | ||
41 | expect(data.cache.previews.size).to.equal(1) | |
42 | expect(data.cache.captions.size).to.equal(1) | |
43 | ||
44 | expect(data.signup.enabled).to.be.true | |
45 | expect(data.signup.limit).to.equal(4) | |
46 | expect(data.signup.requiresEmailVerification).to.be.false | |
47 | ||
48 | expect(data.admin.email).to.equal('admin' + server.internalServerNumber + '@example.com') | |
49 | expect(data.contactForm.enabled).to.be.true | |
50 | ||
51 | expect(data.user.videoQuota).to.equal(5242880) | |
52 | expect(data.user.videoQuotaDaily).to.equal(-1) | |
53 | expect(data.transcoding.enabled).to.be.false | |
54 | expect(data.transcoding.allowAdditionalExtensions).to.be.false | |
55 | expect(data.transcoding.allowAudioFiles).to.be.false | |
56 | expect(data.transcoding.threads).to.equal(2) | |
57 | expect(data.transcoding.resolutions['240p']).to.be.true | |
58 | expect(data.transcoding.resolutions['360p']).to.be.true | |
59 | expect(data.transcoding.resolutions['480p']).to.be.true | |
60 | expect(data.transcoding.resolutions['720p']).to.be.true | |
61 | expect(data.transcoding.resolutions['1080p']).to.be.true | |
62 | expect(data.transcoding.hls.enabled).to.be.true | |
63 | ||
64 | expect(data.import.videos.http.enabled).to.be.true | |
65 | expect(data.import.videos.torrent.enabled).to.be.true | |
66 | expect(data.autoBlacklist.videos.ofUsers.enabled).to.be.false | |
67 | ||
68 | expect(data.followers.instance.enabled).to.be.true | |
69 | expect(data.followers.instance.manualApproval).to.be.false | |
70 | } | |
71 | ||
72 | function checkUpdatedConfig (data: CustomConfig) { | |
73 | expect(data.instance.name).to.equal('PeerTube updated') | |
74 | expect(data.instance.shortDescription).to.equal('my short description') | |
75 | expect(data.instance.description).to.equal('my super description') | |
76 | expect(data.instance.terms).to.equal('my super terms') | |
77 | expect(data.instance.defaultClientRoute).to.equal('/videos/recently-added') | |
78 | expect(data.instance.isNSFW).to.be.true | |
79 | expect(data.instance.defaultNSFWPolicy).to.equal('blur') | |
80 | expect(data.instance.customizations.javascript).to.equal('alert("coucou")') | |
81 | expect(data.instance.customizations.css).to.equal('body { background-color: red; }') | |
82 | ||
83 | expect(data.services.twitter.username).to.equal('@Kuja') | |
84 | expect(data.services.twitter.whitelisted).to.be.true | |
85 | ||
86 | expect(data.cache.previews.size).to.equal(2) | |
87 | expect(data.cache.captions.size).to.equal(3) | |
88 | ||
89 | expect(data.signup.enabled).to.be.false | |
90 | expect(data.signup.limit).to.equal(5) | |
91 | expect(data.signup.requiresEmailVerification).to.be.false | |
92 | ||
93 | // We override admin email in parallel tests, so skip this exception | |
94 | if (parallelTests() === false) { | |
95 | expect(data.admin.email).to.equal('superadmin1@example.com') | |
96 | } | |
97 | ||
98 | expect(data.contactForm.enabled).to.be.false | |
99 | ||
100 | expect(data.user.videoQuota).to.equal(5242881) | |
101 | expect(data.user.videoQuotaDaily).to.equal(318742) | |
102 | ||
103 | expect(data.transcoding.enabled).to.be.true | |
104 | expect(data.transcoding.threads).to.equal(1) | |
105 | expect(data.transcoding.allowAdditionalExtensions).to.be.true | |
106 | expect(data.transcoding.allowAudioFiles).to.be.true | |
107 | expect(data.transcoding.resolutions['240p']).to.be.false | |
108 | expect(data.transcoding.resolutions['360p']).to.be.true | |
109 | expect(data.transcoding.resolutions['480p']).to.be.true | |
110 | expect(data.transcoding.resolutions['720p']).to.be.false | |
111 | expect(data.transcoding.resolutions['1080p']).to.be.false | |
112 | expect(data.transcoding.hls.enabled).to.be.false | |
113 | ||
114 | expect(data.import.videos.http.enabled).to.be.false | |
115 | expect(data.import.videos.torrent.enabled).to.be.false | |
116 | expect(data.autoBlacklist.videos.ofUsers.enabled).to.be.true | |
117 | ||
118 | expect(data.followers.instance.enabled).to.be.false | |
119 | expect(data.followers.instance.manualApproval).to.be.true | |
120 | } | |
121 | ||
122 | describe('Test config', function () { | |
123 | let server = null | |
124 | ||
125 | before(async function () { | |
126 | this.timeout(30000) | |
127 | ||
128 | server = await flushAndRunServer(1) | |
129 | await setAccessTokensToServers([ server ]) | |
130 | }) | |
131 | ||
132 | it('Should have a correct config on a server with registration enabled', async function () { | |
133 | const res = await getConfig(server.url) | |
134 | const data: ServerConfig = res.body | |
135 | ||
136 | expect(data.signup.allowed).to.be.true | |
137 | }) | |
138 | ||
139 | it('Should have a correct config on a server with registration enabled and a users limit', async function () { | |
140 | this.timeout(5000) | |
141 | ||
142 | await Promise.all([ | |
143 | registerUser(server.url, 'user1', 'super password'), | |
144 | registerUser(server.url, 'user2', 'super password'), | |
145 | registerUser(server.url, 'user3', 'super password') | |
146 | ]) | |
147 | ||
148 | const res = await getConfig(server.url) | |
149 | const data: ServerConfig = res.body | |
150 | ||
151 | expect(data.signup.allowed).to.be.false | |
152 | }) | |
153 | ||
154 | it('Should have the correct video allowed extensions', async function () { | |
155 | const res = await getConfig(server.url) | |
156 | const data: ServerConfig = res.body | |
157 | ||
158 | expect(data.video.file.extensions).to.have.lengthOf(3) | |
159 | expect(data.video.file.extensions).to.contain('.mp4') | |
160 | expect(data.video.file.extensions).to.contain('.webm') | |
161 | expect(data.video.file.extensions).to.contain('.ogv') | |
162 | ||
163 | await uploadVideo(server.url, server.accessToken, { fixture: 'video_short.mkv' }, 400) | |
164 | await uploadVideo(server.url, server.accessToken, { fixture: 'sample.ogg' }, 400) | |
165 | ||
166 | expect(data.contactForm.enabled).to.be.true | |
167 | }) | |
168 | ||
169 | it('Should get the customized configuration', async function () { | |
170 | const res = await getCustomConfig(server.url, server.accessToken) | |
171 | const data = res.body as CustomConfig | |
172 | ||
173 | checkInitialConfig(server, data) | |
174 | }) | |
175 | ||
176 | it('Should update the customized configuration', async function () { | |
177 | const newCustomConfig: CustomConfig = { | |
178 | instance: { | |
179 | name: 'PeerTube updated', | |
180 | shortDescription: 'my short description', | |
181 | description: 'my super description', | |
182 | terms: 'my super terms', | |
183 | defaultClientRoute: '/videos/recently-added', | |
184 | isNSFW: true, | |
185 | defaultNSFWPolicy: 'blur' as 'blur', | |
186 | customizations: { | |
187 | javascript: 'alert("coucou")', | |
188 | css: 'body { background-color: red; }' | |
189 | } | |
190 | }, | |
191 | services: { | |
192 | twitter: { | |
193 | username: '@Kuja', | |
194 | whitelisted: true | |
195 | } | |
196 | }, | |
197 | cache: { | |
198 | previews: { | |
199 | size: 2 | |
200 | }, | |
201 | captions: { | |
202 | size: 3 | |
203 | } | |
204 | }, | |
205 | signup: { | |
206 | enabled: false, | |
207 | limit: 5, | |
208 | requiresEmailVerification: false | |
209 | }, | |
210 | admin: { | |
211 | email: 'superadmin1@example.com' | |
212 | }, | |
213 | contactForm: { | |
214 | enabled: false | |
215 | }, | |
216 | user: { | |
217 | videoQuota: 5242881, | |
218 | videoQuotaDaily: 318742 | |
219 | }, | |
220 | transcoding: { | |
221 | enabled: true, | |
222 | allowAdditionalExtensions: true, | |
223 | allowAudioFiles: true, | |
224 | threads: 1, | |
225 | resolutions: { | |
226 | '240p': false, | |
227 | '360p': true, | |
228 | '480p': true, | |
229 | '720p': false, | |
230 | '1080p': false | |
231 | }, | |
232 | hls: { | |
233 | enabled: false | |
234 | } | |
235 | }, | |
236 | import: { | |
237 | videos: { | |
238 | http: { | |
239 | enabled: false | |
240 | }, | |
241 | torrent: { | |
242 | enabled: false | |
243 | } | |
244 | } | |
245 | }, | |
246 | autoBlacklist: { | |
247 | videos: { | |
248 | ofUsers: { | |
249 | enabled: true | |
250 | } | |
251 | } | |
252 | }, | |
253 | followers: { | |
254 | instance: { | |
255 | enabled: false, | |
256 | manualApproval: true | |
257 | } | |
258 | } | |
259 | } | |
260 | await updateCustomConfig(server.url, server.accessToken, newCustomConfig) | |
261 | ||
262 | const res = await getCustomConfig(server.url, server.accessToken) | |
263 | const data = res.body | |
264 | ||
265 | checkUpdatedConfig(data) | |
266 | }) | |
267 | ||
268 | it('Should have the correct updated video allowed extensions', async function () { | |
269 | const res = await getConfig(server.url) | |
270 | const data: ServerConfig = res.body | |
271 | ||
272 | expect(data.video.file.extensions).to.have.length.above(3) | |
273 | expect(data.video.file.extensions).to.contain('.mp4') | |
274 | expect(data.video.file.extensions).to.contain('.webm') | |
275 | expect(data.video.file.extensions).to.contain('.ogv') | |
276 | expect(data.video.file.extensions).to.contain('.flv') | |
277 | expect(data.video.file.extensions).to.contain('.mkv') | |
278 | expect(data.video.file.extensions).to.contain('.mp3') | |
279 | expect(data.video.file.extensions).to.contain('.ogg') | |
280 | expect(data.video.file.extensions).to.contain('.flac') | |
281 | ||
282 | await uploadVideo(server.url, server.accessToken, { fixture: 'video_short.mkv' }, 200) | |
283 | await uploadVideo(server.url, server.accessToken, { fixture: 'sample.ogg' }, 200) | |
284 | }) | |
285 | ||
286 | it('Should have the configuration updated after a restart', async function () { | |
287 | this.timeout(10000) | |
288 | ||
289 | killallServers([ server ]) | |
290 | ||
291 | await reRunServer(server) | |
292 | ||
293 | const res = await getCustomConfig(server.url, server.accessToken) | |
294 | const data = res.body | |
295 | ||
296 | checkUpdatedConfig(data) | |
297 | }) | |
298 | ||
299 | it('Should fetch the about information', async function () { | |
300 | const res = await getAbout(server.url) | |
301 | const data: About = res.body | |
302 | ||
303 | expect(data.instance.name).to.equal('PeerTube updated') | |
304 | expect(data.instance.shortDescription).to.equal('my short description') | |
305 | expect(data.instance.description).to.equal('my super description') | |
306 | expect(data.instance.terms).to.equal('my super terms') | |
307 | }) | |
308 | ||
309 | it('Should remove the custom configuration', async function () { | |
310 | this.timeout(10000) | |
311 | ||
312 | await deleteCustomConfig(server.url, server.accessToken) | |
313 | ||
314 | const res = await getCustomConfig(server.url, server.accessToken) | |
315 | const data = res.body | |
316 | ||
317 | checkInitialConfig(server, data) | |
318 | }) | |
319 | ||
320 | after(async function () { | |
321 | await cleanupTests([ server ]) | |
322 | }) | |
323 | }) |