]>
Commit | Line | Data |
---|---|---|
6c5065a0 C |
1 | /* eslint-disable @typescript-eslint/no-unused-expressions,@typescript-eslint/no-floating-promises */ |
2 | ||
3 | import { expect } from 'chai' | |
4 | import { pathExists, readFile } from 'fs-extra' | |
5 | import { join } from 'path' | |
6 | import { root } from '@server/helpers/core-utils' | |
7 | import { HttpStatusCode } from '@shared/core-utils' | |
8 | import { makeGetRequest } from '../requests' | |
9 | import { ServerInfo } from '../server' | |
10 | ||
11 | // Default interval -> 5 minutes | |
12 | function dateIsValid (dateString: string, interval = 300000) { | |
13 | const dateToCheck = new Date(dateString) | |
14 | const now = new Date() | |
15 | ||
16 | return Math.abs(now.getTime() - dateToCheck.getTime()) <= interval | |
17 | } | |
18 | ||
19 | async function testImage (url: string, imageName: string, imagePath: string, extension = '.jpg') { | |
20 | const res = await makeGetRequest({ | |
21 | url, | |
22 | path: imagePath, | |
23 | statusCodeExpected: HttpStatusCode.OK_200 | |
24 | }) | |
25 | ||
26 | const body = res.body | |
27 | ||
28 | const data = await readFile(join(root(), 'server', 'tests', 'fixtures', imageName + extension)) | |
29 | const minLength = body.length - ((30 * body.length) / 100) | |
30 | const maxLength = body.length + ((30 * body.length) / 100) | |
31 | ||
32 | expect(data.length).to.be.above(minLength, 'the generated image is way smaller than the recorded fixture') | |
33 | expect(data.length).to.be.below(maxLength, 'the generated image is way larger than the recorded fixture') | |
34 | } | |
35 | ||
36 | async function testFileExistsOrNot (server: ServerInfo, directory: string, filePath: string, exist: boolean) { | |
37 | const base = server.serversCommand.buildDirectory(directory) | |
38 | ||
39 | expect(await pathExists(join(base, filePath))).to.equal(exist) | |
40 | } | |
41 | ||
42 | export { | |
43 | dateIsValid, | |
44 | testImage, | |
45 | testFileExistsOrNot | |
46 | } |