mirror of
https://github.com/Chocobozzz/PeerTube.git
synced 2024-11-22 08:46:54 -06:00
Server: add tests to video transcoder
This commit is contained in:
parent
227d02fead
commit
fce897f326
@ -32,5 +32,5 @@ signup:
|
||||
# If enabled, the video will be transcoded to mp4 (x264) with "faststart" flag
|
||||
# Uses a lot of CPU!
|
||||
transcoding:
|
||||
enabled: true
|
||||
enabled: false
|
||||
threads: 2
|
||||
|
@ -21,3 +21,6 @@ admin:
|
||||
|
||||
signup:
|
||||
enabled: false
|
||||
|
||||
transcoding:
|
||||
enabled: true
|
||||
|
@ -18,6 +18,3 @@ storage:
|
||||
|
||||
admin:
|
||||
email: 'admin6@example.com'
|
||||
|
||||
transcoding:
|
||||
enabled: true
|
||||
|
@ -11,3 +11,4 @@ require('./video-blacklist')
|
||||
require('./multiple-pods')
|
||||
require('./requests')
|
||||
require('./friends-advanced')
|
||||
require('./video-transcoder')
|
||||
|
115
server/tests/api/video-transcoder.js
Normal file
115
server/tests/api/video-transcoder.js
Normal file
@ -0,0 +1,115 @@
|
||||
/* eslint-disable no-unused-expressions */
|
||||
|
||||
'use strict'
|
||||
|
||||
const chai = require('chai')
|
||||
const each = require('async/each')
|
||||
const expect = chai.expect
|
||||
const series = require('async/series')
|
||||
const webtorrent = new (require('webtorrent'))()
|
||||
|
||||
const loginUtils = require('../utils/login')
|
||||
const serversUtils = require('../utils/servers')
|
||||
const videosUtils = require('../utils/videos')
|
||||
|
||||
describe('Test video blacklists', function () {
|
||||
let servers = []
|
||||
|
||||
before(function (done) {
|
||||
this.timeout(30000)
|
||||
|
||||
series([
|
||||
// Run servers
|
||||
function (next) {
|
||||
serversUtils.flushAndRunMultipleServers(2, function (serversRun) {
|
||||
servers = serversRun
|
||||
next()
|
||||
})
|
||||
},
|
||||
// Get the access tokens
|
||||
function (next) {
|
||||
each(servers, function (server, callbackEach) {
|
||||
loginUtils.loginAndGetAccessToken(server, function (err, accessToken) {
|
||||
if (err) return callbackEach(err)
|
||||
|
||||
server.accessToken = accessToken
|
||||
callbackEach()
|
||||
})
|
||||
}, next)
|
||||
}
|
||||
], done)
|
||||
})
|
||||
|
||||
it('Should not transcode video on server 1', function (done) {
|
||||
this.timeout(60000)
|
||||
|
||||
const videoAttributes = {
|
||||
name: 'my super name for pod 1',
|
||||
description: 'my super description for pod 1',
|
||||
fixture: 'video_short.webm'
|
||||
}
|
||||
videosUtils.uploadVideo(servers[0].url, servers[0].accessToken, videoAttributes, function (err) {
|
||||
if (err) throw err
|
||||
|
||||
setTimeout(function () {
|
||||
videosUtils.getVideosList(servers[0].url, function (err, res) {
|
||||
if (err) throw err
|
||||
|
||||
const video = res.body.data[0]
|
||||
expect(video.magnetUri).to.match(/\.webm/)
|
||||
|
||||
webtorrent.add(video.magnetUri, function (torrent) {
|
||||
expect(torrent.files).to.exist
|
||||
expect(torrent.files.length).to.equal(1)
|
||||
expect(torrent.files[0].path).match(/\.webm$/)
|
||||
|
||||
done()
|
||||
})
|
||||
})
|
||||
}, 30000)
|
||||
})
|
||||
})
|
||||
|
||||
it('Should transcode video on server 2', function (done) {
|
||||
this.timeout(60000)
|
||||
|
||||
const videoAttributes = {
|
||||
name: 'my super name for pod 2',
|
||||
description: 'my super description for pod 2',
|
||||
fixture: 'video_short.webm'
|
||||
}
|
||||
videosUtils.uploadVideo(servers[1].url, servers[1].accessToken, videoAttributes, function (err) {
|
||||
if (err) throw err
|
||||
|
||||
setTimeout(function () {
|
||||
videosUtils.getVideosList(servers[1].url, function (err, res) {
|
||||
if (err) throw err
|
||||
|
||||
const video = res.body.data[0]
|
||||
expect(video.magnetUri).to.match(/\.mp4/)
|
||||
|
||||
webtorrent.add(video.magnetUri, function (torrent) {
|
||||
expect(torrent.files).to.exist
|
||||
expect(torrent.files.length).to.equal(1)
|
||||
expect(torrent.files[0].path).match(/\.mp4$/)
|
||||
|
||||
done()
|
||||
})
|
||||
})
|
||||
}, 30000)
|
||||
})
|
||||
})
|
||||
|
||||
after(function (done) {
|
||||
servers.forEach(function (server) {
|
||||
process.kill(-server.app.pid)
|
||||
})
|
||||
|
||||
// Keep the logs if the test failed
|
||||
if (this.ok) {
|
||||
serversUtils.flushTests(done)
|
||||
} else {
|
||||
done()
|
||||
}
|
||||
})
|
||||
})
|
Loading…
Reference in New Issue
Block a user