/* eslint-disable @typescript-eslint/no-unused-expressions,@typescript-eslint/require-await */
import 'mocha'
-import * as chai from 'chai'
import { omit } from 'lodash'
-import { join } from 'path'
-import { LiveVideo, VideoPrivacy } from '@shared/models'
+import { VideoCreateResult, VideoPrivacy } from '@shared/models'
+import { HttpStatusCode } from '../../../../shared/core-utils/miscs/http-error-codes'
import {
+ buildAbsoluteFixturePath,
cleanupTests,
createUser,
flushAndRunServer,
- getLive,
getMyUserInformation,
immutableAssign,
+ LiveCommand,
makePostBodyRequest,
makeUploadRequest,
sendRTMPStream,
ServerInfo,
setAccessTokensToServers,
stopFfmpeg,
- updateCustomSubConfig,
- updateLive,
uploadVideoAndGetId,
- userLogin,
- waitUntilLiveStarts
+ userLogin
} from '../../../../shared/extra-utils'
describe('Test video lives API validator', function () {
const path = '/api/v1/videos/live'
let server: ServerInfo
let userAccessToken = ''
- let accountName: string
let channelId: number
- let channelName: string
- let videoId: number
+ let video: VideoCreateResult
let videoIdNotLive: number
+ let command: LiveCommand
// ---------------------------------------------------------------
await setAccessTokensToServers([ server ])
- await updateCustomSubConfig(server.url, server.accessToken, {
- live: {
- enabled: true,
- maxInstanceLives: 20,
- maxUserLives: 20,
- allowReplay: true
+ await server.configCommand.updateCustomSubConfig({
+ newConfig: {
+ live: {
+ enabled: true,
+ maxInstanceLives: 20,
+ maxUserLives: 20,
+ allowReplay: true
+ }
}
})
{
videoIdNotLive = (await uploadVideoAndGetId({ server, videoName: 'not live' })).id
}
+
+ command = server.liveCommand
})
describe('When creating a live', function () {
tags: [ 'tag1', 'tag2' ],
privacy: VideoPrivacy.PUBLIC,
channelId,
- saveReplay: false
+ saveReplay: false,
+ permanentLive: false
}
})
it('Should fail with an incorrect thumbnail file', async function () {
const fields = baseCorrectParams
const attaches = {
- thumbnailfile: join(__dirname, '..', '..', 'fixtures', 'avatar.png')
+ thumbnailfile: buildAbsoluteFixturePath('video_short.mp4')
}
await makeUploadRequest({ url: server.url, path, token: server.accessToken, fields, attaches })
it('Should fail with a big thumbnail file', async function () {
const fields = baseCorrectParams
const attaches = {
- thumbnailfile: join(__dirname, '..', '..', 'fixtures', 'avatar-big.png')
+ thumbnailfile: buildAbsoluteFixturePath('preview-big.png')
}
await makeUploadRequest({ url: server.url, path, token: server.accessToken, fields, attaches })
it('Should fail with an incorrect preview file', async function () {
const fields = baseCorrectParams
const attaches = {
- previewfile: join(__dirname, '..', '..', 'fixtures', 'avatar.png')
+ previewfile: buildAbsoluteFixturePath('video_short.mp4')
}
await makeUploadRequest({ url: server.url, path, token: server.accessToken, fields, attaches })
it('Should fail with a big preview file', async function () {
const fields = baseCorrectParams
const attaches = {
- previewfile: join(__dirname, '..', '..', 'fixtures', 'avatar-big.png')
+ previewfile: buildAbsoluteFixturePath('preview-big.png')
}
await makeUploadRequest({ url: server.url, path, token: server.accessToken, fields, attaches })
})
+ it('Should fail with save replay and permanent live set to true', async function () {
+ const fields = immutableAssign(baseCorrectParams, { saveReplay: true, permanentLive: true })
+
+ await makePostBodyRequest({ url: server.url, path, token: server.accessToken, fields })
+ })
+
it('Should succeed with the correct parameters', async function () {
this.timeout(30000)
path,
token: server.accessToken,
fields: baseCorrectParams,
- statusCodeExpected: 200
+ statusCodeExpected: HttpStatusCode.OK_200
})
- videoId = res.body.video.id
+ video = res.body.video
})
it('Should forbid if live is disabled', async function () {
- await updateCustomSubConfig(server.url, server.accessToken, {
- live: {
- enabled: false
+ await server.configCommand.updateCustomSubConfig({
+ newConfig: {
+ live: {
+ enabled: false
+ }
}
})
path,
token: server.accessToken,
fields: baseCorrectParams,
- statusCodeExpected: 403
+ statusCodeExpected: HttpStatusCode.FORBIDDEN_403
})
})
it('Should forbid to save replay if not enabled by the admin', async function () {
const fields = immutableAssign(baseCorrectParams, { saveReplay: true })
- await updateCustomSubConfig(server.url, server.accessToken, {
- live: {
- enabled: true,
- allowReplay: false
+ await server.configCommand.updateCustomSubConfig({
+ newConfig: {
+ live: {
+ enabled: true,
+ allowReplay: false
+ }
}
})
path,
token: server.accessToken,
fields,
- statusCodeExpected: 403
+ statusCodeExpected: HttpStatusCode.FORBIDDEN_403
})
})
it('Should allow to save replay if enabled by the admin', async function () {
const fields = immutableAssign(baseCorrectParams, { saveReplay: true })
- await updateCustomSubConfig(server.url, server.accessToken, {
- live: {
- enabled: true,
- allowReplay: true
+ await server.configCommand.updateCustomSubConfig({
+ newConfig: {
+ live: {
+ enabled: true,
+ allowReplay: true
+ }
}
})
path,
token: server.accessToken,
fields,
- statusCodeExpected: 200
+ statusCodeExpected: HttpStatusCode.OK_200
})
})
it('Should not allow live if max instance lives is reached', async function () {
- await updateCustomSubConfig(server.url, server.accessToken, {
- live: {
- enabled: true,
- maxInstanceLives: 1
+ await server.configCommand.updateCustomSubConfig({
+ newConfig: {
+ live: {
+ enabled: true,
+ maxInstanceLives: 1
+ }
}
})
path,
token: server.accessToken,
fields: baseCorrectParams,
- statusCodeExpected: 403
+ statusCodeExpected: HttpStatusCode.FORBIDDEN_403
})
})
it('Should not allow live if max user lives is reached', async function () {
- await updateCustomSubConfig(server.url, server.accessToken, {
- live: {
- enabled: true,
- maxInstanceLives: 20,
- maxUserLives: 1
+ await server.configCommand.updateCustomSubConfig({
+ newConfig: {
+ live: {
+ enabled: true,
+ maxInstanceLives: 20,
+ maxUserLives: 1
+ }
}
})
path,
token: server.accessToken,
fields: baseCorrectParams,
- statusCodeExpected: 403
+ statusCodeExpected: HttpStatusCode.FORBIDDEN_403
})
})
})
describe('When getting live information', function () {
it('Should fail without access token', async function () {
- await getLive(server.url, '', videoId, 401)
+ await command.get({ token: '', videoId: video.id, expectedStatus: HttpStatusCode.UNAUTHORIZED_401 })
})
it('Should fail with a bad access token', async function () {
- await getLive(server.url, 'toto', videoId, 401)
+ await command.get({ token: 'toto', videoId: video.id, expectedStatus: HttpStatusCode.UNAUTHORIZED_401 })
})
it('Should fail with access token of another user', async function () {
- await getLive(server.url, userAccessToken, videoId, 403)
+ await command.get({ token: userAccessToken, videoId: video.id, expectedStatus: HttpStatusCode.FORBIDDEN_403 })
})
it('Should fail with a bad video id', async function () {
- await getLive(server.url, server.accessToken, 'toto', 400)
+ await command.get({ videoId: 'toto', expectedStatus: HttpStatusCode.BAD_REQUEST_400 })
})
it('Should fail with an unknown video id', async function () {
- await getLive(server.url, server.accessToken, 454555, 404)
+ await command.get({ videoId: 454555, expectedStatus: HttpStatusCode.NOT_FOUND_404 })
})
it('Should fail with a non live video', async function () {
- await getLive(server.url, server.accessToken, videoIdNotLive, 404)
+ await command.get({ videoId: videoIdNotLive, expectedStatus: HttpStatusCode.NOT_FOUND_404 })
})
it('Should succeed with the correct params', async function () {
- await getLive(server.url, server.accessToken, videoId)
+ await command.get({ videoId: video.id })
+ await command.get({ videoId: video.uuid })
+ await command.get({ videoId: video.shortUUID })
})
})
describe('When updating live information', async function () {
it('Should fail without access token', async function () {
- await updateLive(server.url, '', videoId, {}, 401)
+ await command.update({ token: '', videoId: video.id, fields: {}, expectedStatus: HttpStatusCode.UNAUTHORIZED_401 })
})
it('Should fail with a bad access token', async function () {
- await updateLive(server.url, 'toto', videoId, {}, 401)
+ await command.update({ token: 'toto', videoId: video.id, fields: {}, expectedStatus: HttpStatusCode.UNAUTHORIZED_401 })
})
it('Should fail with access token of another user', async function () {
- await updateLive(server.url, userAccessToken, videoId, {}, 403)
+ await command.update({ token: userAccessToken, videoId: video.id, fields: {}, expectedStatus: HttpStatusCode.FORBIDDEN_403 })
})
it('Should fail with a bad video id', async function () {
- await updateLive(server.url, server.accessToken, 'toto', {}, 400)
+ await command.update({ videoId: 'toto', fields: {}, expectedStatus: HttpStatusCode.BAD_REQUEST_400 })
})
it('Should fail with an unknown video id', async function () {
- await updateLive(server.url, server.accessToken, 454555, {}, 404)
+ await command.update({ videoId: 454555, fields: {}, expectedStatus: HttpStatusCode.NOT_FOUND_404 })
})
it('Should fail with a non live video', async function () {
- await updateLive(server.url, server.accessToken, videoIdNotLive, {}, 404)
+ await command.update({ videoId: videoIdNotLive, fields: {}, expectedStatus: HttpStatusCode.NOT_FOUND_404 })
+ })
+
+ it('Should fail with save replay and permanent live set to true', async function () {
+ const fields = { saveReplay: true, permanentLive: true }
+
+ await command.update({ videoId: video.id, fields, expectedStatus: HttpStatusCode.BAD_REQUEST_400 })
})
it('Should succeed with the correct params', async function () {
- await updateLive(server.url, server.accessToken, videoId, { saveReplay: false })
+ await command.update({ videoId: video.id, fields: { saveReplay: false } })
+ await command.update({ videoId: video.uuid, fields: { saveReplay: false } })
+ await command.update({ videoId: video.shortUUID, fields: { saveReplay: false } })
})
it('Should fail to update replay status if replay is not allowed on the instance', async function () {
- await updateCustomSubConfig(server.url, server.accessToken, {
- live: {
- enabled: true,
- allowReplay: false
+ await server.configCommand.updateCustomSubConfig({
+ newConfig: {
+ live: {
+ enabled: true,
+ allowReplay: false
+ }
}
})
- await updateLive(server.url, server.accessToken, videoId, { saveReplay: true }, 403)
+ await command.update({ videoId: video.id, fields: { saveReplay: true }, expectedStatus: HttpStatusCode.FORBIDDEN_403 })
})
it('Should fail to update a live if it has already started', async function () {
- this.timeout(20000)
+ this.timeout(40000)
+
+ const live = await command.get({ videoId: video.id })
+
+ const ffmpegCommand = sendRTMPStream(live.rtmpUrl, live.streamKey)
+
+ await command.waitUntilPublished({ videoId: video.id })
+ await command.update({ videoId: video.id, fields: {}, expectedStatus: HttpStatusCode.BAD_REQUEST_400 })
+
+ await stopFfmpeg(ffmpegCommand)
+ })
+
+ it('Should fail to stream twice in the save live', async function () {
+ this.timeout(40000)
+
+ const live = await command.get({ videoId: video.id })
- const resLive = await getLive(server.url, server.accessToken, videoId)
- const live: LiveVideo = resLive.body
+ const ffmpegCommand = sendRTMPStream(live.rtmpUrl, live.streamKey)
- const command = sendRTMPStream(live.rtmpUrl, live.streamKey)
+ await command.waitUntilPublished({ videoId: video.id })
- await waitUntilLiveStarts(server.url, server.accessToken, videoId)
- await updateLive(server.url, server.accessToken, videoId, {}, 400)
+ await command.runAndTestStreamError({ videoId: video.id, shouldHaveError: true })
- await stopFfmpeg(command)
+ await stopFfmpeg(ffmpegCommand)
})
})