1
0
Fork 0

Fix tests

This commit is contained in:
Chocobozzz 2021-11-10 14:25:33 +01:00
parent 67eeec8b95
commit d78b51aa4e
No known key found for this signature in database
GPG key ID: 583A612D890159BE
3 changed files with 20 additions and 14 deletions

View file

@ -591,7 +591,9 @@ describe('Test multiple servers', function () {
}) })
describe('Should manipulate these videos', function () { describe('Should manipulate these videos', function () {
it('Should update the video 3 by asking server 3', async function () { let updatedAtMin: Date
it('Should update video 3', async function () {
this.timeout(10000) this.timeout(10000)
const attributes = { const attributes = {
@ -608,6 +610,7 @@ describe('Test multiple servers', function () {
previewfile: 'preview.jpg' previewfile: 'preview.jpg'
} }
updatedAtMin = new Date()
await servers[2].videos.update({ id: toRemove[0].id, attributes }) await servers[2].videos.update({ id: toRemove[0].id, attributes })
await waitJobs(servers) await waitJobs(servers)
@ -622,6 +625,8 @@ describe('Test multiple servers', function () {
const videoUpdated = data.find(video => video.name === 'my super video updated') const videoUpdated = data.find(video => video.name === 'my super video updated')
expect(!!videoUpdated).to.be.true expect(!!videoUpdated).to.be.true
expect(new Date(videoUpdated.updatedAt)).to.be.greaterThan(updatedAtMin)
const isLocal = server.url === 'http://localhost:' + servers[2].port const isLocal = server.url === 'http://localhost:' + servers[2].port
const checkAttributes = { const checkAttributes = {
name: 'my super video updated', name: 'my super video updated',
@ -1024,15 +1029,15 @@ describe('Test multiple servers', function () {
files: [ files: [
{ {
resolution: 720, resolution: 720,
size: 59000 size: 61000
}, },
{ {
resolution: 480, resolution: 480,
size: 34000 size: 40000
}, },
{ {
resolution: 360, resolution: 360,
size: 31000 size: 32000
}, },
{ {
resolution: 240, resolution: 240,

View file

@ -3,7 +3,7 @@
import 'mocha' import 'mocha'
import * as chai from 'chai' import * as chai from 'chai'
import { omit } from 'lodash' import { omit } from 'lodash'
import { getMaxBitrate } from '@shared/core-utils' import { getMaxBitrate, getMinLimitBitrate } from '@shared/core-utils'
import { import {
buildAbsoluteFixturePath, buildAbsoluteFixturePath,
cleanupTests, cleanupTests,
@ -583,7 +583,7 @@ describe('Test video transcoding', function () {
} }
}) })
it('Should not transcode to an higher bitrate than the original file', async function () { it('Should not transcode to an higher bitrate than the original file but above our low limit', async function () {
this.timeout(160_000) this.timeout(160_000)
const newConfig = { const newConfig = {
@ -622,7 +622,13 @@ describe('Test video transcoding', function () {
const path = servers[1].servers.buildWebTorrentFilePath(file.fileUrl) const path = servers[1].servers.buildWebTorrentFilePath(file.fileUrl)
const bitrate = await getVideoFileBitrate(path) const bitrate = await getVideoFileBitrate(path)
expect(bitrate, `${path} not below ${60_000}`).to.be.below(60_000)
const inputBitrate = 60_000
const limit = getMinLimitBitrate({ fps: 10, ratio: 1, resolution: r })
let belowValue = Math.max(inputBitrate, limit)
belowValue += belowValue * 0.20 // Apply 20% margin because bitrate control is not very precise
expect(bitrate, `${path} not below ${limit}`).to.be.below(belowValue)
} }
}) })
}) })

View file

@ -2,8 +2,6 @@
import 'mocha' import 'mocha'
import * as chai from 'chai' import * as chai from 'chai'
import { getVideoFileBitrate, getVideoFileFPS } from '@server/helpers/ffprobe-utils'
import { getMaxBitrate } from '@shared/core-utils'
import { buildAbsoluteFixturePath, CLICommand } from '@shared/extra-utils' import { buildAbsoluteFixturePath, CLICommand } from '@shared/extra-utils'
import { VideoResolution } from '../../../shared/models/videos' import { VideoResolution } from '../../../shared/models/videos'
@ -13,15 +11,12 @@ describe('Test print transcode jobs', function () {
it('Should print the correct command for each resolution', async function () { it('Should print the correct command for each resolution', async function () {
const fixturePath = buildAbsoluteFixturePath('video_short.webm') const fixturePath = buildAbsoluteFixturePath('video_short.webm')
const fps = await getVideoFileFPS(fixturePath)
const bitrate = await getVideoFileBitrate(fixturePath)
for (const resolution of [ for (const resolution of [
VideoResolution.H_720P, VideoResolution.H_720P,
VideoResolution.H_1080P VideoResolution.H_1080P
]) { ]) {
const command = await CLICommand.exec(`npm run print-transcode-command -- ${fixturePath} -r ${resolution}`) const command = await CLICommand.exec(`npm run print-transcode-command -- ${fixturePath} -r ${resolution}`)
const targetBitrate = Math.min(getMaxBitrate({ resolution, fps, ratio: 16 / 9 }), bitrate + (bitrate * 0.3))
expect(command).to.includes(`-vf scale=w=-2:h=${resolution}`) expect(command).to.includes(`-vf scale=w=-2:h=${resolution}`)
expect(command).to.includes(`-y -acodec aac -vcodec libx264`) expect(command).to.includes(`-y -acodec aac -vcodec libx264`)
@ -31,8 +26,8 @@ describe('Test print transcode jobs', function () {
expect(command).to.includes('-r 25') expect(command).to.includes('-r 25')
expect(command).to.includes('-level:v 3.1') expect(command).to.includes('-level:v 3.1')
expect(command).to.includes('-g:v 50') expect(command).to.includes('-g:v 50')
expect(command).to.includes(`-maxrate ${targetBitrate}`) expect(command).to.includes(`-maxrate `)
expect(command).to.includes(`-bufsize ${targetBitrate * 2}`) expect(command).to.includes(`-bufsize `)
} }
}) })
}) })