PeerTube/server/tests/api/friendsBasic.js

184 lines
5.0 KiB
JavaScript
Raw Normal View History

'use strict'
2015-06-09 10:41:40 -05:00
2016-03-16 16:29:27 -05:00
const async = require('async')
const chai = require('chai')
const expect = chai.expect
const request = require('supertest')
2015-06-09 10:41:40 -05:00
2016-03-16 16:29:27 -05:00
const utils = require('./utils')
2015-06-09 10:41:40 -05:00
describe('Test basic friends', function () {
let servers = []
2016-01-24 09:08:09 -06:00
function testMadeFriends (servers, server_to_test, callback) {
2016-03-16 16:29:27 -05:00
const friends = []
for (let i = 0; i < servers.length; i++) {
if (servers[i].url === server_to_test.url) continue
friends.push(servers[i].url)
}
utils.getFriendsList(server_to_test.url, function (err, res) {
if (err) throw err
2016-03-16 16:29:27 -05:00
const result = res.body
const result_urls = [ result[0].url, result[1].url ]
expect(result).to.be.an('array')
expect(result.length).to.equal(2)
expect(result_urls[0]).to.not.equal(result_urls[1])
const error_string = 'Friends url do not correspond for ' + server_to_test.url
expect(friends).to.contain(result_urls[0], error_string)
expect(friends).to.contain(result_urls[1], error_string)
callback()
})
}
// ---------------------------------------------------------------
before(function (done) {
this.timeout(20000)
utils.flushAndRunMultipleServers(3, function (servers_run, urls_run) {
servers = servers_run
done()
})
})
it('Should not have friends', function (done) {
async.each(servers, function (server, callback) {
utils.getFriendsList(server.url, function (err, res) {
if (err) throw err
2016-03-16 16:29:27 -05:00
const result = res.body
expect(result).to.be.an('array')
expect(result.length).to.equal(0)
callback()
})
}, done)
})
it('Should make friends', function (done) {
this.timeout(10000)
2016-03-16 16:29:27 -05:00
const path = '/api/v1/pods/makefriends'
async.series([
// The second pod make friend with the third
function (next) {
request(servers[1].url)
.get(path)
.set('Accept', 'application/json')
.expect(204)
.end(next)
},
// Wait for the request between pods
function (next) {
setTimeout(next, 1000)
},
// The second pod should have the third as a friend
function (next) {
utils.getFriendsList(servers[1].url, function (err, res) {
if (err) throw err
2015-06-09 10:41:40 -05:00
2016-03-16 16:29:27 -05:00
const result = res.body
expect(result).to.be.an('array')
expect(result.length).to.equal(1)
expect(result[0].url).to.be.equal(servers[2].url)
2015-06-09 10:41:40 -05:00
next()
})
},
// Same here, the third pod should have the second pod as a friend
function (next) {
utils.getFriendsList(servers[2].url, function (err, res) {
2015-06-09 10:41:40 -05:00
if (err) throw err
2016-03-16 16:29:27 -05:00
const result = res.body
2015-06-09 10:41:40 -05:00
expect(result).to.be.an('array')
expect(result.length).to.equal(1)
expect(result[0].url).to.be.equal(servers[1].url)
next()
2015-06-09 10:41:40 -05:00
})
},
// Finally the first pod make friend with the second pod
function (next) {
request(servers[0].url)
.get(path)
.set('Accept', 'application/json')
.expect(204)
.end(next)
},
// Wait for the request between pods
function (next) {
setTimeout(next, 1000)
}
],
// Now each pod should be friend with the other ones
function (err) {
if (err) throw err
async.each(servers, function (server, callback) {
testMadeFriends(servers, server, callback)
2016-01-24 09:08:09 -06:00
}, done)
2015-06-09 10:41:40 -05:00
})
})
2015-06-09 10:41:40 -05:00
it('Should not be allowed to make friend again', function (done) {
utils.makeFriends(servers[1].url, 409, done)
})
2015-06-09 10:41:40 -05:00
it('Should quit friends of pod 2', function (done) {
async.series([
// Pod 1 quit friends
function (next) {
utils.quitFriends(servers[1].url, next)
},
// Pod 1 should not have friends anymore
function (next) {
utils.getFriendsList(servers[1].url, function (err, res) {
if (err) throw err
2015-06-09 10:41:40 -05:00
2016-03-16 16:29:27 -05:00
const result = res.body
expect(result).to.be.an('array')
expect(result.length).to.equal(0)
next()
})
},
// Other pods shouldn't have pod 1 too
function (next) {
async.each([ servers[0].url, servers[2].url ], function (url, callback) {
utils.getFriendsList(url, function (err, res) {
2016-01-24 09:08:09 -06:00
if (err) throw err
2016-03-16 16:29:27 -05:00
const result = res.body
2016-01-24 09:08:09 -06:00
expect(result).to.be.an('array')
expect(result.length).to.equal(1)
expect(result[0].url).not.to.be.equal(servers[1].url)
callback()
2016-01-24 09:08:09 -06:00
})
}, next)
}
], done)
})
it('Should allow pod 2 to make friend again', function (done) {
utils.makeFriends(servers[1].url, function () {
async.each(servers, function (server, callback) {
testMadeFriends(servers, server, callback)
}, done)
})
})
after(function (done) {
servers.forEach(function (server) {
process.kill(-server.app.pid)
})
2015-06-09 10:41:40 -05:00
if (this.ok) {
utils.flushTests(done)
} else {
done()
}
2015-06-09 10:41:40 -05:00
})
})