]>
Commit | Line | Data |
---|---|---|
6c5065a0 C |
1 | import { stat } from 'fs-extra' |
2 | import { basename, isAbsolute, join, resolve } from 'path' | |
3 | ||
59bbcced | 4 | const FIXTURE_URLS = { |
e3c9ea72 C |
5 | peertube_long: 'https://peertube2.cpy.re/videos/watch/122d093a-1ede-43bd-bd34-59d2931ffc5e', |
6 | peertube_short: 'https://peertube2.cpy.re/w/3fbif9S3WmtTP8gGsC5HBd', | |
7 | ||
59bbcced C |
8 | youtube: 'https://www.youtube.com/watch?v=msX3jv1XdvM', |
9 | ||
10 | /** | |
11 | * The video is used to check format-selection correctness wrt. HDR, | |
12 | * which brings its own set of oddities outside of a MediaSource. | |
59bbcced C |
13 | * |
14 | * The video needs to have the following format_ids: | |
15 | * (which you can check by using `youtube-dl <url> -F`): | |
179bfea5 C |
16 | * - (webm vp9) |
17 | * - (mp4 avc1) | |
18 | * - (webm vp9.2 HDR) | |
59bbcced | 19 | */ |
179bfea5 | 20 | youtubeHDR: 'https://www.youtube.com/watch?v=RQgnBB9z_N4', |
59bbcced C |
21 | |
22 | // eslint-disable-next-line max-len | |
62549e6c | 23 | magnet: 'magnet:?xs=https%3A%2F%2Fpeertube2.cpy.re%2Flazy-static%2Ftorrents%2Fb209ca00-c8bb-4b2b-b421-1ede169f3dbc-720.torrent&xt=urn:btih:0f498834733e8057ed5c6f2ee2b4efd8d84a76ee&dn=super+peertube2+video&tr=https%3A%2F%2Fpeertube2.cpy.re%2Ftracker%2Fannounce&tr=wss%3A%2F%2Fpeertube2.cpy.re%3A443%2Ftracker%2Fsocket&ws=https%3A%2F%2Fpeertube2.cpy.re%2Fstatic%2Fwebseed%2Fb209ca00-c8bb-4b2b-b421-1ede169f3dbc-720.mp4', |
59bbcced C |
24 | |
25 | badVideo: 'https://download.cpy.re/peertube/bad_video.mp4', | |
26 | goodVideo: 'https://download.cpy.re/peertube/good_video.mp4', | |
0305db28 JB |
27 | goodVideo720: 'https://download.cpy.re/peertube/good_video_720.mp4', |
28 | ||
29 | file4K: 'https://download.cpy.re/peertube/4k_file.txt' | |
59bbcced C |
30 | } |
31 | ||
6c5065a0 C |
32 | function parallelTests () { |
33 | return process.env.MOCHA_PARALLEL === 'true' | |
34 | } | |
35 | ||
36 | function isGithubCI () { | |
37 | return !!process.env.GITHUB_WORKSPACE | |
38 | } | |
39 | ||
40 | function areHttpImportTestsDisabled () { | |
41 | const disabled = process.env.DISABLE_HTTP_IMPORT_TESTS === 'true' | |
42 | ||
0305db28 JB |
43 | if (disabled) console.log('DISABLE_HTTP_IMPORT_TESTS env set to "true" so import tests are disabled') |
44 | ||
45 | return disabled | |
46 | } | |
47 | ||
48 | function areObjectStorageTestsDisabled () { | |
49 | const disabled = process.env.ENABLE_OBJECT_STORAGE_TESTS !== 'true' | |
50 | ||
51 | if (disabled) console.log('ENABLE_OBJECT_STORAGE_TESTS env is not set to "true" so object storage tests are disabled') | |
6c5065a0 C |
52 | |
53 | return disabled | |
54 | } | |
55 | ||
56 | function buildAbsoluteFixturePath (path: string, customCIPath = false) { | |
57 | if (isAbsolute(path)) return path | |
58 | ||
59 | if (customCIPath && process.env.GITHUB_WORKSPACE) { | |
60 | return join(process.env.GITHUB_WORKSPACE, 'fixtures', path) | |
61 | } | |
62 | ||
63 | return join(root(), 'server', 'tests', 'fixtures', path) | |
64 | } | |
65 | ||
66 | function root () { | |
67 | // We are in /miscs | |
68 | let root = join(__dirname, '..', '..', '..') | |
69 | ||
70 | if (basename(root) === 'dist') root = resolve(root, '..') | |
71 | ||
72 | return root | |
73 | } | |
74 | ||
75 | function wait (milliseconds: number) { | |
76 | return new Promise(resolve => setTimeout(resolve, milliseconds)) | |
77 | } | |
78 | ||
79 | async function getFileSize (path: string) { | |
80 | const stats = await stat(path) | |
81 | ||
82 | return stats.size | |
83 | } | |
84 | ||
85 | function buildRequestStub (): any { | |
86 | return { } | |
87 | } | |
88 | ||
89 | export { | |
59bbcced C |
90 | FIXTURE_URLS, |
91 | ||
6c5065a0 C |
92 | parallelTests, |
93 | isGithubCI, | |
94 | areHttpImportTestsDisabled, | |
95 | buildAbsoluteFixturePath, | |
96 | getFileSize, | |
97 | buildRequestStub, | |
0305db28 | 98 | areObjectStorageTestsDisabled, |
6c5065a0 C |
99 | wait, |
100 | root | |
101 | } |