2 import { expect } from 'chai'
3 import { writeFile } from 'fs-extra'
4 import { basename, join } from 'path'
5 import { Video, VideoDetails } from '@shared/models'
10 flushAndRunMultipleServers,
14 setAccessTokensToServers,
17 } from '../../../shared/extra-utils'
18 import { HttpStatusCode } from '@shared/core-utils'
20 async function testThumbnail (server: ServerInfo, videoId: number | string) {
21 const res = await getVideo(server.url, videoId)
22 const video: VideoDetails = res.body
24 const res1 = await makeRawRequest(join(server.url, video.thumbnailPath), HttpStatusCode.OK_200)
25 expect(res1.body).to.not.have.lengthOf(0)
27 const res2 = await makeRawRequest(join(server.url, video.thumbnailPath), HttpStatusCode.OK_200)
28 expect(res2.body).to.not.have.lengthOf(0)
31 describe('Test regenerate thumbnails script', function () {
32 let servers: ServerInfo[]
36 let remoteVideo: Video
38 let thumbnail1Path: string
39 let thumbnailRemotePath: string
41 before(async function () {
44 servers = await flushAndRunMultipleServers(2)
45 await setAccessTokensToServers(servers)
47 await doubleFollow(servers[0], servers[1])
50 const videoUUID1 = (await uploadVideoAndGetId({ server: servers[0], videoName: 'video 1' })).uuid
51 video1 = await (getVideo(servers[0].url, videoUUID1).then(res => res.body))
53 thumbnail1Path = join(buildServerDirectory(servers[0], 'thumbnails'), basename(video1.thumbnailPath))
55 const videoUUID2 = (await uploadVideoAndGetId({ server: servers[0], videoName: 'video 2' })).uuid
56 video2 = await (getVideo(servers[0].url, videoUUID2).then(res => res.body))
60 const videoUUID = (await uploadVideoAndGetId({ server: servers[1], videoName: 'video 3' })).uuid
61 await waitJobs(servers)
63 remoteVideo = await (getVideo(servers[0].url, videoUUID).then(res => res.body))
65 thumbnailRemotePath = join(buildServerDirectory(servers[0], 'thumbnails'), basename(remoteVideo.thumbnailPath))
68 await writeFile(thumbnail1Path, '')
69 await writeFile(thumbnailRemotePath, '')
72 it('Should have empty thumbnails', async function () {
74 const res = await makeRawRequest(join(servers[0].url, video1.thumbnailPath), HttpStatusCode.OK_200)
75 expect(res.body).to.have.lengthOf(0)
79 const res = await makeRawRequest(join(servers[0].url, video2.thumbnailPath), HttpStatusCode.OK_200)
80 expect(res.body).to.not.have.lengthOf(0)
84 const res = await makeRawRequest(join(servers[0].url, remoteVideo.thumbnailPath), HttpStatusCode.OK_200)
85 expect(res.body).to.have.lengthOf(0)
89 it('Should regenerate local thumbnails from the CLI', async function () {
92 await servers[0].cliCommand.execWithEnv(`npm run regenerate-thumbnails`)
95 it('Should have generated new thumbnail files', async function () {
96 await testThumbnail(servers[0], video1.uuid)
97 await testThumbnail(servers[0], video2.uuid)
99 const res = await makeRawRequest(join(servers[0].url, remoteVideo.thumbnailPath), HttpStatusCode.OK_200)
100 expect(res.body).to.have.lengthOf(0)
103 it('Should have deleted old thumbnail files', async function () {
105 await makeRawRequest(join(servers[0].url, video1.thumbnailPath), HttpStatusCode.NOT_FOUND_404)
109 await makeRawRequest(join(servers[0].url, video2.thumbnailPath), HttpStatusCode.NOT_FOUND_404)
113 const res = await makeRawRequest(join(servers[0].url, remoteVideo.thumbnailPath), HttpStatusCode.OK_200)
114 expect(res.body).to.have.lengthOf(0)
118 after(async function () {
119 await cleanupTests(servers)