2020-01-31 16:56:52 +01:00
|
|
|
/* eslint-disable @typescript-eslint/no-unused-expressions,@typescript-eslint/no-floating-promises */
|
|
|
|
|
2017-09-04 21:21:47 +02:00
|
|
|
import * as request from 'supertest'
|
2018-12-07 16:09:57 +01:00
|
|
|
import { buildAbsoluteFixturePath, root } from '../miscs/miscs'
|
2018-06-29 11:29:23 +02:00
|
|
|
import { isAbsolute, join } from 'path'
|
2020-01-31 16:56:52 +01:00
|
|
|
import { URL } from 'url'
|
2020-04-29 09:04:42 +02:00
|
|
|
import { decode } from 'querystring'
|
2019-01-29 08:37:25 +01:00
|
|
|
|
2019-02-21 17:19:16 +01:00
|
|
|
function get4KFileUrl () {
|
|
|
|
return 'https://download.cpy.re/peertube/4k_file.txt'
|
|
|
|
}
|
|
|
|
|
2019-02-07 15:08:19 +01:00
|
|
|
function makeRawRequest (url: string, statusCodeExpected?: number, range?: string) {
|
2020-01-31 16:56:52 +01:00
|
|
|
const { host, protocol, pathname } = new URL(url)
|
2019-01-29 08:37:25 +01:00
|
|
|
|
2019-02-07 15:08:19 +01:00
|
|
|
return makeGetRequest({ url: `${protocol}//${host}`, path: pathname, statusCodeExpected, range })
|
2019-01-29 08:37:25 +01:00
|
|
|
}
|
2017-09-04 21:21:47 +02:00
|
|
|
|
2017-12-28 14:29:57 +01:00
|
|
|
function makeGetRequest (options: {
|
2020-01-31 16:56:52 +01:00
|
|
|
url: string
|
|
|
|
path?: string
|
|
|
|
query?: any
|
|
|
|
token?: string
|
|
|
|
statusCodeExpected?: number
|
|
|
|
contentType?: string
|
2019-02-07 15:08:19 +01:00
|
|
|
range?: string
|
2020-04-29 09:04:42 +02:00
|
|
|
redirects?: number
|
2017-12-28 14:29:57 +01:00
|
|
|
}) {
|
|
|
|
if (!options.statusCodeExpected) options.statusCodeExpected = 400
|
2018-09-25 16:22:48 +02:00
|
|
|
if (options.contentType === undefined) options.contentType = 'application/json'
|
2017-12-28 14:29:57 +01:00
|
|
|
|
2019-01-29 08:37:25 +01:00
|
|
|
const req = request(options.url).get(options.path)
|
2017-12-28 14:29:57 +01:00
|
|
|
|
2018-09-25 16:22:48 +02:00
|
|
|
if (options.contentType) req.set('Accept', options.contentType)
|
2017-12-28 14:29:57 +01:00
|
|
|
if (options.token) req.set('Authorization', 'Bearer ' + options.token)
|
|
|
|
if (options.query) req.query(options.query)
|
2019-02-07 15:08:19 +01:00
|
|
|
if (options.range) req.set('Range', options.range)
|
2020-04-29 09:04:42 +02:00
|
|
|
if (options.redirects) req.redirects(options.redirects)
|
2017-12-28 14:29:57 +01:00
|
|
|
|
2018-09-25 16:22:48 +02:00
|
|
|
return req.expect(options.statusCodeExpected)
|
2017-12-28 14:29:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
function makeDeleteRequest (options: {
|
2020-01-31 16:56:52 +01:00
|
|
|
url: string
|
|
|
|
path: string
|
|
|
|
token?: string
|
2017-12-28 14:29:57 +01:00
|
|
|
statusCodeExpected?: number
|
|
|
|
}) {
|
|
|
|
if (!options.statusCodeExpected) options.statusCodeExpected = 400
|
|
|
|
|
|
|
|
const req = request(options.url)
|
|
|
|
.delete(options.path)
|
|
|
|
.set('Accept', 'application/json')
|
|
|
|
|
|
|
|
if (options.token) req.set('Authorization', 'Bearer ' + options.token)
|
|
|
|
|
2018-10-12 15:26:04 +02:00
|
|
|
return req.expect(options.statusCodeExpected)
|
2017-09-04 21:21:47 +02:00
|
|
|
}
|
|
|
|
|
2018-02-13 18:17:05 +01:00
|
|
|
function makeUploadRequest (options: {
|
2020-01-31 16:56:52 +01:00
|
|
|
url: string
|
|
|
|
method?: 'POST' | 'PUT'
|
|
|
|
path: string
|
|
|
|
token?: string
|
|
|
|
fields: { [ fieldName: string ]: any }
|
2020-10-30 15:09:00 +01:00
|
|
|
attaches?: { [ attachName: string ]: any | any[] }
|
2017-09-04 21:21:47 +02:00
|
|
|
statusCodeExpected?: number
|
|
|
|
}) {
|
|
|
|
if (!options.statusCodeExpected) options.statusCodeExpected = 400
|
|
|
|
|
2018-02-13 18:17:05 +01:00
|
|
|
let req: request.Test
|
|
|
|
if (options.method === 'PUT') {
|
|
|
|
req = request(options.url).put(options.path)
|
|
|
|
} else {
|
|
|
|
req = request(options.url).post(options.path)
|
|
|
|
}
|
|
|
|
|
|
|
|
req.set('Accept', 'application/json')
|
2017-09-04 21:21:47 +02:00
|
|
|
|
|
|
|
if (options.token) req.set('Authorization', 'Bearer ' + options.token)
|
|
|
|
|
|
|
|
Object.keys(options.fields).forEach(field => {
|
|
|
|
const value = options.fields[field]
|
|
|
|
|
2019-03-05 10:58:44 +01:00
|
|
|
if (value === undefined) return
|
|
|
|
|
2017-09-04 21:21:47 +02:00
|
|
|
if (Array.isArray(value)) {
|
|
|
|
for (let i = 0; i < value.length; i++) {
|
|
|
|
req.field(field + '[' + i + ']', value[i])
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
req.field(field, value)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
2020-10-30 15:09:00 +01:00
|
|
|
Object.keys(options.attaches || {}).forEach(attach => {
|
2017-09-04 21:21:47 +02:00
|
|
|
const value = options.attaches[attach]
|
2018-08-06 11:45:24 +02:00
|
|
|
if (Array.isArray(value)) {
|
|
|
|
req.attach(attach, buildAbsoluteFixturePath(value[0]), value[1])
|
|
|
|
} else {
|
|
|
|
req.attach(attach, buildAbsoluteFixturePath(value))
|
|
|
|
}
|
2017-09-04 21:21:47 +02:00
|
|
|
})
|
|
|
|
|
|
|
|
return req.expect(options.statusCodeExpected)
|
|
|
|
}
|
|
|
|
|
|
|
|
function makePostBodyRequest (options: {
|
2020-01-31 16:56:52 +01:00
|
|
|
url: string
|
|
|
|
path: string
|
|
|
|
token?: string
|
|
|
|
fields?: { [ fieldName: string ]: any }
|
2017-09-04 21:21:47 +02:00
|
|
|
statusCodeExpected?: number
|
|
|
|
}) {
|
2017-12-28 14:29:57 +01:00
|
|
|
if (!options.fields) options.fields = {}
|
2017-09-04 21:21:47 +02:00
|
|
|
if (!options.statusCodeExpected) options.statusCodeExpected = 400
|
|
|
|
|
|
|
|
const req = request(options.url)
|
|
|
|
.post(options.path)
|
|
|
|
.set('Accept', 'application/json')
|
|
|
|
|
|
|
|
if (options.token) req.set('Authorization', 'Bearer ' + options.token)
|
|
|
|
|
|
|
|
return req.send(options.fields)
|
|
|
|
.expect(options.statusCodeExpected)
|
|
|
|
}
|
|
|
|
|
|
|
|
function makePutBodyRequest (options: {
|
2020-01-31 16:56:52 +01:00
|
|
|
url: string
|
|
|
|
path: string
|
|
|
|
token?: string
|
|
|
|
fields: { [ fieldName: string ]: any }
|
2017-09-04 21:21:47 +02:00
|
|
|
statusCodeExpected?: number
|
|
|
|
}) {
|
|
|
|
if (!options.statusCodeExpected) options.statusCodeExpected = 400
|
|
|
|
|
|
|
|
const req = request(options.url)
|
|
|
|
.put(options.path)
|
|
|
|
.set('Accept', 'application/json')
|
|
|
|
|
|
|
|
if (options.token) req.set('Authorization', 'Bearer ' + options.token)
|
|
|
|
|
|
|
|
return req.send(options.fields)
|
|
|
|
.expect(options.statusCodeExpected)
|
|
|
|
}
|
|
|
|
|
2018-07-18 09:52:46 +02:00
|
|
|
function makeHTMLRequest (url: string, path: string) {
|
|
|
|
return request(url)
|
|
|
|
.get(path)
|
|
|
|
.set('Accept', 'text/html')
|
|
|
|
.expect(200)
|
|
|
|
}
|
|
|
|
|
2018-06-29 11:29:23 +02:00
|
|
|
function updateAvatarRequest (options: {
|
2020-01-31 16:56:52 +01:00
|
|
|
url: string
|
|
|
|
path: string
|
|
|
|
accessToken: string
|
2018-06-29 11:29:23 +02:00
|
|
|
fixture: string
|
|
|
|
}) {
|
|
|
|
let filePath = ''
|
|
|
|
if (isAbsolute(options.fixture)) {
|
|
|
|
filePath = options.fixture
|
|
|
|
} else {
|
2018-12-07 16:09:57 +01:00
|
|
|
filePath = join(root(), 'server', 'tests', 'fixtures', options.fixture)
|
2018-06-29 11:29:23 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
return makeUploadRequest({
|
|
|
|
url: options.url,
|
|
|
|
path: options.path,
|
|
|
|
token: options.accessToken,
|
|
|
|
fields: {},
|
|
|
|
attaches: { avatarfile: filePath },
|
|
|
|
statusCodeExpected: 200
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2020-04-29 09:04:42 +02:00
|
|
|
function decodeQueryString (path: string) {
|
|
|
|
return decode(path.split('?')[1])
|
|
|
|
}
|
|
|
|
|
2017-09-04 21:21:47 +02:00
|
|
|
// ---------------------------------------------------------------------------
|
|
|
|
|
|
|
|
export {
|
2019-02-21 17:19:16 +01:00
|
|
|
get4KFileUrl,
|
2018-07-18 09:52:46 +02:00
|
|
|
makeHTMLRequest,
|
2017-09-04 21:21:47 +02:00
|
|
|
makeGetRequest,
|
2020-04-29 09:04:42 +02:00
|
|
|
decodeQueryString,
|
2018-02-13 18:17:05 +01:00
|
|
|
makeUploadRequest,
|
2017-09-04 21:21:47 +02:00
|
|
|
makePostBodyRequest,
|
2017-12-28 14:29:57 +01:00
|
|
|
makePutBodyRequest,
|
2018-06-29 11:29:23 +02:00
|
|
|
makeDeleteRequest,
|
2019-01-29 08:37:25 +01:00
|
|
|
makeRawRequest,
|
2018-06-29 11:29:23 +02:00
|
|
|
updateAvatarRequest
|
2017-09-04 21:21:47 +02:00
|
|
|
}
|