]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blob - server/tests/cli/create-import-video-file-job.ts
Merge branch 'release/2.1.0' into develop
[github/Chocobozzz/PeerTube.git] / server / tests / cli / create-import-video-file-job.ts
1 /* eslint-disable @typescript-eslint/no-unused-expressions,@typescript-eslint/require-await */
2
3 import 'mocha'
4 import * as chai from 'chai'
5 import { VideoDetails } from '../../../shared/models/videos'
6 import {
7 cleanupTests,
8 doubleFollow,
9 execCLI,
10 flushAndRunMultipleServers,
11 getEnvCli,
12 getVideo,
13 getVideosList,
14 ServerInfo,
15 setAccessTokensToServers,
16 uploadVideo
17 } from '../../../shared/extra-utils'
18 import { waitJobs } from '../../../shared/extra-utils/server/jobs'
19 import { VideoFile } from '@shared/models/videos/video-file.model'
20
21 const expect = chai.expect
22
23 function assertVideoProperties (video: VideoFile, resolution: number, extname: string, size?: number) {
24 expect(video).to.have.nested.property('resolution.id', resolution)
25 expect(video).to.have.property('magnetUri').that.includes(`.${extname}`)
26 expect(video).to.have.property('torrentUrl').that.includes(`-${resolution}.torrent`)
27 expect(video).to.have.property('fileUrl').that.includes(`.${extname}`)
28 expect(video).to.have.property('size').that.is.above(0)
29
30 if (size) expect(video.size).to.equal(size)
31 }
32
33 describe('Test create import video jobs', function () {
34 this.timeout(60000)
35
36 let servers: ServerInfo[] = []
37 let video1UUID: string
38 let video2UUID: string
39
40 before(async function () {
41 this.timeout(90000)
42
43 // Run server 2 to have transcoding enabled
44 servers = await flushAndRunMultipleServers(2)
45 await setAccessTokensToServers(servers)
46
47 await doubleFollow(servers[0], servers[1])
48
49 // Upload two videos for our needs
50 const res1 = await uploadVideo(servers[0].url, servers[0].accessToken, { name: 'video1' })
51 video1UUID = res1.body.video.uuid
52 const res2 = await uploadVideo(servers[1].url, servers[1].accessToken, { name: 'video2' })
53 video2UUID = res2.body.video.uuid
54
55 // Transcoding
56 await waitJobs(servers)
57 })
58
59 it('Should run a import job on video 1 with a lower resolution', async function () {
60 const env = getEnvCli(servers[0])
61 await execCLI(`${env} npm run create-import-video-file-job -- -v ${video1UUID} -i server/tests/fixtures/video_short-480.webm`)
62
63 await waitJobs(servers)
64
65 let magnetUri: string
66 for (const server of servers) {
67 const { data: videos } = (await getVideosList(server.url)).body
68 expect(videos).to.have.lengthOf(2)
69
70 const video = videos.find(({ uuid }) => uuid === video1UUID)
71 const videoDetail: VideoDetails = (await getVideo(server.url, video.uuid)).body
72
73 expect(videoDetail.files).to.have.lengthOf(2)
74 const [ originalVideo, transcodedVideo ] = videoDetail.files
75 assertVideoProperties(originalVideo, 720, 'webm', 218910)
76 assertVideoProperties(transcodedVideo, 480, 'webm', 69217)
77
78 if (!magnetUri) magnetUri = transcodedVideo.magnetUri
79 else expect(transcodedVideo.magnetUri).to.equal(magnetUri)
80 }
81 })
82
83 it('Should run a import job on video 2 with the same resolution and a different extension', async function () {
84 const env = getEnvCli(servers[1])
85 await execCLI(`${env} npm run create-import-video-file-job -- -v ${video2UUID} -i server/tests/fixtures/video_short.ogv`)
86
87 await waitJobs(servers)
88
89 let magnetUri: string
90 for (const server of servers) {
91 const { data: videos } = (await getVideosList(server.url)).body
92 expect(videos).to.have.lengthOf(2)
93
94 const video = videos.find(({ uuid }) => uuid === video2UUID)
95 const videoDetail: VideoDetails = (await getVideo(server.url, video.uuid)).body
96
97 expect(videoDetail.files).to.have.lengthOf(4)
98 const [ originalVideo, transcodedVideo420, transcodedVideo320, transcodedVideo240 ] = videoDetail.files
99 assertVideoProperties(originalVideo, 720, 'ogv', 140849)
100 assertVideoProperties(transcodedVideo420, 480, 'mp4')
101 assertVideoProperties(transcodedVideo320, 360, 'mp4')
102 assertVideoProperties(transcodedVideo240, 240, 'mp4')
103
104 if (!magnetUri) magnetUri = originalVideo.magnetUri
105 else expect(originalVideo.magnetUri).to.equal(magnetUri)
106 }
107 })
108
109 it('Should run a import job on video 2 with the same resolution and the same extension', async function () {
110 const env = getEnvCli(servers[0])
111 await execCLI(`${env} npm run create-import-video-file-job -- -v ${video1UUID} -i server/tests/fixtures/video_short2.webm`)
112
113 await waitJobs(servers)
114
115 let magnetUri: string
116 for (const server of servers) {
117 const { data: videos } = (await getVideosList(server.url)).body
118 expect(videos).to.have.lengthOf(2)
119
120 const video = videos.find(({ uuid }) => uuid === video1UUID)
121 const videoDetail: VideoDetails = (await getVideo(server.url, video.uuid)).body
122
123 expect(videoDetail.files).to.have.lengthOf(2)
124 const [ video720, video480 ] = videoDetail.files
125 assertVideoProperties(video720, 720, 'webm', 942961)
126 assertVideoProperties(video480, 480, 'webm', 69217)
127
128 if (!magnetUri) magnetUri = video720.magnetUri
129 else expect(video720.magnetUri).to.equal(magnetUri)
130 }
131 })
132
133 after(async function () {
134 await cleanupTests(servers)
135 })
136 })