2021-07-13 03:43:59 -04:00
|
|
|
/* eslint-disable @typescript-eslint/no-unused-expressions,@typescript-eslint/no-floating-promises */
|
|
|
|
|
|
|
|
import { expect } from 'chai'
|
|
|
|
import { pathExists, readFile } from 'fs-extra'
|
2023-02-24 08:48:15 -05:00
|
|
|
import JPEG from 'jpeg-js'
|
2021-07-13 03:43:59 -04:00
|
|
|
import { join } from 'path'
|
2023-02-24 08:48:15 -05:00
|
|
|
import pixelmatch from 'pixelmatch'
|
|
|
|
import { PNG } from 'pngjs'
|
2021-11-02 14:11:20 -04:00
|
|
|
import { root } from '@shared/core-utils'
|
2021-07-16 04:42:24 -04:00
|
|
|
import { HttpStatusCode } from '@shared/models'
|
2021-12-17 05:58:15 -05:00
|
|
|
import { makeGetRequest, PeerTubeServer } from '@shared/server-commands'
|
2021-07-13 03:43:59 -04:00
|
|
|
|
|
|
|
// Default interval -> 5 minutes
|
|
|
|
function dateIsValid (dateString: string, interval = 300000) {
|
|
|
|
const dateToCheck = new Date(dateString)
|
|
|
|
const now = new Date()
|
|
|
|
|
|
|
|
return Math.abs(now.getTime() - dateToCheck.getTime()) <= interval
|
|
|
|
}
|
|
|
|
|
2021-08-17 02:26:20 -04:00
|
|
|
function expectStartWith (str: string, start: string) {
|
|
|
|
expect(str.startsWith(start), `${str} does not start with ${start}`).to.be.true
|
|
|
|
}
|
|
|
|
|
2022-05-09 05:49:25 -04:00
|
|
|
function expectNotStartWith (str: string, start: string) {
|
|
|
|
expect(str.startsWith(start), `${str} does not start with ${start}`).to.be.false
|
|
|
|
}
|
|
|
|
|
2022-12-02 08:47:21 -05:00
|
|
|
function expectEndWith (str: string, end: string) {
|
|
|
|
expect(str.endsWith(end), `${str} does not end with ${end}`).to.be.true
|
|
|
|
}
|
|
|
|
|
|
|
|
// ---------------------------------------------------------------------------
|
|
|
|
|
2021-08-18 03:14:51 -04:00
|
|
|
async function expectLogDoesNotContain (server: PeerTubeServer, str: string) {
|
|
|
|
const content = await server.servers.getLogContent()
|
|
|
|
|
|
|
|
expect(content.toString()).to.not.contain(str)
|
|
|
|
}
|
|
|
|
|
2022-07-05 09:43:21 -04:00
|
|
|
async function expectLogContain (server: PeerTubeServer, str: string) {
|
|
|
|
const content = await server.servers.getLogContent()
|
|
|
|
|
|
|
|
expect(content.toString()).to.contain(str)
|
|
|
|
}
|
|
|
|
|
2023-02-24 08:48:15 -05:00
|
|
|
async function testImageSize (url: string, imageName: string, imageHTTPPath: string, extension = '.jpg') {
|
2021-07-13 03:43:59 -04:00
|
|
|
const res = await makeGetRequest({
|
|
|
|
url,
|
2022-03-08 02:50:38 -05:00
|
|
|
path: imageHTTPPath,
|
2021-07-16 04:42:24 -04:00
|
|
|
expectedStatus: HttpStatusCode.OK_200
|
2021-07-13 03:43:59 -04:00
|
|
|
})
|
|
|
|
|
|
|
|
const body = res.body
|
|
|
|
|
|
|
|
const data = await readFile(join(root(), 'server', 'tests', 'fixtures', imageName + extension))
|
2022-03-08 03:18:43 -05:00
|
|
|
const minLength = data.length - ((40 * data.length) / 100)
|
|
|
|
const maxLength = data.length + ((40 * data.length) / 100)
|
2021-07-13 03:43:59 -04:00
|
|
|
|
2022-03-08 02:50:38 -05:00
|
|
|
expect(body.length).to.be.above(minLength, 'the generated image is way smaller than the recorded fixture')
|
|
|
|
expect(body.length).to.be.below(maxLength, 'the generated image is way larger than the recorded fixture')
|
2021-07-13 03:43:59 -04:00
|
|
|
}
|
|
|
|
|
2023-02-24 08:48:15 -05:00
|
|
|
async function testImage (url: string, imageName: string, imageHTTPPath: string, extension = '.jpg') {
|
|
|
|
const res = await makeGetRequest({
|
|
|
|
url,
|
|
|
|
path: imageHTTPPath,
|
|
|
|
expectedStatus: HttpStatusCode.OK_200
|
|
|
|
})
|
|
|
|
|
|
|
|
const body = res.body
|
|
|
|
const data = await readFile(join(root(), 'server', 'tests', 'fixtures', imageName + extension))
|
|
|
|
|
|
|
|
const img1 = imageHTTPPath.endsWith('.png')
|
|
|
|
? PNG.sync.read(body)
|
|
|
|
: JPEG.decode(body)
|
|
|
|
|
|
|
|
const img2 = extension === '.png'
|
|
|
|
? PNG.sync.read(data)
|
|
|
|
: JPEG.decode(data)
|
|
|
|
|
|
|
|
const result = pixelmatch(img1.data, img2.data, null, img1.width, img1.height, { threshold: 0.1 })
|
|
|
|
|
|
|
|
expect(result).to.equal(0, `${imageHTTPPath} image is not the same as ${imageName}${extension}`)
|
|
|
|
}
|
|
|
|
|
2021-07-16 03:47:51 -04:00
|
|
|
async function testFileExistsOrNot (server: PeerTubeServer, directory: string, filePath: string, exist: boolean) {
|
2021-07-16 03:04:35 -04:00
|
|
|
const base = server.servers.buildDirectory(directory)
|
2021-07-13 03:43:59 -04:00
|
|
|
|
|
|
|
expect(await pathExists(join(base, filePath))).to.equal(exist)
|
|
|
|
}
|
|
|
|
|
2021-12-17 05:58:15 -05:00
|
|
|
function checkBadStartPagination (url: string, path: string, token?: string, query = {}) {
|
|
|
|
return makeGetRequest({
|
|
|
|
url,
|
|
|
|
path,
|
|
|
|
token,
|
|
|
|
query: { ...query, start: 'hello' },
|
|
|
|
expectedStatus: HttpStatusCode.BAD_REQUEST_400
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
async function checkBadCountPagination (url: string, path: string, token?: string, query = {}) {
|
|
|
|
await makeGetRequest({
|
|
|
|
url,
|
|
|
|
path,
|
|
|
|
token,
|
|
|
|
query: { ...query, count: 'hello' },
|
|
|
|
expectedStatus: HttpStatusCode.BAD_REQUEST_400
|
|
|
|
})
|
|
|
|
|
|
|
|
await makeGetRequest({
|
|
|
|
url,
|
|
|
|
path,
|
|
|
|
token,
|
|
|
|
query: { ...query, count: 2000 },
|
|
|
|
expectedStatus: HttpStatusCode.BAD_REQUEST_400
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
function checkBadSortPagination (url: string, path: string, token?: string, query = {}) {
|
|
|
|
return makeGetRequest({
|
|
|
|
url,
|
|
|
|
path,
|
|
|
|
token,
|
|
|
|
query: { ...query, sort: 'hello' },
|
|
|
|
expectedStatus: HttpStatusCode.BAD_REQUEST_400
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2021-07-13 03:43:59 -04:00
|
|
|
export {
|
|
|
|
dateIsValid,
|
2023-02-24 08:48:15 -05:00
|
|
|
testImageSize,
|
2021-07-13 03:43:59 -04:00
|
|
|
testImage,
|
2021-08-18 03:14:51 -04:00
|
|
|
expectLogDoesNotContain,
|
2021-08-17 02:26:20 -04:00
|
|
|
testFileExistsOrNot,
|
2021-12-17 05:58:15 -05:00
|
|
|
expectStartWith,
|
2022-05-09 05:49:25 -04:00
|
|
|
expectNotStartWith,
|
2022-12-02 08:47:21 -05:00
|
|
|
expectEndWith,
|
2021-12-17 05:58:15 -05:00
|
|
|
checkBadStartPagination,
|
|
|
|
checkBadCountPagination,
|
2022-07-05 09:43:21 -04:00
|
|
|
checkBadSortPagination,
|
|
|
|
expectLogContain
|
2021-07-13 03:43:59 -04:00
|
|
|
}
|