/* eslint-disable @typescript-eslint/no-unused-expressions,@typescript-eslint/require-await */ import 'mocha' import { expect } from 'chai' import { HttpStatusCode, randomInt } from '@shared/core-utils' import { VideoImportState, VideoPrivacy } from '@shared/models' import { cleanupTests, flushAndRunServer, ImportsCommand, ServerInfo, setAccessTokensToServers, setDefaultVideoChannel, uploadVideo, waitJobs } from '../../../../shared/extra-utils' describe('Test upload quota', function () { let server: ServerInfo let rootId: number // --------------------------------------------------------------- before(async function () { this.timeout(30000) server = await flushAndRunServer(1) await setAccessTokensToServers([ server ]) await setDefaultVideoChannel([ server ]) const user = await server.usersCommand.getMyInfo() rootId = user.id await server.usersCommand.update({ userId: rootId, videoQuota: 42 }) }) describe('When having a video quota', function () { it('Should fail with a registered user having too many videos with legacy upload', async function () { this.timeout(30000) const user = { username: 'registered' + randomInt(1, 1500), password: 'password' } await server.usersCommand.register(user) const userAccessToken = await server.loginCommand.getAccessToken(user) const videoAttributes = { fixture: 'video_short2.webm' } for (let i = 0; i < 5; i++) { await uploadVideo(server.url, userAccessToken, videoAttributes) } await uploadVideo(server.url, userAccessToken, videoAttributes, HttpStatusCode.PAYLOAD_TOO_LARGE_413, 'legacy') }) it('Should fail with a registered user having too many videos with resumable upload', async function () { this.timeout(30000) const user = { username: 'registered' + randomInt(1, 1500), password: 'password' } await server.usersCommand.register(user) const userAccessToken = await server.loginCommand.getAccessToken(user) const videoAttributes = { fixture: 'video_short2.webm' } for (let i = 0; i < 5; i++) { await uploadVideo(server.url, userAccessToken, videoAttributes) } await uploadVideo(server.url, userAccessToken, videoAttributes, HttpStatusCode.PAYLOAD_TOO_LARGE_413, 'resumable') }) it('Should fail to import with HTTP/Torrent/magnet', async function () { this.timeout(120000) const baseAttributes = { channelId: server.videoChannel.id, privacy: VideoPrivacy.PUBLIC } await server.importsCommand.importVideo({ attributes: { ...baseAttributes, targetUrl: ImportsCommand.getGoodVideoUrl() } }) await server.importsCommand.importVideo({ attributes: { ...baseAttributes, magnetUri: ImportsCommand.getMagnetURI() } }) await server.importsCommand.importVideo({ attributes: { ...baseAttributes, torrentfile: 'video-720p.torrent' as any } }) await waitJobs([ server ]) const { total, data: videoImports } = await server.importsCommand.getMyVideoImports() expect(total).to.equal(3) expect(videoImports).to.have.lengthOf(3) for (const videoImport of videoImports) { expect(videoImport.state.id).to.equal(VideoImportState.FAILED) expect(videoImport.error).not.to.be.undefined expect(videoImport.error).to.contain('user video quota is exceeded') } }) }) describe('When having a daily video quota', function () { it('Should fail with a user having too many videos daily', async function () { await server.usersCommand.update({ userId: rootId, videoQuotaDaily: 42 }) await uploadVideo(server.url, server.accessToken, {}, HttpStatusCode.PAYLOAD_TOO_LARGE_413, 'legacy') await uploadVideo(server.url, server.accessToken, {}, HttpStatusCode.PAYLOAD_TOO_LARGE_413, 'resumable') }) }) describe('When having an absolute and daily video quota', function () { it('Should fail if exceeding total quota', async function () { await server.usersCommand.update({ userId: rootId, videoQuota: 42, videoQuotaDaily: 1024 * 1024 * 1024 }) await uploadVideo(server.url, server.accessToken, {}, HttpStatusCode.PAYLOAD_TOO_LARGE_413, 'legacy') await uploadVideo(server.url, server.accessToken, {}, HttpStatusCode.PAYLOAD_TOO_LARGE_413, 'resumable') }) it('Should fail if exceeding daily quota', async function () { await server.usersCommand.update({ userId: rootId, videoQuota: 1024 * 1024 * 1024, videoQuotaDaily: 42 }) await uploadVideo(server.url, server.accessToken, {}, HttpStatusCode.PAYLOAD_TOO_LARGE_413, 'legacy') await uploadVideo(server.url, server.accessToken, {}, HttpStatusCode.PAYLOAD_TOO_LARGE_413, 'resumable') }) }) after(async function () { await cleanupTests([ server ]) }) })