1 /* tslint:disable:no-unused-expression */
4 import * as chai from 'chai'
8 flushAndRunMultipleServers,
16 setAccessTokensToServers,
27 import { createUser } from '../utils/users'
29 const expect = chai.expect
31 describe('Test multiple servers', function () {
32 let servers: ServerInfo[] = []
35 let videoChannelId: number
37 before(async function () {
40 servers = await flushAndRunMultipleServers(3)
42 // Get the access tokens
43 await setAccessTokensToServers(servers)
45 const videoChannel = {
47 description: 'super channel'
49 await addVideoChannel(servers[0].url, servers[0].accessToken, videoChannel)
50 const channelRes = await getVideoChannelsList(servers[0].url, 0, 1)
51 videoChannelId = channelRes.body.data[0].id
53 // Server 1 and server 2 follow each other
54 await doubleFollow(servers[0], servers[1])
55 // Server 1 and server 3 follow each other
56 await doubleFollow(servers[0], servers[2])
57 // Server 2 and server 3 follow each other
58 await doubleFollow(servers[1], servers[2])
61 it('Should not have videos for all servers', async function () {
62 for (const server of servers) {
63 const res = await getVideosList(server.url)
64 const videos = res.body.data
65 expect(videos).to.be.an('array')
66 expect(videos.length).to.equal(0)
70 describe('Should upload the video and propagate on each server', function () {
71 it('Should upload the video on server 1 and propagate on each server', async function () {
72 // Server 1 has video transcoding activated
75 const videoAttributes = {
76 name: 'my super name for server 1',
81 description: 'my super description for server 1',
82 tags: [ 'tag1p1', 'tag2p1' ],
83 channelId: videoChannelId,
84 fixture: 'video_short1.webm'
86 await uploadVideo(servers[0].url, servers[0].accessToken, videoAttributes)
90 // All servers should have this video
91 for (const server of servers) {
94 const res = await getVideosList(server.url)
96 const videos = res.body.data
97 expect(videos).to.be.an('array')
98 expect(videos.length).to.equal(1)
99 const video = videos[0]
100 expect(video.name).to.equal('my super name for server 1')
101 expect(video.category).to.equal(5)
102 expect(video.categoryLabel).to.equal('Sports')
103 expect(video.licence).to.equal(4)
104 expect(video.licenceLabel).to.equal('Attribution - Non Commercial')
105 expect(video.language).to.equal(9)
106 expect(video.languageLabel).to.equal('Japanese')
107 expect(video.nsfw).to.be.ok
108 expect(video.description).to.equal('my super description for server 1')
109 expect(video.serverHost).to.equal('localhost:9001')
110 expect(video.duration).to.equal(10)
111 expect(video.tags).to.deep.equal([ 'tag1p1', 'tag2p1' ])
112 expect(dateIsValid(video.createdAt)).to.be.true
113 expect(dateIsValid(video.updatedAt)).to.be.true
114 expect(video.account).to.equal('root')
116 const res2 = await getVideo(server.url, video.uuid)
117 const videoDetails = res2.body
119 expect(videoDetails.channel.name).to.equal('my channel')
120 expect(videoDetails.channel.description).to.equal('super channel')
121 expect(dateIsValid(videoDetails.channel.createdAt)).to.be.true
122 expect(dateIsValid(videoDetails.channel.updatedAt)).to.be.true
123 expect(videoDetails.files).to.have.lengthOf(1)
125 const file = videoDetails.files[0]
126 const magnetUri = file.magnetUri
127 expect(file.magnetUri).to.have.lengthOf.above(2)
128 expect(file.torrentUrl).to
129 .equal(`http://${videoDetails.serverHost}/static/torrents/${videoDetails.uuid}-${file.resolution}.torrent`)
130 expect(file.fileUrl).to.equal(`http://${videoDetails.serverHost}/static/webseed/${videoDetails.uuid}-${file.resolution}.webm`)
131 expect(file.resolution).to.equal(720)
132 expect(file.resolutionLabel).to.equal('720p')
133 expect(file.size).to.equal(572456)
135 if (server.url !== 'http://localhost:9001') {
136 expect(video.isLocal).to.be.false
137 expect(videoDetails.channel.isLocal).to.be.false
139 expect(video.isLocal).to.be.true
140 expect(videoDetails.channel.isLocal).to.be.true
143 // All servers should have the same magnet Uri
144 if (baseMagnet === null) {
145 baseMagnet = magnetUri
147 expect(baseMagnet).to.equal(magnetUri)
150 const test = await testVideoImage(server.url, 'video_short1.webm', video.thumbnailPath)
151 expect(test).to.equal(true)
155 it('Should upload the video on server 2 and propagate on each server', async function () {
160 password: 'super_password'
162 await createUser(servers[1].url, servers[1].accessToken, user.username, user.password)
163 const userAccessToken = await getUserAccessToken(servers[1], user)
165 const videoAttributes = {
166 name: 'my super name for server 2',
171 description: 'my super description for server 2',
172 tags: [ 'tag1p2', 'tag2p2', 'tag3p2' ],
173 fixture: 'video_short2.webm'
175 await uploadVideo(servers[1].url, userAccessToken, videoAttributes)
177 // Transcoding, so wait more than 22000
180 // All servers should have this video
181 for (const server of servers) {
184 const res = await getVideosList(server.url)
186 const videos = res.body.data
187 expect(videos).to.be.an('array')
188 expect(videos.length).to.equal(2)
189 const video = videos[1]
190 expect(video.name).to.equal('my super name for server 2')
191 expect(video.category).to.equal(4)
192 expect(video.categoryLabel).to.equal('Art')
193 expect(video.licence).to.equal(3)
194 expect(video.licenceLabel).to.equal('Attribution - No Derivatives')
195 expect(video.language).to.equal(11)
196 expect(video.languageLabel).to.equal('German')
197 expect(video.nsfw).to.be.true
198 expect(video.description).to.equal('my super description for server 2')
199 expect(video.serverHost).to.equal('localhost:9002')
200 expect(video.duration).to.equal(5)
201 expect(video.tags).to.deep.equal([ 'tag1p2', 'tag2p2', 'tag3p2' ])
202 expect(dateIsValid(video.createdAt)).to.be.true
203 expect(dateIsValid(video.updatedAt)).to.be.true
204 expect(video.account).to.equal('user1')
206 if (server.url !== 'http://localhost:9002') {
207 expect(video.isLocal).to.be.false
209 expect(video.isLocal).to.be.true
212 const res2 = await getVideo(server.url, video.uuid)
213 const videoDetails = res2.body
215 expect(videoDetails.channel.name).to.equal('Default user1 channel')
216 expect(dateIsValid(videoDetails.channel.createdAt)).to.be.true
217 expect(dateIsValid(videoDetails.channel.updatedAt)).to.be.true
219 expect(videoDetails.files).to.have.lengthOf(4)
221 // Check common attributes
222 for (const file of videoDetails.files) {
223 expect(file.magnetUri).to.have.lengthOf.above(2)
225 // All servers should have the same magnet Uri
226 if (baseMagnet[file.resolution] === undefined) {
227 baseMagnet[file.resolution] = file.magnet
229 expect(baseMagnet[file.resolution]).to.equal(file.magnet)
233 const file240p = videoDetails.files.find(f => f.resolution === 240)
234 expect(file240p).not.to.be.undefined
235 expect(file240p.resolutionLabel).to.equal('240p')
236 expect(file240p.size).to.be.above(180000).and.below(200000)
238 const file360p = videoDetails.files.find(f => f.resolution === 360)
239 expect(file360p).not.to.be.undefined
240 expect(file360p.resolutionLabel).to.equal('360p')
241 expect(file360p.size).to.be.above(270000).and.below(290000)
243 const file480p = videoDetails.files.find(f => f.resolution === 480)
244 expect(file480p).not.to.be.undefined
245 expect(file480p.resolutionLabel).to.equal('480p')
246 expect(file480p.size).to.be.above(380000).and.below(400000)
248 const file720p = videoDetails.files.find(f => f.resolution === 720)
249 expect(file720p).not.to.be.undefined
250 expect(file720p.resolutionLabel).to.equal('720p')
251 expect(file720p.size).to.be.above(700000).and.below(7200000)
253 const test = await testVideoImage(server.url, 'video_short2.webm', videoDetails.thumbnailPath)
254 expect(test).to.equal(true)
258 it('Should upload two videos on server 3 and propagate on each server', async function () {
261 const videoAttributes1 = {
262 name: 'my super name for server 3',
267 description: 'my super description for server 3',
269 fixture: 'video_short3.webm'
271 await uploadVideo(servers[2].url, servers[2].accessToken, videoAttributes1)
273 const videoAttributes2 = {
274 name: 'my super name for server 3-2',
279 description: 'my super description for server 3-2',
280 tags: [ 'tag2p3', 'tag3p3', 'tag4p3' ],
281 fixture: 'video_short.webm'
283 await uploadVideo(servers[2].url, servers[2].accessToken, videoAttributes2)
287 let baseMagnet = null
288 // All servers should have this video
289 for (const server of servers) {
290 const res = await getVideosList(server.url)
292 const videos = res.body.data
293 expect(videos).to.be.an('array')
294 expect(videos.length).to.equal(4)
296 // We not sure about the order of the two last uploads
299 if (videos[2].name === 'my super name for server 3') {
307 expect(video1.name).to.equal('my super name for server 3')
308 expect(video1.category).to.equal(6)
309 expect(video1.categoryLabel).to.equal('Travels')
310 expect(video1.licence).to.equal(5)
311 expect(video1.licenceLabel).to.equal('Attribution - Non Commercial - Share Alike')
312 expect(video1.language).to.equal(11)
313 expect(video1.languageLabel).to.equal('German')
314 expect(video1.nsfw).to.be.ok
315 expect(video1.description).to.equal('my super description for server 3')
316 expect(video1.serverHost).to.equal('localhost:9003')
317 expect(video1.duration).to.equal(5)
318 expect(video1.tags).to.deep.equal([ 'tag1p3' ])
319 expect(video1.author).to.equal('root')
320 expect(dateIsValid(video1.createdAt)).to.be.true
321 expect(dateIsValid(video1.updatedAt)).to.be.true
323 const res2 = await getVideo(server.url, video1.id)
324 const video1Details = res2.body
325 expect(video1Details.files).to.have.lengthOf(1)
327 const file1 = video1Details.files[0]
328 expect(file1.magnetUri).to.have.lengthOf.above(2)
329 expect(file1.resolution).to.equal(720)
330 expect(file1.resolutionLabel).to.equal('720p')
331 expect(file1.size).to.equal(292677)
333 expect(video2.name).to.equal('my super name for server 3-2')
334 expect(video2.category).to.equal(7)
335 expect(video2.categoryLabel).to.equal('Gaming')
336 expect(video2.licence).to.equal(6)
337 expect(video2.licenceLabel).to.equal('Attribution - Non Commercial - No Derivatives')
338 expect(video2.language).to.equal(12)
339 expect(video2.languageLabel).to.equal('Korean')
340 expect(video2.nsfw).to.be.false
341 expect(video2.description).to.equal('my super description for server 3-2')
342 expect(video2.serverHost).to.equal('localhost:9003')
343 expect(video2.duration).to.equal(5)
344 expect(video2.tags).to.deep.equal([ 'tag2p3', 'tag3p3', 'tag4p3' ])
345 expect(video2.author).to.equal('root')
346 expect(dateIsValid(video2.createdAt)).to.be.true
347 expect(dateIsValid(video2.updatedAt)).to.be.true
349 const res3 = await getVideo(server.url, video2.id)
350 const video2Details = res3.body
352 expect(video2Details.files).to.have.lengthOf(1)
354 const file2 = video2Details.files[0]
355 const magnetUri2 = file2.magnetUri
356 expect(file2.magnetUri).to.have.lengthOf.above(2)
357 expect(file2.resolution).to.equal(720)
358 expect(file2.resolutionLabel).to.equal('720p')
359 expect(file2.size).to.equal(218910)
361 if (server.url !== 'http://localhost:9003') {
362 expect(video1.isLocal).to.be.false
363 expect(video2.isLocal).to.be.false
365 expect(video1.isLocal).to.be.true
366 expect(video2.isLocal).to.be.true
369 // All servers should have the same magnet Uri
370 if (baseMagnet === null) {
371 baseMagnet = magnetUri2
373 expect(baseMagnet).to.equal(magnetUri2)
376 const test1 = await testVideoImage(server.url, 'video_short3.webm', video1.thumbnailPath)
377 expect(test1).to.equal(true)
379 const test2 = await testVideoImage(server.url, 'video_short.webm', video2.thumbnailPath)
380 expect(test2).to.equal(true)
385 describe('Should seed the uploaded video', function () {
386 it('Should add the file 1 by asking server 3', async function () {
387 // Yes, this could be long
390 const res = await getVideosList(servers[2].url)
392 const video = res.body.data[0]
393 toRemove.push(res.body.data[2])
394 toRemove.push(res.body.data[3])
396 const res2 = await getVideo(servers[2].url, video.id)
397 const videoDetails = res2.body
399 const torrent = await webtorrentAdd(videoDetails.files[0].magnetUri)
400 expect(torrent.files).to.be.an('array')
401 expect(torrent.files.length).to.equal(1)
402 expect(torrent.files[0].path).to.exist.and.to.not.equal('')
405 it('Should add the file 2 by asking server 1', async function () {
406 // Yes, this could be long
409 const res = await getVideosList(servers[0].url)
411 const video = res.body.data[1]
412 const res2 = await getVideo(servers[0].url, video.id)
413 const videoDetails = res2.body
415 const torrent = await webtorrentAdd(videoDetails.files[0].magnetUri)
416 expect(torrent.files).to.be.an('array')
417 expect(torrent.files.length).to.equal(1)
418 expect(torrent.files[0].path).to.exist.and.to.not.equal('')
421 it('Should add the file 3 by asking server 2', async function () {
422 // Yes, this could be long
425 const res = await getVideosList(servers[1].url)
427 const video = res.body.data[2]
428 const res2 = await getVideo(servers[1].url, video.id)
429 const videoDetails = res2.body
431 const torrent = await webtorrentAdd(videoDetails.files[0].magnetUri)
432 expect(torrent.files).to.be.an('array')
433 expect(torrent.files.length).to.equal(1)
434 expect(torrent.files[0].path).to.exist.and.to.not.equal('')
437 it('Should add the file 3-2 by asking server 1', async function () {
438 // Yes, this could be long
441 const res = await getVideosList(servers[0].url)
443 const video = res.body.data[3]
444 const res2 = await getVideo(servers[0].url, video.id)
445 const videoDetails = res2.body
447 const torrent = await webtorrentAdd(videoDetails.files[0].magnetUri)
448 expect(torrent.files).to.be.an('array')
449 expect(torrent.files.length).to.equal(1)
450 expect(torrent.files[0].path).to.exist.and.to.not.equal('')
453 it('Should add the file 2 in 360p by asking server 1', async function () {
454 // Yes, this could be long
457 const res = await getVideosList(servers[0].url)
459 const video = res.body.data.find(v => v.name === 'my super name for server 2')
460 const res2 = await getVideo(servers[0].url, video.id)
461 const videoDetails = res2.body
463 const file = videoDetails.files.find(f => f.resolution === 360)
464 expect(file).not.to.be.undefined
466 const torrent = await webtorrentAdd(file.magnetUri)
467 expect(torrent.files).to.be.an('array')
468 expect(torrent.files.length).to.equal(1)
469 expect(torrent.files[0].path).to.exist.and.to.not.equal('')
473 describe('Should update video views, likes and dislikes', function () {
474 let localVideosServer3 = []
475 let remoteVideosServer1 = []
476 let remoteVideosServer2 = []
477 let remoteVideosServer3 = []
479 before(async function () {
480 const res1 = await getVideosList(servers[0].url)
481 remoteVideosServer1 = res1.body.data.filter(video => video.isLocal === false).map(video => video.uuid)
483 const res2 = await getVideosList(servers[1].url)
484 remoteVideosServer2 = res2.body.data.filter(video => video.isLocal === false).map(video => video.uuid)
486 const res3 = await getVideosList(servers[2].url)
487 localVideosServer3 = res3.body.data.filter(video => video.isLocal === true).map(video => video.uuid)
488 remoteVideosServer3 = res3.body.data.filter(video => video.isLocal === false).map(video => video.uuid)
491 it('Should view multiple videos on owned servers', async function () {
494 const tasks: Promise<any>[] = []
495 tasks.push(getVideo(servers[2].url, localVideosServer3[0]))
496 tasks.push(getVideo(servers[2].url, localVideosServer3[0]))
497 tasks.push(getVideo(servers[2].url, localVideosServer3[0]))
498 tasks.push(getVideo(servers[2].url, localVideosServer3[1]))
500 await Promise.all(tasks)
504 for (const server of servers) {
505 const res = await getVideosList(server.url)
507 const videos = res.body.data
508 const video0 = videos.find(v => v.uuid === localVideosServer3[0])
509 const video1 = videos.find(v => v.uuid === localVideosServer3[1])
511 expect(video0.views).to.equal(7)
512 expect(video1.views).to.equal(5)
516 it('Should view multiple videos on each servers', async function () {
519 const tasks: Promise<any>[] = []
520 tasks.push(getVideo(servers[0].url, remoteVideosServer1[0]))
521 tasks.push(getVideo(servers[1].url, remoteVideosServer2[0]))
522 tasks.push(getVideo(servers[1].url, remoteVideosServer2[0]))
523 tasks.push(getVideo(servers[2].url, remoteVideosServer3[0]))
524 tasks.push(getVideo(servers[2].url, remoteVideosServer3[1]))
525 tasks.push(getVideo(servers[2].url, remoteVideosServer3[1]))
526 tasks.push(getVideo(servers[2].url, remoteVideosServer3[1]))
527 tasks.push(getVideo(servers[2].url, localVideosServer3[1]))
528 tasks.push(getVideo(servers[2].url, localVideosServer3[1]))
529 tasks.push(getVideo(servers[2].url, localVideosServer3[1]))
531 await Promise.all(tasks)
535 let baseVideos = null
537 for (const server of servers) {
538 const res = await getVideosList(server.url)
540 const videos = res.body.data
542 // Initialize base videos for future comparisons
543 if (baseVideos === null) {
548 for (const baseVideo of baseVideos) {
549 const sameVideo = videos.find(video => video.name === baseVideo.name)
550 expect(baseVideo.views).to.equal(sameVideo.views)
555 it('Should like and dislikes videos on different services', async function () {
558 const tasks: Promise<any>[] = []
559 tasks.push(rateVideo(servers[0].url, servers[0].accessToken, remoteVideosServer1[0], 'like'))
560 tasks.push(rateVideo(servers[0].url, servers[0].accessToken, remoteVideosServer1[0], 'dislike'))
561 tasks.push(rateVideo(servers[0].url, servers[0].accessToken, remoteVideosServer1[0], 'like'))
562 tasks.push(rateVideo(servers[2].url, servers[2].accessToken, localVideosServer3[1], 'like'))
563 tasks.push(rateVideo(servers[2].url, servers[2].accessToken, localVideosServer3[1], 'dislike'))
564 tasks.push(rateVideo(servers[2].url, servers[2].accessToken, remoteVideosServer3[1], 'dislike'))
565 tasks.push(rateVideo(servers[2].url, servers[2].accessToken, remoteVideosServer3[0], 'like'))
567 await Promise.all(tasks)
571 let baseVideos = null
572 for (const server of servers) {
573 const res = await getVideosList(server.url)
575 const videos = res.body.data
577 // Initialize base videos for future comparisons
578 if (baseVideos === null) {
583 baseVideos.forEach(baseVideo => {
584 const sameVideo = videos.find(video => video.name === baseVideo.name)
585 expect(baseVideo.likes).to.equal(sameVideo.likes)
586 expect(baseVideo.dislikes).to.equal(sameVideo.dislikes)
592 describe('Should manipulate these videos', function () {
593 it('Should update the video 3 by asking server 3', async function () {
597 name: 'my super video updated',
602 description: 'my super description updated',
603 tags: [ 'tag_up_1', 'tag_up_2' ]
606 await updateVideo(servers[2].url, servers[2].accessToken, toRemove[0].id, attributes)
611 it('Should have the video 3 updated on each server', async function () {
614 for (const server of servers) {
615 const res = await getVideosList(server.url)
617 const videos = res.body.data
618 const videoUpdated = videos.find(video => video.name === 'my super video updated')
620 expect(!!videoUpdated).to.be.true
621 expect(videoUpdated.category).to.equal(10)
622 expect(videoUpdated.categoryLabel).to.equal('Entertainment')
623 expect(videoUpdated.licence).to.equal(7)
624 expect(videoUpdated.licenceLabel).to.equal('Public Domain Dedication')
625 expect(videoUpdated.language).to.equal(13)
626 expect(videoUpdated.languageLabel).to.equal('French')
627 expect(videoUpdated.nsfw).to.be.ok
628 expect(videoUpdated.description).to.equal('my super description updated')
629 expect(videoUpdated.tags).to.deep.equal([ 'tag_up_1', 'tag_up_2' ])
630 expect(dateIsValid(videoUpdated.updatedAt, 20000)).to.be.true
632 const res2 = await getVideo(server.url, videoUpdated.uuid)
633 const videoUpdatedDetails = res2.body
635 const file = videoUpdatedDetails .files[0]
636 expect(file.magnetUri).to.have.lengthOf.above(2)
637 expect(file.resolution).to.equal(720)
638 expect(file.resolutionLabel).to.equal('720p')
639 expect(file.size).to.equal(292677)
641 const test = await testVideoImage(server.url, 'video_short3.webm', videoUpdated.thumbnailPath)
642 expect(test).to.equal(true)
644 // Avoid "duplicate torrent" errors
645 const refreshWebTorrent = true
646 const torrent = await webtorrentAdd(videoUpdatedDetails .files[0].magnetUri, refreshWebTorrent)
647 expect(torrent.files).to.be.an('array')
648 expect(torrent.files.length).to.equal(1)
649 expect(torrent.files[0].path).to.exist.and.to.not.equal('')
653 it('Should remove the videos 3 and 3-2 by asking server 3', async function () {
656 await removeVideo(servers[2].url, servers[2].accessToken, toRemove[0].id)
657 await removeVideo(servers[2].url, servers[2].accessToken, toRemove[1].id)
662 it('Should have videos 1 and 3 on each server', async function () {
663 for (const server of servers) {
664 const res = await getVideosList(server.url)
666 const videos = res.body.data
667 expect(videos).to.be.an('array')
668 expect(videos.length).to.equal(2)
669 expect(videos[0].name).not.to.equal(videos[1].name)
670 expect(videos[0].name).not.to.equal(toRemove[0].name)
671 expect(videos[1].name).not.to.equal(toRemove[0].name)
672 expect(videos[0].name).not.to.equal(toRemove[1].name)
673 expect(videos[1].name).not.to.equal(toRemove[1].name)
675 videoUUID = videos.find(video => video.name === 'my super name for server 1').uuid
679 it('Should get the same video by UUID on each server', async function () {
681 for (const server of servers) {
682 const res = await getVideo(server.url, videoUUID)
684 const video = res.body
686 if (baseVideo === null) {
691 expect(baseVideo.name).to.equal(video.name)
692 expect(baseVideo.uuid).to.equal(video.uuid)
693 expect(baseVideo.category).to.equal(video.category)
694 expect(baseVideo.language).to.equal(video.language)
695 expect(baseVideo.licence).to.equal(video.licence)
696 expect(baseVideo.category).to.equal(video.category)
697 expect(baseVideo.nsfw).to.equal(video.nsfw)
698 expect(baseVideo.author).to.equal(video.account)
699 expect(baseVideo.tags).to.deep.equal(video.tags)
703 it('Should get the preview from each server', async function () {
704 for (const server of servers) {
705 const res = await getVideo(server.url, videoUUID)
706 const video = res.body
708 const test = await testVideoImage(server.url, 'video_short1-preview.webm', video.previewPath)
709 expect(test).to.equal(true)
714 after(async function () {
715 killallServers(servers)
717 // Keep the logs if the test failed