From 13e13377918b65c30b9334920fef4b43e70b964e Mon Sep 17 00:00:00 2001 From: Chocobozzz Date: Thu, 22 Jul 2021 08:46:55 +0200 Subject: [PATCH] Speed up plugin transcoding tests --- scripts/benchmark.ts | 6 +- scripts/ci.sh | 2 +- .../main.js | 7 +- .../tests/fixtures/video_very_short_240p.mp4 | Bin 0 -> 9352 bytes server/tests/plugins/plugin-transcoding.ts | 174 +++++++++--------- 5 files changed, 97 insertions(+), 92 deletions(-) create mode 100644 server/tests/fixtures/video_very_short_240p.mp4 diff --git a/scripts/benchmark.ts b/scripts/benchmark.ts index 83b932909..5dcf9b01b 100644 --- a/scripts/benchmark.ts +++ b/scripts/benchmark.ts @@ -1,10 +1,10 @@ +import { registerTSPaths } from '../server/helpers/register-ts-paths' +registerTSPaths() + import * as autocannon from 'autocannon' import { writeJson } from 'fs-extra' import { createSingleServer, killallServers, PeerTubeServer, setAccessTokensToServers } from '@shared/extra-utils' import { Video, VideoPrivacy } from '@shared/models' -import { registerTSPaths } from '../server/helpers/register-ts-paths' - -registerTSPaths() let server: PeerTubeServer let video: Video diff --git a/scripts/ci.sh b/scripts/ci.sh index 7862888b8..71b1be53b 100755 --- a/scripts/ci.sh +++ b/scripts/ci.sh @@ -77,7 +77,7 @@ elif [ "$1" = "api-2" ]; then serverFiles=$(findTestFiles ./dist/server/tests/api/server) usersFiles=$(findTestFiles ./dist/server/tests/api/users) - MOCHA_PARALLEL=true runTest "$1" 3 $serverFiles $usersFiles $liveFiles + MOCHA_PARALLEL=true runTest "$1" 3 $liveFiles $serverFiles $usersFiles elif [ "$1" = "api-3" ]; then npm run build:server diff --git a/server/tests/fixtures/peertube-plugin-test-transcoding-one/main.js b/server/tests/fixtures/peertube-plugin-test-transcoding-one/main.js index 59b136947..c4ae777f5 100644 --- a/server/tests/fixtures/peertube-plugin-test-transcoding-one/main.js +++ b/server/tests/fixtures/peertube-plugin-test-transcoding-one/main.js @@ -18,12 +18,12 @@ async function register ({ transcodingManager }) { const builder = (options) => { return { outputOptions: [ - '-r:' + options.streamNum + ' 5' + '-r:' + options.streamNum + ' 50' ] } } - transcodingManager.addLiveProfile('libx264', 'low-live', builder) + transcodingManager.addLiveProfile('libx264', 'high-live', builder) } } @@ -45,7 +45,7 @@ async function register ({ transcodingManager }) { const builder = () => { return { inputOptions: [ - '-r 5' + '-r 50' ] } } @@ -82,7 +82,6 @@ async function register ({ transcodingManager }) { } } - async function unregister () { return } diff --git a/server/tests/fixtures/video_very_short_240p.mp4 b/server/tests/fixtures/video_very_short_240p.mp4 new file mode 100644 index 0000000000000000000000000000000000000000..95b6be92a1dd8d75fe5beb36729f2cca259fd6dc GIT binary patch literal 9352 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 literal 0 HcmV?d00001 diff --git a/server/tests/plugins/plugin-transcoding.ts b/server/tests/plugins/plugin-transcoding.ts index 0bf1fab01..c14c34c7e 100644 --- a/server/tests/plugins/plugin-transcoding.ts +++ b/server/tests/plugins/plugin-transcoding.ts @@ -110,119 +110,125 @@ describe('Test transcoding plugins', function () { const config = await server.config.getConfig() expect(config.transcoding.availableProfiles).to.have.members([ 'default', 'low-vod', 'input-options-vod', 'bad-scale-vod' ]) - expect(config.live.transcoding.availableProfiles).to.have.members([ 'default', 'low-live', 'input-options-live', 'bad-scale-live' ]) + expect(config.live.transcoding.availableProfiles).to.have.members([ 'default', 'high-live', 'input-options-live', 'bad-scale-live' ]) }) - it('Should not use the plugin profile if not chosen by the admin', async function () { - this.timeout(240000) + describe('VOD', function () { - const videoUUID = (await server.videos.quickUpload({ name: 'video' })).uuid - await waitJobs([ server ]) + it('Should not use the plugin profile if not chosen by the admin', async function () { + this.timeout(240000) - await checkVideoFPS(videoUUID, 'above', 20) + const videoUUID = (await server.videos.quickUpload({ name: 'video' })).uuid + await waitJobs([ server ]) + + await checkVideoFPS(videoUUID, 'above', 20) + }) + + it('Should use the vod profile', async function () { + this.timeout(240000) + + await updateConf(server, 'low-vod', 'default') + + const videoUUID = (await server.videos.quickUpload({ name: 'video' })).uuid + await waitJobs([ server ]) + + await checkVideoFPS(videoUUID, 'below', 12) + }) + + it('Should apply input options in vod profile', async function () { + this.timeout(240000) + + await updateConf(server, 'input-options-vod', 'default') + + const videoUUID = (await server.videos.quickUpload({ name: 'video' })).uuid + await waitJobs([ server ]) + + await checkVideoFPS(videoUUID, 'below', 6) + }) + + it('Should apply the scale filter in vod profile', async function () { + this.timeout(240000) + + await updateConf(server, 'bad-scale-vod', 'default') + + const videoUUID = (await server.videos.quickUpload({ name: 'video' })).uuid + await waitJobs([ server ]) + + // Transcoding failed + const video = await server.videos.get({ id: videoUUID }) + expect(video.files).to.have.lengthOf(1) + expect(video.streamingPlaylists).to.have.lengthOf(0) + }) }) - it('Should use the vod profile', async function () { - this.timeout(240000) + describe('Live', function () { - await updateConf(server, 'low-vod', 'default') + it('Should not use the plugin profile if not chosen by the admin', async function () { + this.timeout(240000) - const videoUUID = (await server.videos.quickUpload({ name: 'video' })).uuid - await waitJobs([ server ]) + const liveVideoId = await createLiveWrapper(server) - await checkVideoFPS(videoUUID, 'below', 12) - }) + await server.live.sendRTMPStreamInVideo({ videoId: liveVideoId, fixtureName: 'video_very_short_240p.mp4' }) + await server.live.waitUntilPublished({ videoId: liveVideoId }) + await waitJobs([ server ]) - it('Should apply input options in vod profile', async function () { - this.timeout(240000) + await checkLiveFPS(liveVideoId, 'above', 20) + }) - await updateConf(server, 'input-options-vod', 'default') + it('Should use the live profile', async function () { + this.timeout(240000) - const videoUUID = (await server.videos.quickUpload({ name: 'video' })).uuid - await waitJobs([ server ]) + await updateConf(server, 'low-vod', 'high-live') - await checkVideoFPS(videoUUID, 'below', 6) - }) + const liveVideoId = await createLiveWrapper(server) - it('Should apply the scale filter in vod profile', async function () { - this.timeout(240000) + await server.live.sendRTMPStreamInVideo({ videoId: liveVideoId, fixtureName: 'video_very_short_240p.mp4' }) + await server.live.waitUntilPublished({ videoId: liveVideoId }) + await waitJobs([ server ]) - await updateConf(server, 'bad-scale-vod', 'default') + await checkLiveFPS(liveVideoId, 'above', 45) + }) - const videoUUID = (await server.videos.quickUpload({ name: 'video' })).uuid - await waitJobs([ server ]) + it('Should apply the input options on live profile', async function () { + this.timeout(240000) - // Transcoding failed - const video = await server.videos.get({ id: videoUUID }) - expect(video.files).to.have.lengthOf(1) - expect(video.streamingPlaylists).to.have.lengthOf(0) - }) + await updateConf(server, 'low-vod', 'input-options-live') - it('Should not use the plugin profile if not chosen by the admin', async function () { - this.timeout(240000) + const liveVideoId = await createLiveWrapper(server) - const liveVideoId = await createLiveWrapper(server) + await server.live.sendRTMPStreamInVideo({ videoId: liveVideoId, fixtureName: 'video_very_short_240p.mp4' }) + await server.live.waitUntilPublished({ videoId: liveVideoId }) + await waitJobs([ server ]) - await server.live.sendRTMPStreamInVideo({ videoId: liveVideoId, fixtureName: 'video_short2.webm' }) - await server.live.waitUntilPublished({ videoId: liveVideoId }) - await waitJobs([ server ]) + await checkLiveFPS(liveVideoId, 'above', 45) + }) - await checkLiveFPS(liveVideoId, 'above', 20) - }) + it('Should apply the scale filter name on live profile', async function () { + this.timeout(240000) - it('Should use the live profile', async function () { - this.timeout(240000) + await updateConf(server, 'low-vod', 'bad-scale-live') - await updateConf(server, 'low-vod', 'low-live') + const liveVideoId = await createLiveWrapper(server) - const liveVideoId = await createLiveWrapper(server) + const command = await server.live.sendRTMPStreamInVideo({ videoId: liveVideoId, fixtureName: 'video_very_short_240p.mp4' }) + await testFfmpegStreamError(command, true) + }) - await server.live.sendRTMPStreamInVideo({ videoId: liveVideoId, fixtureName: 'video_short2.webm' }) - await server.live.waitUntilPublished({ videoId: liveVideoId }) - await waitJobs([ server ]) + it('Should default to the default profile if the specified profile does not exist', async function () { + this.timeout(240000) - await checkLiveFPS(liveVideoId, 'below', 12) - }) + await server.plugins.uninstall({ npmName: 'peertube-plugin-test-transcoding-one' }) - it('Should apply the input options on live profile', async function () { - this.timeout(240000) + const config = await server.config.getConfig() - await updateConf(server, 'low-vod', 'input-options-live') + expect(config.transcoding.availableProfiles).to.deep.equal([ 'default' ]) + expect(config.live.transcoding.availableProfiles).to.deep.equal([ 'default' ]) - const liveVideoId = await createLiveWrapper(server) + const videoUUID = (await server.videos.quickUpload({ name: 'video', fixture: 'video_very_short_240p.mp4' })).uuid + await waitJobs([ server ]) - await server.live.sendRTMPStreamInVideo({ videoId: liveVideoId, fixtureName: 'video_short2.webm' }) - await server.live.waitUntilPublished({ videoId: liveVideoId }) - await waitJobs([ server ]) - - await checkLiveFPS(liveVideoId, 'below', 6) - }) - - it('Should apply the scale filter name on live profile', async function () { - this.timeout(240000) - - await updateConf(server, 'low-vod', 'bad-scale-live') - - const liveVideoId = await createLiveWrapper(server) - - const command = await server.live.sendRTMPStreamInVideo({ videoId: liveVideoId, fixtureName: 'video_short2.webm' }) - await testFfmpegStreamError(command, true) - }) - - it('Should default to the default profile if the specified profile does not exist', async function () { - this.timeout(240000) - - await server.plugins.uninstall({ npmName: 'peertube-plugin-test-transcoding-one' }) - - const config = await server.config.getConfig() - - expect(config.transcoding.availableProfiles).to.deep.equal([ 'default' ]) - expect(config.live.transcoding.availableProfiles).to.deep.equal([ 'default' ]) - - const videoUUID = (await server.videos.quickUpload({ name: 'video' })).uuid - await waitJobs([ server ]) - - await checkVideoFPS(videoUUID, 'above', 20) + await checkVideoFPS(videoUUID, 'above', 20) + }) }) }) @@ -238,7 +244,7 @@ describe('Test transcoding plugins', function () { it('Should use the new vod encoders', async function () { this.timeout(240000) - const videoUUID = (await server.videos.quickUpload({ name: 'video', fixture: 'video_short_240p.mp4' })).uuid + const videoUUID = (await server.videos.quickUpload({ name: 'video', fixture: 'video_very_short_240p.mp4' })).uuid await waitJobs([ server ]) const path = server.servers.buildDirectory(join('videos', videoUUID + '-240.mp4'))