X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=server%2Ftests%2Fapi%2FsinglePod.js;h=1a53ada3ace5d15256793a51f12ba202f5536dc6;hb=a877d5acc5c52b8667c65f725bbca9a52e40ec48;hp=e2999530eab334b5f5918ccc404ea5502467ac23;hpb=3a8a8b51228070d8e6a01ea6e460534aa0a20efc;p=github%2FChocobozzz%2FPeerTube.git diff --git a/server/tests/api/singlePod.js b/server/tests/api/singlePod.js index e2999530e..1a53ada3a 100644 --- a/server/tests/api/singlePod.js +++ b/server/tests/api/singlePod.js @@ -14,7 +14,8 @@ const utils = require('./utils') describe('Test a single pod', function () { let server = null - let video_id = -1 + let videoId = -1 + let videosListBase = null before(function (done) { this.timeout(20000) @@ -32,7 +33,7 @@ describe('Test a single pod', function () { function (next) { utils.loginAndGetAccessToken(server, function (err, token) { if (err) throw err - server.access_token = token + server.accessToken = token next() }) }, @@ -55,7 +56,7 @@ describe('Test a single pod', function () { 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) + utils.uploadVideo(server.url, server.accessToken, 'my super name', 'my super description', 'video_short.webm', done) }) it('Should seed the uploaded video', function (done) { @@ -75,15 +76,22 @@ describe('Test a single pod', function () { expect(video.magnetUri).to.exist expect(video.author).to.equal('root') expect(video.isLocal).to.be.true + expect(utils.dateIsValid(video.createdDate)).to.be.true - video_id = video.id + utils.testImage(server.url, 'video_short.webm', video.thumbnailPath, function (err, test) { + if (err) throw err + expect(test).to.equal(true) - 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('') + videoId = video.id - done() + 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('') + + // We remove it because we'll add it again + webtorrent.remove(video.magnetUri, done) + }) }) }) }) @@ -92,7 +100,7 @@ describe('Test a single pod', function () { // Yes, this could be long this.timeout(60000) - utils.getVideo(server.url, video_id, function (err, res) { + utils.getVideo(server.url, videoId, function (err, res) { if (err) throw err const video = res.body @@ -102,13 +110,19 @@ describe('Test a single pod', function () { expect(video.magnetUri).to.exist expect(video.author).to.equal('root') expect(video.isLocal).to.be.true + expect(utils.dateIsValid(video.createdDate)).to.be.true - 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('') + utils.testImage(server.url, 'video_short.webm', video.thumbnailPath, function (err, test) { + if (err) throw err + expect(test).to.equal(true) - done() + 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() + }) }) }) }) @@ -126,8 +140,14 @@ describe('Test a single pod', function () { expect(video.podUrl).to.equal('http://localhost:9001') expect(video.author).to.equal('root') expect(video.isLocal).to.be.true + expect(utils.dateIsValid(video.createdDate)).to.be.true - done() + utils.testImage(server.url, 'video_short.webm', video.thumbnailPath, function (err, test) { + if (err) throw err + expect(test).to.equal(true) + + done() + }) }) }) @@ -143,7 +163,7 @@ describe('Test a single pod', function () { }) it('Should remove the video', function (done) { - utils.removeVideo(server.url, server.access_token, video_id, function (err) { + utils.removeVideo(server.url, server.accessToken, videoId, function (err) { if (err) throw err fs.readdir(pathUtils.join(__dirname, '../../../test1/uploads/'), function (err, files) { @@ -172,8 +192,8 @@ describe('Test a single pod', function () { '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) + async.each(videos, function (video, callbackEach) { + utils.uploadVideo(server.url, server.accessToken, video + ' name', video + ' description', video, callbackEach) }, done) }) @@ -185,13 +205,143 @@ describe('Test a single pod', function () { 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) + const videosByName = keyBy(videos, 'name') + expect(videosByName['video_short.mp4 name'].duration).to.equal(5) + expect(videosByName['video_short.ogv name'].duration).to.equal(5) + expect(videosByName['video_short.webm name'].duration).to.equal(5) + expect(videosByName['video_short1.webm name'].duration).to.equal(10) + expect(videosByName['video_short2.webm name'].duration).to.equal(5) + expect(videosByName['video_short3.webm name'].duration).to.equal(5) + + done() + }) + }) + + it('Should have the correct thumbnails', function (done) { + utils.getVideosList(server.url, function (err, res) { + if (err) throw err + + const videos = res.body + // For the next test + videosListBase = videos + + async.each(videos, function (video, callbackEach) { + if (err) throw err + const videoName = video.name.replace(' name', '') + + utils.testImage(server.url, videoName, video.thumbnailPath, function (err, test) { + if (err) throw err + + expect(test).to.equal(true) + callbackEach() + }) + }, done) + }) + }) + + it('Should list only the two first videos', function (done) { + utils.getVideosListPagination(server.url, 0, 2, function (err, res) { + if (err) throw err + + const videos = res.body + expect(videos.length).to.equal(2) + expect(videos[0].name === videosListBase[0].name) + expect(videos[1].name === videosListBase[1].name) + + done() + }) + }) + + it('Should list only the next three videos', function (done) { + utils.getVideosListPagination(server.url, 2, 3, function (err, res) { + if (err) throw err + + const videos = res.body + expect(videos.length).to.equal(4) + expect(videos[0].name === videosListBase[2].name) + expect(videos[1].name === videosListBase[3].name) + expect(videos[2].name === videosListBase[4].name) + + done() + }) + }) + + it('Should list the last video', function (done) { + utils.getVideosListPagination(server.url, 5, 6, function (err, res) { + if (err) throw err + + const videos = res.body + expect(videos.length).to.equal(1) + expect(videos[0].name === videosListBase[5].name) + + done() + }) + }) + + it('Should search the first video', function (done) { + utils.searchVideoWithPagination(server.url, 'webm', 0, 1, function (err, res) { + if (err) throw err + + const videos = res.body + expect(videos.length).to.equal(1) + expect(videos[0].name === 'video_short.webm name') + + done() + }) + }) + + it('Should search the last two videos', function (done) { + utils.searchVideoWithPagination(server.url, 'webm', 2, 2, function (err, res) { + if (err) throw err + + const videos = res.body + expect(videos.length).to.equal(2) + expect(videos[0].name === 'video_short2.webm name') + expect(videos[1].name === 'video_short3.webm name') + + done() + }) + }) + + it('Should search all the videos', function (done) { + utils.searchVideoWithPagination(server.url, 'webm', 0, 15, function (err, res) { + if (err) throw err + + const videos = res.body + expect(videos.length).to.equal(4) + + done() + }) + }) + + it('Should list and sort by name in descending order', function (done) { + utils.getVideosListSort(server.url, '-name', function (err, res) { + if (err) throw err + + const videos = res.body + expect(videos.length).to.equal(6) + expect(videos[5].name === 'video_short.mp4 name') + expect(videos[4].name === 'video_short.ogv name') + expect(videos[3].name === 'video_short.webm name') + expect(videos[2].name === 'video_short1.webm name') + expect(videos[1].name === 'video_short2.webm name') + expect(videos[0].name === 'video_short3.webm name') + + done() + }) + }) + + it('Should search and sort by name in ascending order', function (done) { + utils.searchVideoWithSort(server.url, 'webm', 'name', function (err, res) { + if (err) throw err + + const videos = res.body + expect(videos.length).to.equal(4) + + expect(videos[0].name === 'video_short.webm name') + expect(videos[1].name === 'video_short1.webm name') + expect(videos[2].name === 'video_short2.webm name') + expect(videos[3].name === 'video_short3.webm name') done() })