import { createFile, readdir } from 'fs-extra'
import { join } from 'path'
import { buildUUID } from '@server/helpers/uuid'
-import { HttpStatusCode } from '@shared/core-utils'
import {
cleanupTests,
CLICommand,
- doubleFollow,
createMultipleServers,
+ doubleFollow,
killallServers,
makeGetRequest,
PeerTubeServer,
wait,
waitJobs
} from '@shared/extra-utils'
-import { VideoPlaylistPrivacy } from '@shared/models'
+import { HttpStatusCode, VideoPlaylistPrivacy } from '@shared/models'
const expect = chai.expect
}
}
-async function assertCountAreOkay (servers: PeerTubeServer[]) {
+async function assertCountAreOkay (servers: PeerTubeServer[], videoServer2UUID: string) {
for (const server of servers) {
const videosCount = await countFiles(server, 'videos')
expect(videosCount).to.equal(8)
const avatarsCount = await countFiles(server, 'avatars')
expect(avatarsCount).to.equal(2)
}
+
+ // When we'll prune HLS directories too
+ // const hlsRootCount = await countFiles(servers[1], 'streaming-playlists/hls/')
+ // expect(hlsRootCount).to.equal(2)
+
+ // const hlsCount = await countFiles(servers[1], 'streaming-playlists/hls/' + videoServer2UUID)
+ // expect(hlsCount).to.equal(10)
}
describe('Test prune storage scripts', function () {
let servers: PeerTubeServer[]
const badNames: { [directory: string]: string[] } = {}
+ let videoServer2UUID: string
+
before(async function () {
this.timeout(120000)
for (const server of servers) {
await server.videos.upload({ attributes: { name: 'video 1' } })
- await server.videos.upload({ attributes: { name: 'video 2' } })
+
+ const { uuid } = await server.videos.upload({ attributes: { name: 'video 2' } })
+ if (server.serverNumber === 2) videoServer2UUID = uuid
await server.users.updateMyAvatar({ fixture: 'avatar.png' })
await makeGetRequest({
url: servers[0].url,
path: account.avatar.path,
- statusCodeExpected: HttpStatusCode.OK_200
+ expectedStatus: HttpStatusCode.OK_200
})
}
await makeGetRequest({
url: servers[1].url,
path: account.avatar.path,
- statusCodeExpected: HttpStatusCode.OK_200
+ expectedStatus: HttpStatusCode.OK_200
})
}
})
it('Should have the files on the disk', async function () {
- await assertCountAreOkay(servers)
+ await assertCountAreOkay(servers, videoServer2UUID)
})
it('Should create some dirty files', async function () {
badNames['avatars'] = [ n1, n2 ]
}
+
+ // When we'll prune HLS directories too
+ // {
+ // const directory = join('streaming-playlists', 'hls')
+ // const base = servers[1].servers.buildDirectory(directory)
+
+ // const n1 = buildUUID()
+ // await createFile(join(base, n1))
+ // badNames[directory] = [ n1 ]
+ // }
+
+ // {
+ // const directory = join('streaming-playlists', 'hls', videoServer2UUID)
+ // const base = servers[1].servers.buildDirectory(directory)
+ // const n1 = buildUUID() + '-240-fragmented-.mp4'
+ // const n2 = buildUUID() + '-master.m3u8'
+
+ // await createFile(join(base, n1))
+ // await createFile(join(base, n2))
+
+ // badNames[directory] = [ n1, n2 ]
+ // }
}
})
})
it('Should have removed files', async function () {
- await assertCountAreOkay(servers)
+ await assertCountAreOkay(servers, videoServer2UUID)
for (const directory of Object.keys(badNames)) {
for (const name of badNames[directory]) {