Merge branch 'release/v1.3.0' into develop
[oweals/peertube.git] / server / tests / api / server / config.ts
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 })