1 /* eslint-disable @typescript-eslint/no-unused-expressions,@typescript-eslint/require-await */
4 import * as chai from 'chai'
5 import { wait } from '@shared/core-utils'
6 import { LiveVideoError, VideoPrivacy } from '@shared/models'
10 createMultipleServers,
13 setAccessTokensToServers,
14 setDefaultVideoChannel,
16 waitUntilLiveWaitingOnAllServers
17 } from '@shared/server-commands'
18 import { checkLiveCleanup } from '../../shared'
20 const expect = chai.expect
22 describe('Test live constraints', function () {
23 let servers: PeerTubeServer[] = []
25 let userAccessToken: string
26 let userChannelId: number
28 async function createLiveWrapper (options: {
32 const { replay, permanent } = options
34 const liveAttributes = {
36 channelId: userChannelId,
37 privacy: VideoPrivacy.PUBLIC,
39 permanentLive: permanent
42 const { uuid } = await servers[0].live.create({ token: userAccessToken, fields: liveAttributes })
46 async function checkSaveReplay (videoId: string, resolutions = [ 720 ]) {
47 for (const server of servers) {
48 const video = await server.videos.get({ id: videoId })
49 expect(video.isLive).to.be.false
50 expect(video.duration).to.be.greaterThan(0)
53 await checkLiveCleanup(servers[0], videoId, resolutions)
56 async function waitUntilLivePublishedOnAllServers (videoId: string) {
57 for (const server of servers) {
58 await server.live.waitUntilPublished({ videoId })
62 function updateQuota (options: { total: number, daily: number }) {
63 return servers[0].users.update({
65 videoQuota: options.total,
66 videoQuotaDaily: options.daily
70 before(async function () {
73 servers = await createMultipleServers(2)
75 // Get the access tokens
76 await setAccessTokensToServers(servers)
77 await setDefaultVideoChannel(servers)
79 await servers[0].config.updateCustomSubConfig({
92 const res = await servers[0].users.generate('user1')
94 userChannelId = res.userChannelId
95 userAccessToken = res.token
97 await updateQuota({ total: 1, daily: -1 })
100 // Server 1 and server 2 follow each other
101 await doubleFollow(servers[0], servers[1])
104 it('Should not have size limit if save replay is disabled', async function () {
107 const userVideoLiveoId = await createLiveWrapper({ replay: false, permanent: false })
108 await servers[0].live.runAndTestStreamError({ token: userAccessToken, videoId: userVideoLiveoId, shouldHaveError: false })
111 it('Should have size limit depending on user global quota if save replay is enabled on non permanent live', async function () {
114 // Wait for user quota memoize cache invalidation
117 const userVideoLiveoId = await createLiveWrapper({ replay: true, permanent: false })
118 await servers[0].live.runAndTestStreamError({ token: userAccessToken, videoId: userVideoLiveoId, shouldHaveError: true })
120 await waitUntilLivePublishedOnAllServers(userVideoLiveoId)
121 await waitJobs(servers)
123 await checkSaveReplay(userVideoLiveoId)
125 const session = await servers[0].live.getReplaySession({ videoId: userVideoLiveoId })
126 expect(session.error).to.equal(LiveVideoError.QUOTA_EXCEEDED)
129 it('Should have size limit depending on user global quota if save replay is enabled on a permanent live', async function () {
132 // Wait for user quota memoize cache invalidation
135 const userVideoLiveoId = await createLiveWrapper({ replay: true, permanent: true })
136 await servers[0].live.runAndTestStreamError({ token: userAccessToken, videoId: userVideoLiveoId, shouldHaveError: true })
138 await waitJobs(servers)
139 await waitUntilLiveWaitingOnAllServers(servers, userVideoLiveoId)
141 const session = await servers[0].live.findLatestSession({ videoId: userVideoLiveoId })
142 expect(session.error).to.equal(LiveVideoError.QUOTA_EXCEEDED)
145 it('Should have size limit depending on user daily quota if save replay is enabled', async function () {
148 // Wait for user quota memoize cache invalidation
151 await updateQuota({ total: -1, daily: 1 })
153 const userVideoLiveoId = await createLiveWrapper({ replay: true, permanent: false })
154 await servers[0].live.runAndTestStreamError({ token: userAccessToken, videoId: userVideoLiveoId, shouldHaveError: true })
156 await waitUntilLivePublishedOnAllServers(userVideoLiveoId)
157 await waitJobs(servers)
159 await checkSaveReplay(userVideoLiveoId)
161 const session = await servers[0].live.getReplaySession({ videoId: userVideoLiveoId })
162 expect(session.error).to.equal(LiveVideoError.QUOTA_EXCEEDED)
165 it('Should succeed without quota limit', async function () {
168 // Wait for user quota memoize cache invalidation
171 await updateQuota({ total: 10 * 1000 * 1000, daily: -1 })
173 const userVideoLiveoId = await createLiveWrapper({ replay: true, permanent: false })
174 await servers[0].live.runAndTestStreamError({ token: userAccessToken, videoId: userVideoLiveoId, shouldHaveError: false })
177 it('Should have max duration limit', async function () {
180 await servers[0].config.updateCustomSubConfig({
188 resolutions: ConfigCommand.getCustomConfigResolutions(true)
194 const userVideoLiveoId = await createLiveWrapper({ replay: true, permanent: false })
195 await servers[0].live.runAndTestStreamError({ token: userAccessToken, videoId: userVideoLiveoId, shouldHaveError: true })
197 await waitUntilLivePublishedOnAllServers(userVideoLiveoId)
198 await waitJobs(servers)
200 await checkSaveReplay(userVideoLiveoId, [ 720, 480, 360, 240, 144 ])
202 const session = await servers[0].live.getReplaySession({ videoId: userVideoLiveoId })
203 expect(session.error).to.equal(LiveVideoError.DURATION_EXCEEDED)
206 after(async function () {
207 await cleanupTests(servers)