PeerTube/server/tests/api/singlePod.js

212 lines
5.8 KiB
JavaScript
Raw Normal View History

'use strict'
2016-03-16 22:29:27 +01:00
const async = require('async')
const chai = require('chai')
const expect = chai.expect
const fs = require('fs')
2016-05-03 22:41:46 +02:00
const keyBy = require('lodash/keyBy')
2016-03-16 22:29:27 +01:00
const pathUtils = require('path')
2016-03-16 22:29:27 +01:00
const webtorrent = require(pathUtils.join(__dirname, '../../lib/webtorrent'))
webtorrent.silent = true
2016-03-16 22:29:27 +01:00
const utils = require('./utils')
describe('Test a single pod', function () {
let server = null
2016-03-16 22:29:27 +01:00
let video_id = -1
before(function (done) {
this.timeout(20000)
async.series([
function (next) {
utils.flushTests(next)
},
function (next) {
utils.runServer(1, function (server1) {
server = server1
next()
})
},
function (next) {
utils.loginAndGetAccessToken(server, function (err, token) {
if (err) throw err
server.access_token = token
next()
})
},
function (next) {
webtorrent.create({ host: 'client', port: '1' }, next)
}
], done)
})
2015-06-09 17:41:40 +02:00
it('Should not have videos', function (done) {
utils.getVideosList(server.url, function (err, res) {
if (err) throw err
2015-06-09 17:41:40 +02:00
expect(res.body).to.be.an('array')
expect(res.body.length).to.equal(0)
2015-06-09 17:41:40 +02:00
done()
2015-06-09 17:41:40 +02:00
})
})
2015-06-09 17:41:40 +02:00
it('Should upload the video', function (done) {
this.timeout(5000)
utils.uploadVideo(server.url, server.access_token, 'my super name', 'my super description', 'video_short.webm', done)
})
2015-06-09 17:41:40 +02:00
it('Should seed the uploaded video', function (done) {
// Yes, this could be long
this.timeout(60000)
2015-06-09 17:41:40 +02:00
utils.getVideosList(server.url, function (err, res) {
if (err) throw err
2015-06-09 17:41:40 +02:00
expect(res.body).to.be.an('array')
expect(res.body.length).to.equal(1)
2015-06-09 17:41:40 +02:00
2016-03-16 22:29:27 +01:00
const video = res.body[0]
expect(video.name).to.equal('my super name')
expect(video.description).to.equal('my super description')
expect(video.podUrl).to.equal('http://localhost:9001')
expect(video.magnetUri).to.exist
2016-05-03 21:03:51 +02:00
expect(video.author).to.equal('root')
expect(video.isLocal).to.be.true
2015-06-09 17:41:40 +02:00
2016-03-18 16:28:09 +01:00
video_id = video.id
webtorrent.add(video.magnetUri, function (torrent) {
expect(torrent.files).to.exist
expect(torrent.files.length).to.equal(1)
expect(torrent.files[0].path).to.exist.and.to.not.equal('')
done()
})
})
})
it('Should get the video', function (done) {
// Yes, this could be long
this.timeout(60000)
utils.getVideo(server.url, video_id, function (err, res) {
2016-03-18 16:28:09 +01:00
if (err) throw err
const video = res.body
expect(video.name).to.equal('my super name')
expect(video.description).to.equal('my super description')
expect(video.podUrl).to.equal('http://localhost:9001')
expect(video.magnetUri).to.exist
2016-05-03 21:03:51 +02:00
expect(video.author).to.equal('root')
expect(video.isLocal).to.be.true
2015-06-09 17:41:40 +02:00
webtorrent.add(video.magnetUri, function (torrent) {
expect(torrent.files).to.exist
expect(torrent.files.length).to.equal(1)
expect(torrent.files[0].path).to.exist.and.to.not.equal('')
2015-06-09 17:41:40 +02:00
done()
2015-12-06 17:09:07 +01:00
})
2015-06-09 17:41:40 +02:00
})
})
2015-06-09 17:41:40 +02:00
it('Should search the video', function (done) {
utils.searchVideo(server.url, 'my', function (err, res) {
if (err) throw err
2015-12-05 10:28:27 +01:00
expect(res.body).to.be.an('array')
expect(res.body.length).to.equal(1)
2015-12-05 10:28:27 +01:00
2016-03-16 22:29:27 +01:00
const video = res.body[0]
expect(video.name).to.equal('my super name')
expect(video.description).to.equal('my super description')
expect(video.podUrl).to.equal('http://localhost:9001')
2016-05-03 21:03:51 +02:00
expect(video.author).to.equal('root')
expect(video.isLocal).to.be.true
2015-12-05 10:28:27 +01:00
done()
2015-12-05 10:28:27 +01:00
})
})
2015-12-05 10:28:27 +01:00
it('Should not find a search', function (done) {
utils.searchVideo(server.url, 'hello', function (err, res) {
if (err) throw err
2015-12-05 10:28:27 +01:00
expect(res.body).to.be.an('array')
expect(res.body.length).to.equal(0)
2015-12-05 10:28:27 +01:00
done()
2015-12-05 10:28:27 +01:00
})
})
2015-12-05 10:28:27 +01:00
it('Should remove the video', function (done) {
utils.removeVideo(server.url, server.access_token, video_id, function (err) {
if (err) throw err
2015-11-06 17:34:15 +01:00
2016-03-07 18:53:03 +01:00
fs.readdir(pathUtils.join(__dirname, '../../../test1/uploads/'), function (err, files) {
if (err) throw err
2015-11-06 17:34:15 +01:00
expect(files.length).to.equal(0)
done()
2015-12-06 17:09:07 +01:00
})
2015-06-09 17:41:40 +02:00
})
})
2015-06-09 17:41:40 +02:00
it('Should not have videos', function (done) {
utils.getVideosList(server.url, function (err, res) {
if (err) throw err
2015-06-09 17:41:40 +02:00
expect(res.body).to.be.an('array')
expect(res.body.length).to.equal(0)
2015-06-09 17:41:40 +02:00
done()
2015-06-09 17:41:40 +02:00
})
})
2015-06-09 17:41:40 +02:00
2016-05-03 22:41:46 +02:00
it('Should upload 6 videos', function (done) {
this.timeout(25000)
const videos = [
'video_short.mp4', 'video_short.ogv', 'video_short.webm',
'video_short1.webm', 'video_short2.webm', 'video_short3.webm'
]
async.each(videos, function (video, callback_each) {
utils.uploadVideo(server.url, server.access_token, video + ' name', video + ' description', video, callback_each)
}, done)
})
it('Should have the correct durations', function (done) {
utils.getVideosList(server.url, function (err, res) {
if (err) throw err
const videos = res.body
expect(videos).to.be.an('array')
expect(videos.length).to.equal(6)
const videos_by_name = keyBy(videos, 'name')
expect(videos_by_name['video_short.mp4 name'].duration).to.equal(5)
expect(videos_by_name['video_short.ogv name'].duration).to.equal(5)
expect(videos_by_name['video_short.webm name'].duration).to.equal(5)
expect(videos_by_name['video_short1.webm name'].duration).to.equal(10)
expect(videos_by_name['video_short2.webm name'].duration).to.equal(5)
expect(videos_by_name['video_short3.webm name'].duration).to.equal(5)
done()
})
})
after(function (done) {
process.kill(-server.app.pid)
process.kill(-webtorrent.app.pid)
2015-06-09 17:41:40 +02:00
// Keep the logs if the test failed
if (this.ok) {
utils.flushTests(done)
} else {
done()
}
2015-06-09 17:41:40 +02:00
})
})