Server: add tests to video transcoder

pull/71/head
Chocobozzz 2017-05-04 21:51:00 +02:00
parent 227d02fead
commit fce897f326
5 changed files with 120 additions and 4 deletions

View File

@ -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

View File

@ -21,3 +21,6 @@ admin:
signup:
enabled: false
transcoding:
enabled: true

View File

@ -18,6 +18,3 @@ storage:
admin:
email: 'admin6@example.com'
transcoding:
enabled: true

View File

@ -11,3 +11,4 @@ require('./video-blacklist')
require('./multiple-pods')
require('./requests')
require('./friends-advanced')
require('./video-transcoder')

View 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()
}
})
})