f2eb23cd87
- reduce http status codes list to potentially useful codes - convert more codes to typed ones - factorize html generator for error responses
177 lines
5.4 KiB
TypeScript
177 lines
5.4 KiB
TypeScript
/* eslint-disable @typescript-eslint/no-unused-expressions,@typescript-eslint/require-await */
|
|
|
|
import * as chai from 'chai'
|
|
import 'mocha'
|
|
import { cleanupTests, flushAndRunServer, ServerInfo } from '../../../shared/extra-utils/server/servers'
|
|
import {
|
|
createVideoPlaylist,
|
|
getPluginTestPath,
|
|
getVideo,
|
|
getVideoCategories,
|
|
getVideoLanguages,
|
|
getVideoLicences, getVideoPlaylistPrivacies, getVideoPrivacies,
|
|
installPlugin,
|
|
setAccessTokensToServers,
|
|
uninstallPlugin,
|
|
uploadVideo
|
|
} from '../../../shared/extra-utils'
|
|
import { VideoDetails, VideoPlaylistPrivacy } from '../../../shared/models/videos'
|
|
import { HttpStatusCode } from '../../../shared/core-utils/miscs/http-error-codes'
|
|
|
|
const expect = chai.expect
|
|
|
|
describe('Test plugin altering video constants', function () {
|
|
let server: ServerInfo
|
|
|
|
before(async function () {
|
|
this.timeout(30000)
|
|
|
|
server = await flushAndRunServer(1)
|
|
await setAccessTokensToServers([ server ])
|
|
|
|
await installPlugin({
|
|
url: server.url,
|
|
accessToken: server.accessToken,
|
|
path: getPluginTestPath('-three')
|
|
})
|
|
})
|
|
|
|
it('Should have updated languages', async function () {
|
|
const res = await getVideoLanguages(server.url)
|
|
const languages = res.body
|
|
|
|
expect(languages['en']).to.not.exist
|
|
expect(languages['fr']).to.not.exist
|
|
|
|
expect(languages['al_bhed']).to.equal('Al Bhed')
|
|
expect(languages['al_bhed2']).to.equal('Al Bhed 2')
|
|
})
|
|
|
|
it('Should have updated categories', async function () {
|
|
const res = await getVideoCategories(server.url)
|
|
const categories = res.body
|
|
|
|
expect(categories[1]).to.not.exist
|
|
expect(categories[2]).to.not.exist
|
|
|
|
expect(categories[42]).to.equal('Best category')
|
|
expect(categories[43]).to.equal('High best category')
|
|
})
|
|
|
|
it('Should have updated licences', async function () {
|
|
const res = await getVideoLicences(server.url)
|
|
const licences = res.body
|
|
|
|
expect(licences[1]).to.not.exist
|
|
expect(licences[7]).to.not.exist
|
|
|
|
expect(licences[42]).to.equal('Best licence')
|
|
expect(licences[43]).to.equal('High best licence')
|
|
})
|
|
|
|
it('Should have updated video privacies', async function () {
|
|
const res = await getVideoPrivacies(server.url)
|
|
const privacies = res.body
|
|
|
|
expect(privacies[1]).to.exist
|
|
expect(privacies[2]).to.not.exist
|
|
expect(privacies[3]).to.exist
|
|
expect(privacies[4]).to.exist
|
|
})
|
|
|
|
it('Should have updated playlist privacies', async function () {
|
|
const res = await getVideoPlaylistPrivacies(server.url)
|
|
const playlistPrivacies = res.body
|
|
|
|
expect(playlistPrivacies[1]).to.exist
|
|
expect(playlistPrivacies[2]).to.exist
|
|
expect(playlistPrivacies[3]).to.not.exist
|
|
})
|
|
|
|
it('Should not be able to create a video with this privacy', async function () {
|
|
const attrs = { name: 'video', privacy: 2 }
|
|
await uploadVideo(server.url, server.accessToken, attrs, HttpStatusCode.BAD_REQUEST_400)
|
|
})
|
|
|
|
it('Should not be able to create a video with this privacy', async function () {
|
|
const attrs = { displayName: 'video playlist', privacy: VideoPlaylistPrivacy.PRIVATE }
|
|
await createVideoPlaylist({
|
|
url: server.url,
|
|
token: server.accessToken,
|
|
playlistAttrs: attrs,
|
|
expectedStatus: HttpStatusCode.BAD_REQUEST_400
|
|
})
|
|
})
|
|
|
|
it('Should be able to upload a video with these values', async function () {
|
|
const attrs = { name: 'video', category: 42, licence: 42, language: 'al_bhed2' }
|
|
const resUpload = await uploadVideo(server.url, server.accessToken, attrs)
|
|
|
|
const res = await getVideo(server.url, resUpload.body.video.uuid)
|
|
|
|
const video: VideoDetails = res.body
|
|
expect(video.language.label).to.equal('Al Bhed 2')
|
|
expect(video.licence.label).to.equal('Best licence')
|
|
expect(video.category.label).to.equal('Best category')
|
|
})
|
|
|
|
it('Should uninstall the plugin and reset languages, categories, licences and privacies', async function () {
|
|
await uninstallPlugin({ url: server.url, accessToken: server.accessToken, npmName: 'peertube-plugin-test-three' })
|
|
|
|
{
|
|
const res = await getVideoLanguages(server.url)
|
|
const languages = res.body
|
|
|
|
expect(languages['en']).to.equal('English')
|
|
expect(languages['fr']).to.equal('French')
|
|
|
|
expect(languages['al_bhed']).to.not.exist
|
|
expect(languages['al_bhed2']).to.not.exist
|
|
}
|
|
|
|
{
|
|
const res = await getVideoCategories(server.url)
|
|
const categories = res.body
|
|
|
|
expect(categories[1]).to.equal('Music')
|
|
expect(categories[2]).to.equal('Films')
|
|
|
|
expect(categories[42]).to.not.exist
|
|
expect(categories[43]).to.not.exist
|
|
}
|
|
|
|
{
|
|
const res = await getVideoLicences(server.url)
|
|
const licences = res.body
|
|
|
|
expect(licences[1]).to.equal('Attribution')
|
|
expect(licences[7]).to.equal('Public Domain Dedication')
|
|
|
|
expect(licences[42]).to.not.exist
|
|
expect(licences[43]).to.not.exist
|
|
}
|
|
|
|
{
|
|
const res = await getVideoPrivacies(server.url)
|
|
const privacies = res.body
|
|
|
|
expect(privacies[1]).to.exist
|
|
expect(privacies[2]).to.exist
|
|
expect(privacies[3]).to.exist
|
|
expect(privacies[4]).to.exist
|
|
}
|
|
|
|
{
|
|
const res = await getVideoPlaylistPrivacies(server.url)
|
|
const playlistPrivacies = res.body
|
|
|
|
expect(playlistPrivacies[1]).to.exist
|
|
expect(playlistPrivacies[2]).to.exist
|
|
expect(playlistPrivacies[3]).to.exist
|
|
}
|
|
})
|
|
|
|
after(async function () {
|
|
await cleanupTests([ server ])
|
|
})
|
|
})
|