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,
updateLive,
uploadVideoAndGetId,
userLogin,
- waitUntilLiveStarts
+ waitUntilLivePublished
} from '../../../../shared/extra-utils'
describe('Test video lives API validator', function () {
let server: ServerInfo
let userAccessToken = ''
let channelId: number
- let videoId: number
+ let video: VideoCreateResult
let videoIdNotLive: number
// ---------------------------------------------------------------
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 })
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 () {
path,
token: server.accessToken,
fields: baseCorrectParams,
- statusCodeExpected: 403
+ statusCodeExpected: HttpStatusCode.FORBIDDEN_403
})
})
path,
token: server.accessToken,
fields,
- statusCodeExpected: 403
+ statusCodeExpected: HttpStatusCode.FORBIDDEN_403
})
})
path,
token: server.accessToken,
fields,
- statusCodeExpected: 200
+ statusCodeExpected: HttpStatusCode.OK_200
})
})
path,
token: server.accessToken,
fields: baseCorrectParams,
- statusCodeExpected: 403
+ statusCodeExpected: HttpStatusCode.FORBIDDEN_403
})
})
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 getLive(server.url, '', video.id, HttpStatusCode.UNAUTHORIZED_401)
})
it('Should fail with a bad access token', async function () {
- await getLive(server.url, 'toto', videoId, 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, 403)
+ await getLive(server.url, userAccessToken, video.id, HttpStatusCode.FORBIDDEN_403)
})
it('Should fail with a bad video id', async function () {
- await getLive(server.url, server.accessToken, 'toto', 400)
+ await getLive(server.url, server.accessToken, 'toto', HttpStatusCode.BAD_REQUEST_400)
})
it('Should fail with an unknown video id', async function () {
- await getLive(server.url, server.accessToken, 454555, 404)
+ await getLive(server.url, server.accessToken, 454555, HttpStatusCode.NOT_FOUND_404)
})
it('Should fail with a non live video', async function () {
- await getLive(server.url, server.accessToken, videoIdNotLive, 404)
+ await getLive(server.url, server.accessToken, videoIdNotLive, HttpStatusCode.NOT_FOUND_404)
})
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, {}, 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, {}, 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, {}, 403)
+ await updateLive(server.url, userAccessToken, video.id, {}, HttpStatusCode.FORBIDDEN_403)
})
it('Should fail with a bad video id', async function () {
- await updateLive(server.url, server.accessToken, 'toto', {}, 400)
+ await updateLive(server.url, server.accessToken, 'toto', {}, HttpStatusCode.BAD_REQUEST_400)
})
it('Should fail with an unknown video id', async function () {
- await updateLive(server.url, server.accessToken, 454555, {}, 404)
+ await updateLive(server.url, server.accessToken, 454555, {}, HttpStatusCode.NOT_FOUND_404)
})
it('Should fail with a non live video', async function () {
- await updateLive(server.url, server.accessToken, videoIdNotLive, {}, 404)
+ await updateLive(server.url, server.accessToken, videoIdNotLive, {}, 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 updateLive(server.url, server.accessToken, videoId, fields, 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 updateLive(server.url, server.accessToken, videoId, { saveReplay: true }, 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(20000)
+ 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 waitUntilLiveStarts(server.url, server.accessToken, videoId)
- await updateLive(server.url, server.accessToken, videoId, {}, 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(30000)
+ 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 waitUntilLiveStarts(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)
})