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
|
# If enabled, the video will be transcoded to mp4 (x264) with "faststart" flag
|
||||||
# Uses a lot of CPU!
|
# Uses a lot of CPU!
|
||||||
transcoding:
|
transcoding:
|
||||||
enabled: true
|
enabled: false
|
||||||
threads: 2
|
threads: 2
|
||||||
|
|
|
@ -21,3 +21,6 @@ admin:
|
||||||
|
|
||||||
signup:
|
signup:
|
||||||
enabled: false
|
enabled: false
|
||||||
|
|
||||||
|
transcoding:
|
||||||
|
enabled: true
|
||||||
|
|
|
@ -18,6 +18,3 @@ storage:
|
||||||
|
|
||||||
admin:
|
admin:
|
||||||
email: 'admin6@example.com'
|
email: 'admin6@example.com'
|
||||||
|
|
||||||
transcoding:
|
|
||||||
enabled: true
|
|
||||||
|
|
|
@ -11,3 +11,4 @@ require('./video-blacklist')
|
||||||
require('./multiple-pods')
|
require('./multiple-pods')
|
||||||
require('./requests')
|
require('./requests')
|
||||||
require('./friends-advanced')
|
require('./friends-advanced')
|
||||||
|
require('./video-transcoder')
|
||||||
|
|
|
@ -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