allow limiting video-comments rss feeds to an account or video channel
[oweals/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 })