2021-02-22 08:34:32 -06:00
|
|
|
import { registerTSPaths } from '../server/helpers/register-ts-paths'
|
|
|
|
registerTSPaths()
|
|
|
|
|
|
|
|
import * as autocannon from 'autocannon'
|
|
|
|
import {
|
|
|
|
addVideoCommentReply,
|
|
|
|
addVideoCommentThread,
|
|
|
|
createVideoCaption,
|
|
|
|
flushAndRunServer,
|
|
|
|
getVideosList,
|
|
|
|
killallServers,
|
|
|
|
ServerInfo,
|
|
|
|
setAccessTokensToServers,
|
|
|
|
uploadVideo
|
|
|
|
} from '@shared/extra-utils'
|
|
|
|
import { Video, VideoPrivacy } from '@shared/models'
|
|
|
|
import { writeJson } from 'fs-extra'
|
|
|
|
|
|
|
|
let server: ServerInfo
|
|
|
|
let video: Video
|
|
|
|
let threadId: number
|
|
|
|
|
|
|
|
const outfile = process.argv[2]
|
|
|
|
|
|
|
|
run()
|
|
|
|
.catch(err => console.error(err))
|
|
|
|
.finally(() => {
|
|
|
|
if (server) killallServers([ server ])
|
|
|
|
})
|
|
|
|
|
|
|
|
function buildAuthorizationHeader () {
|
|
|
|
return {
|
|
|
|
Authorization: 'Bearer ' + server.accessToken
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-02-25 09:23:30 -06:00
|
|
|
function buildAPHeader () {
|
|
|
|
return {
|
|
|
|
Accept: 'application/ld+json; profile="https://www.w3.org/ns/activitystreams"'
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-02-22 08:34:32 -06:00
|
|
|
async function run () {
|
|
|
|
console.log('Preparing server...')
|
|
|
|
|
|
|
|
await prepare()
|
|
|
|
|
|
|
|
const tests = [
|
2021-02-25 09:23:30 -06:00
|
|
|
{
|
|
|
|
title: 'AP - account peertube',
|
|
|
|
path: '/accounts/peertube',
|
|
|
|
headers: buildAPHeader(),
|
|
|
|
expecter: (client, statusCode) => {
|
|
|
|
const body = client.resData[0].body
|
|
|
|
|
|
|
|
return statusCode === 200 && body.startsWith('{"type":')
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
title: 'AP - video',
|
|
|
|
path: '/videos/watch/' + video.uuid,
|
|
|
|
headers: buildAPHeader(),
|
|
|
|
expecter: (client, statusCode) => {
|
|
|
|
const body = client.resData[0].body
|
|
|
|
|
|
|
|
return statusCode === 200 && body.startsWith('{"type":"Video"')
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
title: 'Misc - webfinger peertube',
|
|
|
|
path: '/.well-known/webfinger?resource=acct:peertube@' + server.host,
|
|
|
|
expecter: (client, statusCode) => {
|
|
|
|
const body = client.resData[0].body
|
|
|
|
|
|
|
|
return statusCode === 200 && body.startsWith('{"subject":')
|
|
|
|
}
|
|
|
|
},
|
2021-02-22 08:34:32 -06:00
|
|
|
{
|
|
|
|
title: 'API - unread notifications',
|
|
|
|
path: '/api/v1/users/me/notifications?start=0&count=0&unread=true',
|
|
|
|
headers: buildAuthorizationHeader(),
|
|
|
|
expecter: (_client, statusCode) => {
|
|
|
|
return statusCode === 200
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
title: 'API - me',
|
|
|
|
path: '/api/v1/users/me',
|
|
|
|
headers: buildAuthorizationHeader(),
|
|
|
|
expecter: (client, statusCode) => {
|
|
|
|
const body = client.resData[0].body
|
|
|
|
|
|
|
|
return statusCode === 200 && body.startsWith('{"id":')
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
title: 'API - videos list',
|
|
|
|
path: '/api/v1/videos',
|
|
|
|
expecter: (client, statusCode) => {
|
|
|
|
const body = client.resData[0].body
|
|
|
|
|
|
|
|
return statusCode === 200 && body.startsWith('{"total":10')
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
title: 'API - video get',
|
|
|
|
path: '/api/v1/videos/' + video.uuid,
|
|
|
|
expecter: (client, statusCode) => {
|
|
|
|
const body = client.resData[0].body
|
|
|
|
|
|
|
|
return statusCode === 200 && body.startsWith('{"id":')
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
title: 'API - video captions',
|
|
|
|
path: '/api/v1/videos/' + video.uuid + '/captions',
|
|
|
|
expecter: (client, statusCode) => {
|
|
|
|
const body = client.resData[0].body
|
|
|
|
|
|
|
|
return statusCode === 200 && body.startsWith('{"total":4')
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
title: 'API - video threads',
|
|
|
|
path: '/api/v1/videos/' + video.uuid + '/comment-threads',
|
|
|
|
expecter: (client, statusCode) => {
|
|
|
|
const body = client.resData[0].body
|
|
|
|
|
|
|
|
return statusCode === 200 && body.startsWith('{"total":10')
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
title: 'API - video replies',
|
|
|
|
path: '/api/v1/videos/' + video.uuid + '/comment-threads/' + threadId,
|
|
|
|
expecter: (client, statusCode) => {
|
|
|
|
const body = client.resData[0].body
|
|
|
|
|
|
|
|
return statusCode === 200 && body.startsWith('{"comment":{')
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
title: 'HTML - video watch',
|
|
|
|
path: '/videos/watch/' + video.uuid,
|
|
|
|
expecter: (client, statusCode) => {
|
|
|
|
const body = client.resData[0].body
|
|
|
|
|
|
|
|
return statusCode === 200 && body.includes('<title>my super')
|
|
|
|
}
|
|
|
|
},
|
2021-02-25 09:23:30 -06:00
|
|
|
{
|
|
|
|
title: 'HTML - video embed',
|
|
|
|
path: '/videos/embed/' + video.uuid,
|
|
|
|
expecter: (client, statusCode) => {
|
|
|
|
const body = client.resData[0].body
|
|
|
|
|
|
|
|
return statusCode === 200 && body.includes('embed')
|
|
|
|
}
|
|
|
|
},
|
2021-02-22 08:34:32 -06:00
|
|
|
{
|
|
|
|
title: 'HTML - homepage',
|
|
|
|
path: '/',
|
|
|
|
expecter: (_client, statusCode) => {
|
|
|
|
return statusCode === 200
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
title: 'API - config',
|
|
|
|
path: '/api/v1/config',
|
|
|
|
expecter: (client, statusCode) => {
|
|
|
|
const body = client.resData[0].body
|
|
|
|
|
|
|
|
return statusCode === 200 && body.startsWith('{"instance":')
|
|
|
|
}
|
|
|
|
}
|
|
|
|
]
|
|
|
|
|
|
|
|
const finalResult: any[] = []
|
|
|
|
|
|
|
|
for (const test of tests) {
|
|
|
|
console.log('Running against %s.', test.path)
|
|
|
|
const testResult = await runBenchmark(test)
|
|
|
|
|
|
|
|
Object.assign(testResult, { title: test.title, path: test.path })
|
|
|
|
finalResult.push(testResult)
|
|
|
|
|
|
|
|
console.log(autocannon.printResult(testResult))
|
|
|
|
}
|
|
|
|
|
|
|
|
if (outfile) await writeJson(outfile, finalResult)
|
|
|
|
}
|
|
|
|
|
|
|
|
function runBenchmark (options: {
|
|
|
|
path: string
|
|
|
|
headers?: { [ id: string ]: string }
|
|
|
|
expecter: Function
|
|
|
|
}) {
|
|
|
|
const { path, expecter, headers } = options
|
|
|
|
|
|
|
|
return new Promise((res, rej) => {
|
|
|
|
const instance = autocannon({
|
|
|
|
url: server.url + path,
|
|
|
|
connections: 20,
|
|
|
|
headers,
|
|
|
|
pipelining: 1,
|
|
|
|
duration: 10
|
|
|
|
}, (err, result) => {
|
|
|
|
if (err) return rej(err)
|
|
|
|
|
|
|
|
return res(result)
|
|
|
|
})
|
|
|
|
|
|
|
|
instance.on('response', (client, statusCode) => {
|
|
|
|
if (expecter(client, statusCode) !== true) {
|
|
|
|
console.error('Expected result failed.', { data: client.resData })
|
|
|
|
process.exit(-1)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
async function prepare () {
|
|
|
|
server = await flushAndRunServer(1, {
|
|
|
|
rates_limit: {
|
|
|
|
api: {
|
|
|
|
max: 5_000_000
|
|
|
|
}
|
|
|
|
}
|
|
|
|
})
|
|
|
|
await setAccessTokensToServers([ server ])
|
|
|
|
|
|
|
|
const videoAttributes = {
|
|
|
|
name: 'my super video',
|
|
|
|
category: 2,
|
|
|
|
nsfw: true,
|
|
|
|
licence: 6,
|
|
|
|
language: 'fr',
|
|
|
|
privacy: VideoPrivacy.PUBLIC,
|
|
|
|
support: 'please give me a coffee',
|
|
|
|
description: 'my super description'.repeat(10),
|
|
|
|
tags: [ 'tag1', 'tag2', 'tag3' ]
|
|
|
|
}
|
|
|
|
|
|
|
|
for (let i = 0; i < 10; i++) {
|
|
|
|
Object.assign(videoAttributes, { name: 'my super video ' + i })
|
|
|
|
await uploadVideo(server.url, server.accessToken, videoAttributes)
|
|
|
|
}
|
|
|
|
|
|
|
|
const resVideos = await getVideosList(server.url)
|
|
|
|
video = resVideos.body.data.find(v => v.name === 'my super video 1')
|
|
|
|
|
|
|
|
for (let i = 0; i < 10; i++) {
|
|
|
|
const text = 'my super first comment'
|
|
|
|
const res = await addVideoCommentThread(server.url, server.accessToken, video.id, text)
|
|
|
|
threadId = res.body.comment.id
|
|
|
|
|
|
|
|
const text1 = 'my super answer to thread 1'
|
|
|
|
const childCommentRes = await addVideoCommentReply(server.url, server.accessToken, video.id, threadId, text1)
|
|
|
|
const childCommentId = childCommentRes.body.comment.id
|
|
|
|
|
|
|
|
const text2 = 'my super answer to answer of thread 1'
|
|
|
|
await addVideoCommentReply(server.url, server.accessToken, video.id, childCommentId, text2)
|
|
|
|
|
|
|
|
const text3 = 'my second answer to thread 1'
|
|
|
|
await addVideoCommentReply(server.url, server.accessToken, video.id, threadId, text3)
|
|
|
|
}
|
|
|
|
|
|
|
|
for (const caption of [ 'ar', 'fr', 'en', 'zh' ]) {
|
|
|
|
await createVideoCaption({
|
|
|
|
url: server.url,
|
|
|
|
accessToken: server.accessToken,
|
|
|
|
language: caption,
|
|
|
|
videoId: video.id,
|
|
|
|
fixture: 'subtitle-good2.vtt'
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
return { server, video, threadId }
|
|
|
|
}
|