Improve check services parameters tests

This commit is contained in:
Chocobozzz 2017-12-28 14:49:43 +01:00
parent 93e4a311f3
commit 331128ed35
No known key found for this signature in database
GPG Key ID: 583A612D890159BE
2 changed files with 39 additions and 90 deletions

View File

@ -1,18 +1,11 @@
/* tslint:disable:no-unused-expression */ /* tslint:disable:no-unused-expression */
import * as request from 'supertest'
import 'mocha' import 'mocha'
import { import { flushTests, killallServers, makeGetRequest, runServer, ServerInfo, setAccessTokensToServers, uploadVideo } from '../../utils'
flushTests,
runServer,
setAccessTokensToServers,
killallServers
} from '../../utils'
import { getVideosList, uploadVideo } from '../../utils/videos/videos'
describe('Test services API validators', function () { describe('Test services API validators', function () {
let server let server: ServerInfo
// --------------------------------------------------------------- // ---------------------------------------------------------------
@ -24,127 +17,71 @@ describe('Test services API validators', function () {
server = await runServer(1) server = await runServer(1)
await setAccessTokensToServers([ server ]) await setAccessTokensToServers([ server ])
const videoAttributes = { const res = await uploadVideo(server.url, server.accessToken, { name: 'my super name' })
name: 'my super name' server.video = res.body.video
}
await uploadVideo(server.url, server.accessToken, videoAttributes)
const res = await getVideosList(server.url)
server.video = res.body.data[0]
}) })
describe('Test oEmbed API validators', function () { describe('Test oEmbed API validators', function () {
const path = '/services/oembed'
it('Should fail with an invalid url', async function () { it('Should fail with an invalid url', async function () {
const embedUrl = 'hello.com' const embedUrl = 'hello.com'
await checkParamEmbed(server, embedUrl)
await request(server.url)
.get(path)
.query({ url: embedUrl })
.set('Accept', 'application/json')
.set('Authorization', 'Bearer ' + server.accessToken)
.expect(400)
}) })
it('Should fail with an invalid host', async function () { it('Should fail with an invalid host', async function () {
const embedUrl = 'http://hello.com/videos/watch/' + server.video.uuid const embedUrl = 'http://hello.com/videos/watch/' + server.video.uuid
await checkParamEmbed(server, embedUrl)
await request(server.url)
.get(path)
.query({ url: embedUrl })
.set('Accept', 'application/json')
.set('Authorization', 'Bearer ' + server.accessToken)
.expect(400)
}) })
it('Should fail with an invalid video id', async function () { it('Should fail with an invalid video id', async function () {
const embedUrl = 'http://localhost:9001/videos/watch/blabla' const embedUrl = 'http://localhost:9001/videos/watch/blabla'
await checkParamEmbed(server, embedUrl)
await request(server.url)
.get(path)
.query({ url: embedUrl })
.set('Accept', 'application/json')
.set('Authorization', 'Bearer ' + server.accessToken)
.expect(400)
}) })
it('Should fail with an unknown video', async function () { it('Should fail with an unknown video', async function () {
const embedUrl = 'http://localhost:9001/videos/watch/88fc0165-d1f0-4a35-a51a-3b47f668689c' const embedUrl = 'http://localhost:9001/videos/watch/88fc0165-d1f0-4a35-a51a-3b47f668689c'
await checkParamEmbed(server, embedUrl, 404)
await request(server.url)
.get(path)
.query({ url: embedUrl })
.set('Accept', 'application/json')
.set('Authorization', 'Bearer ' + server.accessToken)
.expect(404)
}) })
it('Should fail with an invalid path', async function () { it('Should fail with an invalid path', async function () {
const embedUrl = 'http://localhost:9001/videos/watchs/' + server.video.uuid const embedUrl = 'http://localhost:9001/videos/watchs/' + server.video.uuid
await request(server.url) await checkParamEmbed(server, embedUrl)
.get(path)
.query({ url: embedUrl })
.set('Accept', 'application/json')
.set('Authorization', 'Bearer ' + server.accessToken)
.expect(400)
}) })
it('Should fail with an invalid max height', async function () { it('Should fail with an invalid max height', async function () {
const embedUrl = 'http://localhost:9001/videos/watch/' + server.video.uuid const embedUrl = 'http://localhost:9001/videos/watch/' + server.video.uuid
await request(server.url) await checkParamEmbed(server, embedUrl, 400, { maxheight: 'hello' })
.get(path)
.query({
url: embedUrl,
maxheight: 'hello'
})
.set('Accept', 'application/json')
.set('Authorization', 'Bearer ' + server.accessToken)
.expect(400)
}) })
it('Should fail with an invalid max width', async function () { it('Should fail with an invalid max width', async function () {
const embedUrl = 'http://localhost:9001/videos/watch/' + server.video.uuid const embedUrl = 'http://localhost:9001/videos/watch/' + server.video.uuid
await request(server.url) await checkParamEmbed(server, embedUrl, 400, { maxwidth: 'hello' })
.get(path)
.query({
url: embedUrl,
maxwidth: 'hello'
})
.set('Accept', 'application/json')
.set('Authorization', 'Bearer ' + server.accessToken)
.expect(400)
}) })
it('Should fail with an invalid format', async function () { it('Should fail with an invalid format', async function () {
const embedUrl = 'http://localhost:9001/videos/watch/' + server.video.uuid const embedUrl = 'http://localhost:9001/videos/watch/' + server.video.uuid
await request(server.url) await checkParamEmbed(server, embedUrl, 400, { format: 'blabla' })
.get(path)
.query({
url: embedUrl,
format: 'blabla'
})
.set('Accept', 'application/json')
.set('Authorization', 'Bearer ' + server.accessToken)
.expect(400)
}) })
it('Should fail with a non supported format', async function () { it('Should fail with a non supported format', async function () {
const embedUrl = 'http://localhost:9001/videos/watch/' + server.video.uuid const embedUrl = 'http://localhost:9001/videos/watch/' + server.video.uuid
await request(server.url) await checkParamEmbed(server, embedUrl, 501, { format: 'xml' })
.get(path) })
.query({
url: embedUrl, it('Should succeed with the correct params', async function () {
format: 'xml' const embedUrl = 'http://localhost:9001/videos/watch/' + server.video.uuid
}) const query = {
.set('Accept', 'application/json') format: 'json',
.set('Authorization', 'Bearer ' + server.accessToken) maxheight: 400,
.expect(501) maxwidth: 400
}
await checkParamEmbed(server, embedUrl, 200, query)
}) })
}) })
@ -157,3 +94,15 @@ describe('Test services API validators', function () {
} }
}) })
}) })
function checkParamEmbed (server: ServerInfo, embedUrl: string, statusCodeExpected = 400, query = {}) {
const path = '/services/oembed'
return makeGetRequest({
url: server.url,
path,
query: Object.assign(query, { url: embedUrl }),
token: server.accessToken,
statusCodeExpected
})
}

