Improve check services parameters tests
This commit is contained in:
parent
93e4a311f3
commit
331128ed35
|
@ -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
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
|
@ -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)
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue