import 'mocha'
import { omit } from 'lodash'
-import { join } from 'path'
-import { LiveVideo, VideoPrivacy } from '@shared/models'
+import { LiveVideo, VideoCreateResult, VideoPrivacy } from '@shared/models'
+import { HttpStatusCode } from '../../../../shared/core-utils/miscs/http-error-codes'
import {
+ buildAbsoluteFixturePath,
cleanupTests,
createUser,
flushAndRunServer,
ServerInfo,
setAccessTokensToServers,
stopFfmpeg,
- updateCustomSubConfig,
updateLive,
uploadVideoAndGetId,
userLogin,
waitUntilLivePublished
} from '../../../../shared/extra-utils'
-import { HttpStatusCode } from '../../../../shared/core-utils/miscs/http-error-codes'
describe('Test video lives API validator', function () {
const path = '/api/v1/videos/live'
let server: ServerInfo
let userAccessToken = ''
let channelId: number
- let videoId: number
+ let video: VideoCreateResult
let videoIdNotLive: number
// ---------------------------------------------------------------
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
+ }
}
})
it('Should fail with an incorrect thumbnail file', async function () {
const fields = baseCorrectParams
const attaches = {
- thumbnailfile: join(__dirname, '..', '..', 'fixtures', 'video_short.mp4')
+ 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', 'preview-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', 'video_short.mp4')
+ 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', 'preview-big.png')
+ previewfile: buildAbsoluteFixturePath('preview-big.png')
}
await makeUploadRequest({ url: server.url, path, token: server.accessToken, fields, attaches })
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
+ }
}
})
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
+ }
}
})
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
+ }
}
})
})
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
+ }
}
})
})
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
+ }
}
})
describe('When getting live information', function () {
it('Should fail without access token', async function () {
- await getLive(server.url, '', videoId, HttpStatusCode.UNAUTHORIZED_401)
+ await getLive(server.url, '', video.id, HttpStatusCode.UNAUTHORIZED_401)
})
it('Should fail with a bad access token', async function () {
- await getLive(server.url, 'toto', videoId, HttpStatusCode.UNAUTHORIZED_401)
+ await getLive(server.url, 'toto', video.id, HttpStatusCode.UNAUTHORIZED_401)
})
it('Should fail with access token of another user', async function () {
- await getLive(server.url, userAccessToken, videoId, HttpStatusCode.FORBIDDEN_403)
+ await getLive(server.url, userAccessToken, video.id, HttpStatusCode.FORBIDDEN_403)
})
it('Should fail with a bad video id', async function () {
})
it('Should succeed with the correct params', async function () {
- await getLive(server.url, server.accessToken, videoId)
+ await getLive(server.url, server.accessToken, video.id)
+ await getLive(server.url, server.accessToken, video.shortUUID)
})
})
describe('When updating live information', async function () {
it('Should fail without access token', async function () {
- await updateLive(server.url, '', videoId, {}, HttpStatusCode.UNAUTHORIZED_401)
+ await updateLive(server.url, '', video.id, {}, HttpStatusCode.UNAUTHORIZED_401)
})
it('Should fail with a bad access token', async function () {
- await updateLive(server.url, 'toto', videoId, {}, HttpStatusCode.UNAUTHORIZED_401)
+ await updateLive(server.url, 'toto', video.id, {}, HttpStatusCode.UNAUTHORIZED_401)
})
it('Should fail with access token of another user', async function () {
- await updateLive(server.url, userAccessToken, videoId, {}, HttpStatusCode.FORBIDDEN_403)
+ await updateLive(server.url, userAccessToken, video.id, {}, HttpStatusCode.FORBIDDEN_403)
})
it('Should fail with a bad video id', async function () {
it('Should fail with save replay and permanent live set to true', async function () {
const fields = { saveReplay: true, permanentLive: true }
- await updateLive(server.url, server.accessToken, videoId, fields, HttpStatusCode.BAD_REQUEST_400)
+ await updateLive(server.url, server.accessToken, video.id, fields, HttpStatusCode.BAD_REQUEST_400)
})
it('Should succeed with the correct params', async function () {
- await updateLive(server.url, server.accessToken, videoId, { saveReplay: false })
+ await updateLive(server.url, server.accessToken, video.id, { saveReplay: false })
+ await updateLive(server.url, server.accessToken, video.shortUUID, { 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 }, HttpStatusCode.FORBIDDEN_403)
+ await updateLive(server.url, server.accessToken, video.id, { saveReplay: true }, HttpStatusCode.FORBIDDEN_403)
})
it('Should fail to update a live if it has already started', async function () {
this.timeout(40000)
- const resLive = await getLive(server.url, server.accessToken, videoId)
+ const resLive = await getLive(server.url, server.accessToken, video.id)
const live: LiveVideo = resLive.body
const command = sendRTMPStream(live.rtmpUrl, live.streamKey)
- await waitUntilLivePublished(server.url, server.accessToken, videoId)
- await updateLive(server.url, server.accessToken, videoId, {}, HttpStatusCode.BAD_REQUEST_400)
+ await waitUntilLivePublished(server.url, server.accessToken, video.id)
+ await updateLive(server.url, server.accessToken, video.id, {}, HttpStatusCode.BAD_REQUEST_400)
await stopFfmpeg(command)
})
it('Should fail to stream twice in the save live', async function () {
this.timeout(40000)
- const resLive = await getLive(server.url, server.accessToken, videoId)
+ const resLive = await getLive(server.url, server.accessToken, video.id)
const live: LiveVideo = resLive.body
const command = sendRTMPStream(live.rtmpUrl, live.streamKey)
- await waitUntilLivePublished(server.url, server.accessToken, videoId)
+ await waitUntilLivePublished(server.url, server.accessToken, video.id)
- await runAndTestFfmpegStreamError(server.url, server.accessToken, videoId, true)
+ await runAndTestFfmpegStreamError(server.url, server.accessToken, video.id, true)
await stopFfmpeg(command)
})