View File

@ -200,7 +200,7 @@ async function testVideoImage (url: string, imageName: string, imagePath: string
.get(imagePath) .get(imagePath)
.expect(200) .expect(200)
const data = await readFilePromise(join(__dirname, '..', 'api', 'fixtures', imageName + '.jpg')) const data = await readFilePromise(join(__dirname, '..', '..', 'api', 'fixtures', imageName + '.jpg'))
return data.equals(res.body) return data.equals(res.body)
} else { } else {
@ -257,7 +257,7 @@ async function uploadVideo (url: string, accessToken: string, videoAttributesArg
if (isAbsolute(attributes.fixture)) { if (isAbsolute(attributes.fixture)) {
filePath = attributes.fixture filePath = attributes.fixture
} else { } else {
filePath = join(__dirname, '..', 'api', 'fixtures', attributes.fixture) filePath = join(__dirname, '..', '..', 'api', 'fixtures', attributes.fixture)
} }
return req.attach('videofile', filePath) return req.attach('videofile', filePath)
@ -299,7 +299,7 @@ function rateVideo (url: string, accessToken: string, id: number, rating: string
function parseTorrentVideo (server: ServerInfo, videoUUID: string, resolution: number) { function parseTorrentVideo (server: ServerInfo, videoUUID: string, resolution: number) {
return new Promise<any>((res, rej) => { return new Promise<any>((res, rej) => {
const torrentName = videoUUID + '-' + resolution + '.torrent' const torrentName = videoUUID + '-' + resolution + '.torrent'
const torrentPath = join(__dirname, '..', '..', '..', 'test' + server.serverNumber, 'torrents', torrentName) const torrentPath = join(__dirname, '..', '..', '..', '..', 'test' + server.serverNumber, 'torrents', torrentName)
readFile(torrentPath, (err, data) => { readFile(torrentPath, (err, data) => {
if (err) return rej(err) if (err) return rej(err)