Server: create requests utils module

This commit is contained in:
Chocobozzz 2016-08-07 22:18:14 +02:00
parent 8d30905858
commit 25ed57f3db
2 changed files with 105 additions and 89 deletions

View File

@ -7,65 +7,13 @@ const request = require('supertest')
const series = require('async/series') const series = require('async/series')
const loginUtils = require('../utils/login') const loginUtils = require('../utils/login')
const requestsUtils = require('../utils/requests')
const serversUtils = require('../utils/servers') const serversUtils = require('../utils/servers')
const usersUtils = require('../utils/users') const usersUtils = require('../utils/users')
describe('Test parameters validator', function () { describe('Test parameters validator', function () {
let server = null let server = null
function makePostRequest (path, token, fields, attaches, done, statusCodeExpected) {
if (!statusCodeExpected) statusCodeExpected = 400
const req = request(server.url)
.post(path)
.set('Accept', 'application/json')
if (token) req.set('Authorization', 'Bearer ' + token)
Object.keys(fields).forEach(function (field) {
const value = fields[field]
if (Array.isArray(value)) {
for (let i = 0; i < value.length; i++) {
req.field(field + '[' + i + ']', value[i])
}
} else {
req.field(field, value)
}
})
Object.keys(attaches).forEach(function (attach) {
const value = attaches[attach]
req.attach(attach, value)
})
req.expect(statusCodeExpected, done)
}
function makePostBodyRequest (path, token, fields, done, statusCodeExpected) {
if (!statusCodeExpected) statusCodeExpected = 400
const req = request(server.url)
.post(path)
.set('Accept', 'application/json')
if (token) req.set('Authorization', 'Bearer ' + token)
req.send(fields).expect(statusCodeExpected, done)
}
function makePutBodyRequest (path, token, fields, done, statusCodeExpected) {
if (!statusCodeExpected) statusCodeExpected = 400
const req = request(server.url)
.put(path)
.set('Accept', 'application/json')
if (token) req.set('Authorization', 'Bearer ' + token)
req.send(fields).expect(statusCodeExpected, done)
}
// --------------------------------------------------------------- // ---------------------------------------------------------------
before(function (done) { before(function (done) {
@ -99,21 +47,21 @@ describe('Test parameters validator', function () {
describe('When adding a pod', function () { describe('When adding a pod', function () {
it('Should fail with nothing', function (done) { it('Should fail with nothing', function (done) {
const data = {} const data = {}
makePostBodyRequest(path, null, data, done) requestsUtils.makePostBodyRequest(server.url, path, null, data, done)
}) })
it('Should fail without public key', function (done) { it('Should fail without public key', function (done) {
const data = { const data = {
url: 'http://coucou.com' url: 'http://coucou.com'
} }
makePostBodyRequest(path, null, data, done) requestsUtils.makePostBodyRequest(server.url, path, null, data, done)
}) })
it('Should fail without an url', function (done) { it('Should fail without an url', function (done) {
const data = { const data = {
publicKey: 'mysuperpublickey' publicKey: 'mysuperpublickey'
} }
makePostBodyRequest(path, null, data, done) requestsUtils.makePostBodyRequest(server.url, path, null, data, done)
}) })
it('Should fail with an incorrect url', function (done) { it('Should fail with an incorrect url', function (done) {
@ -121,11 +69,11 @@ describe('Test parameters validator', function () {
url: 'coucou.com', url: 'coucou.com',
publicKey: 'mysuperpublickey' publicKey: 'mysuperpublickey'
} }
makePostBodyRequest(path, null, data, function () { requestsUtils.makePostBodyRequest(server.url, path, null, data, function () {
data.url = 'http://coucou' data.url = 'http://coucou'
makePostBodyRequest(path, null, data, function () { requestsUtils.makePostBodyRequest(server.url, path, null, data, function () {
data.url = 'coucou' data.url = 'coucou'
makePostBodyRequest(path, null, data, done) requestsUtils.makePostBodyRequest(server.url, path, null, data, done)
}) })
}) })
}) })
@ -135,7 +83,7 @@ describe('Test parameters validator', function () {
url: 'http://coucou.com', url: 'http://coucou.com',
publicKey: 'mysuperpublickey' publicKey: 'mysuperpublickey'
} }
makePostBodyRequest(path, null, data, done, 200) requestsUtils.makePostBodyRequest(server.url, path, null, data, done, 200)
}) })
}) })
@ -267,7 +215,7 @@ describe('Test parameters validator', function () {
it('Should fail with nothing', function (done) { it('Should fail with nothing', function (done) {
const data = {} const data = {}
const attach = {} const attach = {}
makePostRequest(path, server.accessToken, data, attach, done) requestsUtils.makePostUploadRequest(server.url, path, server.accessToken, data, attach, done)
}) })
it('Should fail without name', function (done) { it('Should fail without name', function (done) {
@ -278,7 +226,7 @@ describe('Test parameters validator', function () {
const attach = { const attach = {
'videofile': pathUtils.join(__dirname, 'fixtures', 'video_short.webm') 'videofile': pathUtils.join(__dirname, 'fixtures', 'video_short.webm')
} }
makePostRequest(path, server.accessToken, data, attach, done) requestsUtils.makePostUploadRequest(server.url, path, server.accessToken, data, attach, done)
}) })
it('Should fail with a long name', function (done) { it('Should fail with a long name', function (done) {
@ -290,7 +238,7 @@ describe('Test parameters validator', function () {
const attach = { const attach = {
'videofile': pathUtils.join(__dirname, 'fixtures', 'video_short.webm') 'videofile': pathUtils.join(__dirname, 'fixtures', 'video_short.webm')
} }
makePostRequest(path, server.accessToken, data, attach, done) requestsUtils.makePostUploadRequest(server.url, path, server.accessToken, data, attach, done)
}) })
it('Should fail without description', function (done) { it('Should fail without description', function (done) {
@ -301,7 +249,7 @@ describe('Test parameters validator', function () {
const attach = { const attach = {
'videofile': pathUtils.join(__dirname, 'fixtures', 'video_short.webm') 'videofile': pathUtils.join(__dirname, 'fixtures', 'video_short.webm')
} }
makePostRequest(path, server.accessToken, data, attach, done) requestsUtils.makePostUploadRequest(server.url, path, server.accessToken, data, attach, done)
}) })
it('Should fail with a long description', function (done) { it('Should fail with a long description', function (done) {
@ -315,7 +263,7 @@ describe('Test parameters validator', function () {
const attach = { const attach = {
'videofile': pathUtils.join(__dirname, 'fixtures', 'video_short.webm') 'videofile': pathUtils.join(__dirname, 'fixtures', 'video_short.webm')
} }
makePostRequest(path, server.accessToken, data, attach, done) requestsUtils.makePostUploadRequest(server.url, path, server.accessToken, data, attach, done)
}) })
it('Should fail without tags', function (done) { it('Should fail without tags', function (done) {
@ -326,7 +274,7 @@ describe('Test parameters validator', function () {
const attach = { const attach = {
'videofile': pathUtils.join(__dirname, 'fixtures', 'video_short.webm') 'videofile': pathUtils.join(__dirname, 'fixtures', 'video_short.webm')
} }
makePostRequest(path, server.accessToken, data, attach, done) requestsUtils.makePostUploadRequest(server.url, path, server.accessToken, data, attach, done)
}) })
it('Should fail with too many tags', function (done) { it('Should fail with too many tags', function (done) {
@ -338,7 +286,7 @@ describe('Test parameters validator', function () {
const attach = { const attach = {
'videofile': pathUtils.join(__dirname, 'fixtures', 'video_short.webm') 'videofile': pathUtils.join(__dirname, 'fixtures', 'video_short.webm')
} }
makePostRequest(path, server.accessToken, data, attach, done) requestsUtils.makePostUploadRequest(server.url, path, server.accessToken, data, attach, done)
}) })
it('Should fail with not enough tags', function (done) { it('Should fail with not enough tags', function (done) {
@ -350,7 +298,7 @@ describe('Test parameters validator', function () {
const attach = { const attach = {
'videofile': pathUtils.join(__dirname, 'fixtures', 'video_short.webm') 'videofile': pathUtils.join(__dirname, 'fixtures', 'video_short.webm')
} }
makePostRequest(path, server.accessToken, data, attach, done) requestsUtils.makePostUploadRequest(server.url, path, server.accessToken, data, attach, done)
}) })
it('Should fail with a tag length too low', function (done) { it('Should fail with a tag length too low', function (done) {
@ -362,7 +310,7 @@ describe('Test parameters validator', function () {
const attach = { const attach = {
'videofile': pathUtils.join(__dirname, 'fixtures', 'video_short.webm') 'videofile': pathUtils.join(__dirname, 'fixtures', 'video_short.webm')
} }
makePostRequest(path, server.accessToken, data, attach, done) requestsUtils.makePostUploadRequest(server.url, path, server.accessToken, data, attach, done)
}) })
it('Should fail with a tag length too big', function (done) { it('Should fail with a tag length too big', function (done) {
@ -374,7 +322,7 @@ describe('Test parameters validator', function () {
const attach = { const attach = {
'videofile': pathUtils.join(__dirname, 'fixtures', 'video_short.webm') 'videofile': pathUtils.join(__dirname, 'fixtures', 'video_short.webm')
} }
makePostRequest(path, server.accessToken, data, attach, done) requestsUtils.makePostUploadRequest(server.url, path, server.accessToken, data, attach, done)
}) })
it('Should fail with malformed tags', function (done) { it('Should fail with malformed tags', function (done) {
@ -386,7 +334,7 @@ describe('Test parameters validator', function () {
const attach = { const attach = {
'videofile': pathUtils.join(__dirname, 'fixtures', 'video_short.webm') 'videofile': pathUtils.join(__dirname, 'fixtures', 'video_short.webm')
} }
makePostRequest(path, server.accessToken, data, attach, done) requestsUtils.makePostUploadRequest(server.url, path, server.accessToken, data, attach, done)
}) })
it('Should fail without an input file', function (done) { it('Should fail without an input file', function (done) {
@ -396,7 +344,7 @@ describe('Test parameters validator', function () {
tags: [ 'tag1', 'tag2' ] tags: [ 'tag1', 'tag2' ]
} }
const attach = {} const attach = {}
makePostRequest(path, server.accessToken, data, attach, done) requestsUtils.makePostUploadRequest(server.url, path, server.accessToken, data, attach, done)
}) })
it('Should fail without an incorrect input file', function (done) { it('Should fail without an incorrect input file', function (done) {
@ -408,7 +356,7 @@ describe('Test parameters validator', function () {
const attach = { const attach = {
'videofile': pathUtils.join(__dirname, 'fixtures', 'video_short_fake.webm') 'videofile': pathUtils.join(__dirname, 'fixtures', 'video_short_fake.webm')
} }
makePostRequest(path, server.accessToken, data, attach, done) requestsUtils.makePostUploadRequest(server.url, path, server.accessToken, data, attach, done)
}) })
it('Should fail with a too big duration', function (done) { it('Should fail with a too big duration', function (done) {
@ -420,7 +368,7 @@ describe('Test parameters validator', function () {
const attach = { const attach = {
'videofile': pathUtils.join(__dirname, 'fixtures', 'video_too_long.webm') 'videofile': pathUtils.join(__dirname, 'fixtures', 'video_too_long.webm')
} }
makePostRequest(path, server.accessToken, data, attach, done) requestsUtils.makePostUploadRequest(server.url, path, server.accessToken, data, attach, done)
}) })
it('Should succeed with the correct parameters', function (done) { it('Should succeed with the correct parameters', function (done) {
@ -432,11 +380,11 @@ describe('Test parameters validator', function () {
const attach = { const attach = {
'videofile': pathUtils.join(__dirname, 'fixtures', 'video_short.webm') 'videofile': pathUtils.join(__dirname, 'fixtures', 'video_short.webm')
} }
makePostRequest(path, server.accessToken, data, attach, function () { requestsUtils.makePostUploadRequest(server.url, path, server.accessToken, data, attach, function () {
attach.videofile = pathUtils.join(__dirname, 'fixtures', 'video_short.mp4') attach.videofile = pathUtils.join(__dirname, 'fixtures', 'video_short.mp4')
makePostRequest(path, server.accessToken, data, attach, function () { requestsUtils.makePostUploadRequest(server.url, path, server.accessToken, data, attach, function () {
attach.videofile = pathUtils.join(__dirname, 'fixtures', 'video_short.ogv') attach.videofile = pathUtils.join(__dirname, 'fixtures', 'video_short.ogv')
makePostRequest(path, server.accessToken, data, attach, done, 204) requestsUtils.makePostUploadRequest(server.url, path, server.accessToken, data, attach, done, 204)
}, false) }, false)
}, false) }, false)
}) })
@ -518,7 +466,7 @@ describe('Test parameters validator', function () {
password: 'mysuperpassword' password: 'mysuperpassword'
} }
makePostBodyRequest(path, server.accessToken, data, done) requestsUtils.makePostBodyRequest(server.url, path, server.accessToken, data, done)
}) })
it('Should fail with a too long username', function (done) { it('Should fail with a too long username', function (done) {
@ -527,7 +475,7 @@ describe('Test parameters validator', function () {
password: 'mysuperpassword' password: 'mysuperpassword'
} }
makePostBodyRequest(path, server.accessToken, data, done) requestsUtils.makePostBodyRequest(server.url, path, server.accessToken, data, done)
}) })
it('Should fail with an incorrect username', function (done) { it('Should fail with an incorrect username', function (done) {
@ -536,7 +484,7 @@ describe('Test parameters validator', function () {
password: 'mysuperpassword' password: 'mysuperpassword'
} }
makePostBodyRequest(path, server.accessToken, data, done) requestsUtils.makePostBodyRequest(server.url, path, server.accessToken, data, done)
}) })
it('Should fail with a too small password', function (done) { it('Should fail with a too small password', function (done) {
@ -545,7 +493,7 @@ describe('Test parameters validator', function () {
password: 'bla' password: 'bla'
} }
makePostBodyRequest(path, server.accessToken, data, done) requestsUtils.makePostBodyRequest(server.url, path, server.accessToken, data, done)
}) })
it('Should fail with a too long password', function (done) { it('Should fail with a too long password', function (done) {
@ -556,7 +504,7 @@ describe('Test parameters validator', function () {
'very very very very very very very very very very very very very very very very very very very very long' 'very very very very very very very very very very very very very very very very very very very very long'
} }
makePostBodyRequest(path, server.accessToken, data, done) requestsUtils.makePostBodyRequest(server.url, path, server.accessToken, data, done)
}) })
it('Should fail with an non authenticated user', function (done) { it('Should fail with an non authenticated user', function (done) {
@ -565,7 +513,7 @@ describe('Test parameters validator', function () {
password: 'my super password' password: 'my super password'
} }
makePostBodyRequest(path, 'super token', data, done, 401) requestsUtils.makePostBodyRequest(server.url, path, 'super token', data, done, 401)
}) })
it('Should succeed with the correct params', function (done) { it('Should succeed with the correct params', function (done) {
@ -574,7 +522,7 @@ describe('Test parameters validator', function () {
password: 'my super password' password: 'my super password'
} }
makePostBodyRequest(path, server.accessToken, data, done, 204) requestsUtils.makePostBodyRequest(server.url, path, server.accessToken, data, done, 204)
}) })
it('Should fail with a non admin user', function (done) { it('Should fail with a non admin user', function (done) {
@ -593,7 +541,7 @@ describe('Test parameters validator', function () {
password: 'my super password' password: 'my super password'
} }
makePostBodyRequest(path, userAccessToken, data, done, 403) requestsUtils.makePostBodyRequest(server.url, path, userAccessToken, data, done, 403)
}) })
}) })
}) })
@ -613,7 +561,7 @@ describe('Test parameters validator', function () {
password: 'bla' password: 'bla'
} }
makePutBodyRequest(path + userId, userAccessToken, data, done) requestsUtils.makePutBodyRequest(server.url, path + userId, userAccessToken, data, done)
}) })
it('Should fail with a too long password', function (done) { it('Should fail with a too long password', function (done) {
@ -623,7 +571,7 @@ describe('Test parameters validator', function () {
'very very very very very very very very very very very very very very very very very very very very long' 'very very very very very very very very very very very very very very very very very very very very long'
} }
makePutBodyRequest(path + userId, userAccessToken, data, done) requestsUtils.makePutBodyRequest(server.url, path + userId, userAccessToken, data, done)
}) })
it('Should fail with an non authenticated user', function (done) { it('Should fail with an non authenticated user', function (done) {
@ -631,7 +579,7 @@ describe('Test parameters validator', function () {
password: 'my super password' password: 'my super password'
} }
makePutBodyRequest(path + userId, 'super token', data, done, 401) requestsUtils.makePutBodyRequest(server.url, path + userId, 'super token', data, done, 401)
}) })
it('Should succeed with the correct params', function (done) { it('Should succeed with the correct params', function (done) {
@ -639,7 +587,7 @@ describe('Test parameters validator', function () {
password: 'my super password' password: 'my super password'
} }
makePutBodyRequest(path + userId, userAccessToken, data, done, 204) requestsUtils.makePutBodyRequest(server.url, path + userId, userAccessToken, data, done, 204)
}) })
}) })

View File

@ -0,0 +1,68 @@
'use strict'
const request = require('supertest')
const requestsUtils = {
makePostUploadRequest: makePostUploadRequest,
makePostBodyRequest: makePostBodyRequest,
makePutBodyRequest: makePutBodyRequest
}
// ---------------------- Export functions --------------------
function makePostUploadRequest (url, path, token, fields, attaches, done, statusCodeExpected) {
if (!statusCodeExpected) statusCodeExpected = 400
const req = request(url)
.post(path)
.set('Accept', 'application/json')
if (token) req.set('Authorization', 'Bearer ' + token)
Object.keys(fields).forEach(function (field) {
const value = fields[field]
if (Array.isArray(value)) {
for (let i = 0; i < value.length; i++) {
req.field(field + '[' + i + ']', value[i])
}
} else {
req.field(field, value)
}
})
Object.keys(attaches).forEach(function (attach) {
const value = attaches[attach]
req.attach(attach, value)
})
req.expect(statusCodeExpected, done)
}
function makePostBodyRequest (url, path, token, fields, done, statusCodeExpected) {
if (!statusCodeExpected) statusCodeExpected = 400
const req = request(url)
.post(path)
.set('Accept', 'application/json')
if (token) req.set('Authorization', 'Bearer ' + token)
req.send(fields).expect(statusCodeExpected, done)
}
function makePutBodyRequest (url, path, token, fields, done, statusCodeExpected) {
if (!statusCodeExpected) statusCodeExpected = 400
const req = request(url)
.put(path)
.set('Accept', 'application/json')
if (token) req.set('Authorization', 'Bearer ' + token)
req.send(fields).expect(statusCodeExpected, done)
}
// ---------------------------------------------------------------------------
module.exports = requestsUtils