]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blame_incremental - server/tests/cli/prune-storage.ts
Introduce accounts command
[github/Chocobozzz/PeerTube.git] / server / tests / cli / prune-storage.ts
... / ...
CommitLineData
1/* eslint-disable @typescript-eslint/no-unused-expressions,@typescript-eslint/require-await */
2
3import 'mocha'
4import * as chai from 'chai'
5import { createFile, readdir } from 'fs-extra'
6import { join } from 'path'
7import { buildUUID } from '@server/helpers/uuid'
8import { HttpStatusCode } from '@shared/core-utils'
9import {
10 buildServerDirectory,
11 cleanupTests,
12 CLICommand,
13 createVideoPlaylist,
14 doubleFollow,
15 flushAndRunMultipleServers,
16 killallServers,
17 makeGetRequest,
18 ServerInfo,
19 setAccessTokensToServers,
20 setDefaultVideoChannel,
21 updateMyAvatar,
22 uploadVideo,
23 wait,
24 waitJobs
25} from '@shared/extra-utils'
26import { VideoPlaylistPrivacy } from '@shared/models'
27
28const expect = chai.expect
29
30async function countFiles (internalServerNumber: number, directory: string) {
31 const files = await readdir(buildServerDirectory({ internalServerNumber }, directory))
32
33 return files.length
34}
35
36async function assertNotExists (internalServerNumber: number, directory: string, substring: string) {
37 const files = await readdir(buildServerDirectory({ internalServerNumber }, directory))
38
39 for (const f of files) {
40 expect(f).to.not.contain(substring)
41 }
42}
43
44async function assertCountAreOkay (servers: ServerInfo[]) {
45 for (const server of servers) {
46 const videosCount = await countFiles(server.internalServerNumber, 'videos')
47 expect(videosCount).to.equal(8)
48
49 const torrentsCount = await countFiles(server.internalServerNumber, 'torrents')
50 expect(torrentsCount).to.equal(16)
51
52 const previewsCount = await countFiles(server.internalServerNumber, 'previews')
53 expect(previewsCount).to.equal(2)
54
55 const thumbnailsCount = await countFiles(server.internalServerNumber, 'thumbnails')
56 expect(thumbnailsCount).to.equal(6)
57
58 const avatarsCount = await countFiles(server.internalServerNumber, 'avatars')
59 expect(avatarsCount).to.equal(2)
60 }
61}
62
63describe('Test prune storage scripts', function () {
64 let servers: ServerInfo[]
65 const badNames: { [directory: string]: string[] } = {}
66
67 before(async function () {
68 this.timeout(120000)
69
70 servers = await flushAndRunMultipleServers(2, { transcoding: { enabled: true } })
71 await setAccessTokensToServers(servers)
72 await setDefaultVideoChannel(servers)
73
74 for (const server of servers) {
75 await uploadVideo(server.url, server.accessToken, { name: 'video 1' })
76 await uploadVideo(server.url, server.accessToken, { name: 'video 2' })
77
78 await updateMyAvatar({ url: server.url, accessToken: server.accessToken, fixture: 'avatar.png' })
79
80 await createVideoPlaylist({
81 url: server.url,
82 token: server.accessToken,
83 playlistAttrs: {
84 displayName: 'playlist',
85 privacy: VideoPlaylistPrivacy.PUBLIC,
86 videoChannelId: server.videoChannel.id,
87 thumbnailfile: 'thumbnail.jpg'
88 }
89 })
90 }
91
92 await doubleFollow(servers[0], servers[1])
93
94 // Lazy load the remote avatar
95 {
96 const account = await servers[0].accountsCommand.get({ accountName: 'root@localhost:' + servers[1].port })
97 await makeGetRequest({
98 url: servers[0].url,
99 path: account.avatar.path,
100 statusCodeExpected: HttpStatusCode.OK_200
101 })
102 }
103
104 {
105 const account = await servers[1].accountsCommand.get({ accountName: 'root@localhost:' + servers[0].port })
106 await makeGetRequest({
107 url: servers[1].url,
108 path: account.avatar.path,
109 statusCodeExpected: HttpStatusCode.OK_200
110 })
111 }
112
113 await wait(1000)
114
115 await waitJobs(servers)
116 killallServers(servers)
117
118 await wait(1000)
119 })
120
121 it('Should have the files on the disk', async function () {
122 await assertCountAreOkay(servers)
123 })
124
125 it('Should create some dirty files', async function () {
126 for (let i = 0; i < 2; i++) {
127 {
128 const base = buildServerDirectory(servers[0], 'videos')
129
130 const n1 = buildUUID() + '.mp4'
131 const n2 = buildUUID() + '.webm'
132
133 await createFile(join(base, n1))
134 await createFile(join(base, n2))
135
136 badNames['videos'] = [ n1, n2 ]
137 }
138
139 {
140 const base = buildServerDirectory(servers[0], 'torrents')
141
142 const n1 = buildUUID() + '-240.torrent'
143 const n2 = buildUUID() + '-480.torrent'
144
145 await createFile(join(base, n1))
146 await createFile(join(base, n2))
147
148 badNames['torrents'] = [ n1, n2 ]
149 }
150
151 {
152 const base = buildServerDirectory(servers[0], 'thumbnails')
153
154 const n1 = buildUUID() + '.jpg'
155 const n2 = buildUUID() + '.jpg'
156
157 await createFile(join(base, n1))
158 await createFile(join(base, n2))
159
160 badNames['thumbnails'] = [ n1, n2 ]
161 }
162
163 {
164 const base = buildServerDirectory(servers[0], 'previews')
165
166 const n1 = buildUUID() + '.jpg'
167 const n2 = buildUUID() + '.jpg'
168
169 await createFile(join(base, n1))
170 await createFile(join(base, n2))
171
172 badNames['previews'] = [ n1, n2 ]
173 }
174
175 {
176 const base = buildServerDirectory(servers[0], 'avatars')
177
178 const n1 = buildUUID() + '.png'
179 const n2 = buildUUID() + '.jpg'
180
181 await createFile(join(base, n1))
182 await createFile(join(base, n2))
183
184 badNames['avatars'] = [ n1, n2 ]
185 }
186 }
187 })
188
189 it('Should run prune storage', async function () {
190 this.timeout(30000)
191
192 const env = servers[0].cliCommand.getEnv()
193 await CLICommand.exec(`echo y | ${env} npm run prune-storage`)
194 })
195
196 it('Should have removed files', async function () {
197 await assertCountAreOkay(servers)
198
199 for (const directory of Object.keys(badNames)) {
200 for (const name of badNames[directory]) {
201 await assertNotExists(servers[0].internalServerNumber, directory, name)
202 }
203 }
204 })
205
206 after(async function () {
207 await cleanupTests(servers)
208 })
209})