]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blame - server/tests/api/check-params/video-files.ts
Channel sync (#5135)
[github/Chocobozzz/PeerTube.git] / server / tests / api / check-params / video-files.ts
CommitLineData
b46cf4b9
C
1/* eslint-disable @typescript-eslint/no-unused-expressions,@typescript-eslint/require-await */
2
3import 'mocha'
b46cf4b9 4import { HttpStatusCode, UserRole } from '@shared/models'
c55e3d72
C
5import {
6 cleanupTests,
7 createMultipleServers,
8 doubleFollow,
9 PeerTubeServer,
10 setAccessTokensToServers,
11 waitJobs
12} from '@shared/server-commands'
b46cf4b9
C
13
14describe('Test videos files', function () {
15 let servers: PeerTubeServer[]
ad5db104 16
b46cf4b9
C
17 let webtorrentId: string
18 let hlsId: string
19 let remoteId: string
ad5db104 20
b46cf4b9
C
21 let userToken: string
22 let moderatorToken: string
ad5db104 23
b46cf4b9
C
24 let validId1: string
25 let validId2: string
26
1bb4c9ab
C
27 let hlsFileId: number
28 let webtorrentFileId: number
29
30 let remoteHLSFileId: number
31 let remoteWebtorrentFileId: number
32
b46cf4b9
C
33 // ---------------------------------------------------------------
34
35 before(async function () {
5d3c5f27 36 this.timeout(300_000)
b46cf4b9
C
37
38 servers = await createMultipleServers(2)
39 await setAccessTokensToServers(servers)
40
ad5db104
C
41 await doubleFollow(servers[0], servers[1])
42
b46cf4b9
C
43 userToken = await servers[0].users.generateUserAndToken('user', UserRole.USER)
44 moderatorToken = await servers[0].users.generateUserAndToken('moderator', UserRole.MODERATOR)
45
ad5db104
C
46 {
47 const { uuid } = await servers[1].videos.quickUpload({ name: 'remote video' })
1bb4c9ab
C
48 await waitJobs(servers)
49
50 const video = await servers[1].videos.get({ id: uuid })
51 remoteId = video.uuid
52 remoteHLSFileId = video.streamingPlaylists[0].files[0].id
53 remoteWebtorrentFileId = video.files[0].id
ad5db104
C
54 }
55
b46cf4b9
C
56 {
57 await servers[0].config.enableTranscoding(true, true)
58
59 {
60 const { uuid } = await servers[0].videos.quickUpload({ name: 'both 1' })
1bb4c9ab
C
61 await waitJobs(servers)
62
63 const video = await servers[0].videos.get({ id: uuid })
64 validId1 = video.uuid
65 hlsFileId = video.streamingPlaylists[0].files[0].id
66 webtorrentFileId = video.files[0].id
b46cf4b9
C
67 }
68
69 {
70 const { uuid } = await servers[0].videos.quickUpload({ name: 'both 2' })
71 validId2 = uuid
72 }
73 }
74
75 await waitJobs(servers)
76
77 {
78 await servers[0].config.enableTranscoding(false, true)
79 const { uuid } = await servers[0].videos.quickUpload({ name: 'hls' })
80 hlsId = uuid
81 }
82
83 await waitJobs(servers)
84
85 {
86 await servers[0].config.enableTranscoding(false, true)
87 const { uuid } = await servers[0].videos.quickUpload({ name: 'webtorrent' })
88 webtorrentId = uuid
89 }
90
91 await waitJobs(servers)
92 })
93
ad5db104 94 it('Should not delete files of a unknown video', async function () {
1bb4c9ab
C
95 const expectedStatus = HttpStatusCode.NOT_FOUND_404
96
97 await servers[0].videos.removeHLSPlaylist({ videoId: 404, expectedStatus })
98 await servers[0].videos.removeAllWebTorrentFiles({ videoId: 404, expectedStatus })
99
100 await servers[0].videos.removeHLSFile({ videoId: 404, fileId: hlsFileId, expectedStatus })
101 await servers[0].videos.removeWebTorrentFile({ videoId: 404, fileId: webtorrentFileId, expectedStatus })
102 })
103
104 it('Should not delete unknown files', async function () {
105 const expectedStatus = HttpStatusCode.NOT_FOUND_404
106
107 await servers[0].videos.removeHLSFile({ videoId: validId1, fileId: webtorrentFileId, expectedStatus })
108 await servers[0].videos.removeWebTorrentFile({ videoId: validId1, fileId: hlsFileId, expectedStatus })
ad5db104
C
109 })
110
b46cf4b9 111 it('Should not delete files of a remote video', async function () {
1bb4c9ab
C
112 const expectedStatus = HttpStatusCode.BAD_REQUEST_400
113
114 await servers[0].videos.removeHLSPlaylist({ videoId: remoteId, expectedStatus })
115 await servers[0].videos.removeAllWebTorrentFiles({ videoId: remoteId, expectedStatus })
116
117 await servers[0].videos.removeHLSFile({ videoId: remoteId, fileId: remoteHLSFileId, expectedStatus })
118 await servers[0].videos.removeWebTorrentFile({ videoId: remoteId, fileId: remoteWebtorrentFileId, expectedStatus })
b46cf4b9
C
119 })
120
121 it('Should not delete files by a non admin user', async function () {
122 const expectedStatus = HttpStatusCode.FORBIDDEN_403
123
1bb4c9ab
C
124 await servers[0].videos.removeHLSPlaylist({ videoId: validId1, token: userToken, expectedStatus })
125 await servers[0].videos.removeHLSPlaylist({ videoId: validId1, token: moderatorToken, expectedStatus })
126
127 await servers[0].videos.removeAllWebTorrentFiles({ videoId: validId1, token: userToken, expectedStatus })
128 await servers[0].videos.removeAllWebTorrentFiles({ videoId: validId1, token: moderatorToken, expectedStatus })
b46cf4b9 129
1bb4c9ab
C
130 await servers[0].videos.removeHLSFile({ videoId: validId1, fileId: hlsFileId, token: userToken, expectedStatus })
131 await servers[0].videos.removeHLSFile({ videoId: validId1, fileId: hlsFileId, token: moderatorToken, expectedStatus })
132
133 await servers[0].videos.removeWebTorrentFile({ videoId: validId1, fileId: webtorrentFileId, token: userToken, expectedStatus })
134 await servers[0].videos.removeWebTorrentFile({ videoId: validId1, fileId: webtorrentFileId, token: moderatorToken, expectedStatus })
b46cf4b9
C
135 })
136
137 it('Should not delete files if the files are not available', async function () {
1bb4c9ab
C
138 await servers[0].videos.removeHLSPlaylist({ videoId: hlsId, expectedStatus: HttpStatusCode.BAD_REQUEST_400 })
139 await servers[0].videos.removeAllWebTorrentFiles({ videoId: webtorrentId, expectedStatus: HttpStatusCode.BAD_REQUEST_400 })
b46cf4b9 140
1bb4c9ab
C
141 await servers[0].videos.removeHLSFile({ videoId: hlsId, fileId: 404, expectedStatus: HttpStatusCode.NOT_FOUND_404 })
142 await servers[0].videos.removeWebTorrentFile({ videoId: webtorrentId, fileId: 404, expectedStatus: HttpStatusCode.NOT_FOUND_404 })
b46cf4b9
C
143 })
144
145 it('Should not delete files if no both versions are available', async function () {
1bb4c9ab
C
146 await servers[0].videos.removeHLSPlaylist({ videoId: hlsId, expectedStatus: HttpStatusCode.BAD_REQUEST_400 })
147 await servers[0].videos.removeAllWebTorrentFiles({ videoId: webtorrentId, expectedStatus: HttpStatusCode.BAD_REQUEST_400 })
b46cf4b9
C
148 })
149
150 it('Should delete files if both versions are available', async function () {
1bb4c9ab
C
151 await servers[0].videos.removeHLSFile({ videoId: validId1, fileId: hlsFileId })
152 await servers[0].videos.removeWebTorrentFile({ videoId: validId1, fileId: webtorrentFileId })
153
154 await servers[0].videos.removeHLSPlaylist({ videoId: validId1 })
155 await servers[0].videos.removeAllWebTorrentFiles({ videoId: validId2 })
b46cf4b9
C
156 })
157
158 after(async function () {
159 await cleanupTests(servers)
160 })
161})