X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=server%2Ftests%2Fplugins%2Fvideo-constants.ts;h=6dce6922f7d6ad7925304220cf0a217faaa58839;hb=83b1b7eaf1c04837f92de497e74895bee808eb83;hp=6562e2b4554e98eef8cd1d56e3dbc3a1968a1234;hpb=ee286591a5b740702bad66c55cc900740f749e9a;p=github%2FChocobozzz%2FPeerTube.git diff --git a/server/tests/plugins/video-constants.ts b/server/tests/plugins/video-constants.ts index 6562e2b45..6dce6922f 100644 --- a/server/tests/plugins/video-constants.ts +++ b/server/tests/plugins/video-constants.ts @@ -1,71 +1,44 @@ -/* tslint:disable:no-unused-expression */ +/* eslint-disable @typescript-eslint/no-unused-expressions,@typescript-eslint/require-await */ -import * as chai from 'chai' import 'mocha' +import * as chai from 'chai' import { cleanupTests, - flushAndRunMultipleServers, - flushAndRunServer, killallServers, reRunServer, - ServerInfo, - waitUntilLog -} from '../../../shared/extra-utils/server/servers' -import { - addVideoCommentReply, - addVideoCommentThread, - deleteVideoComment, - getPluginTestPath, - getVideosList, - installPlugin, - removeVideo, - setAccessTokensToServers, - updateVideo, - uploadVideo, - viewVideo, - getVideosListPagination, - getVideo, - getVideoCommentThreads, - getVideoThreadComments, - getVideoWithToken, - setDefaultVideoChannel, - waitJobs, - doubleFollow, getVideoLanguages, getVideoLicences, getVideoCategories, uninstallPlugin -} from '../../../shared/extra-utils' -import { VideoCommentThreadTree } from '../../../shared/models/videos/video-comment.model' -import { VideoDetails } from '../../../shared/models/videos' -import { getYoutubeVideoUrl, importVideo } from '../../../shared/extra-utils/videos/video-imports' + createSingleServer, + makeGetRequest, + PeerTubeServer, + PluginsCommand, + setAccessTokensToServers +} from '@shared/server-commands' +import { HttpStatusCode, VideoPlaylistPrivacy } from '@shared/models' const expect = chai.expect describe('Test plugin altering video constants', function () { - let server: ServerInfo + let server: PeerTubeServer before(async function () { this.timeout(30000) - server = await flushAndRunServer(1) + server = await createSingleServer(1) await setAccessTokensToServers([ server ]) - await installPlugin({ - url: server.url, - accessToken: server.accessToken, - path: getPluginTestPath('-three') - }) + await server.plugins.install({ path: PluginsCommand.getPluginTestPath('-video-constants') }) }) it('Should have updated languages', async function () { - const res = await getVideoLanguages(server.url) - const languages = res.body + const languages = await server.videos.getLanguages() 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') + expect(languages['al_bhed3']).to.not.exist }) it('Should have updated categories', async function () { - const res = await getVideoCategories(server.url) - const categories = res.body + const categories = await server.videos.getCategories() expect(categories[1]).to.not.exist expect(categories[2]).to.not.exist @@ -75,8 +48,7 @@ describe('Test plugin altering video constants', function () { }) it('Should have updated licences', async function () { - const res = await getVideoLicences(server.url) - const licences = res.body + const licences = await server.videos.getLicences() expect(licences[1]).to.not.exist expect(licences[7]).to.not.exist @@ -85,52 +57,123 @@ describe('Test plugin altering video constants', function () { expect(licences[43]).to.equal('High best licence') }) - 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) + it('Should have updated video privacies', async function () { + const privacies = await server.videos.getPrivacies() + + 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 playlistPrivacies = await server.playlists.getPrivacies() + + 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 attributes = { name: 'video', privacy: 2 } + await server.videos.upload({ attributes, expectedStatus: HttpStatusCode.BAD_REQUEST_400 }) + }) + + it('Should not be able to create a video with this privacy', async function () { + const attributes = { displayName: 'video playlist', privacy: VideoPlaylistPrivacy.PRIVATE } + await server.playlists.create({ attributes, expectedStatus: HttpStatusCode.BAD_REQUEST_400 }) + }) - const res = await getVideo(server.url, resUpload.body.video.uuid) + it('Should be able to upload a video with these values', async function () { + const attributes = { name: 'video', category: 42, licence: 42, language: 'al_bhed2' } + const { uuid } = await server.videos.upload({ attributes }) - const video: VideoDetails = res.body + const video = await server.videos.get({ id: uuid }) 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 and licences', async function () { - await uninstallPlugin({ url: server.url, accessToken: server.accessToken, npmName: 'peertube-plugin-test-three' }) + it('Should uninstall the plugin and reset languages, categories, licences and privacies', async function () { + await server.plugins.uninstall({ npmName: 'peertube-plugin-test-video-constants' }) { - const res = await getVideoLanguages(server.url) - const languages = res.body + const languages = await server.videos.getLanguages() - expect(languages[ 'en' ]).to.equal('English') - expect(languages[ 'fr' ]).to.equal('French') + 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 + expect(languages['al_bhed']).to.not.exist + expect(languages['al_bhed2']).to.not.exist + expect(languages['al_bhed3']).to.not.exist } { - const res = await getVideoCategories(server.url) - const categories = res.body + const categories = await server.videos.getCategories() - expect(categories[ 1 ]).to.equal('Music') - expect(categories[ 2 ]).to.equal('Films') + expect(categories[1]).to.equal('Music') + expect(categories[2]).to.equal('Films') - expect(categories[ 42 ]).to.not.exist - expect(categories[ 43 ]).to.not.exist + expect(categories[42]).to.not.exist + expect(categories[43]).to.not.exist } { - const res = await getVideoLicences(server.url) - const licences = res.body + const licences = await server.videos.getLicences() + + 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 privacies = await server.videos.getPrivacies() + + expect(privacies[1]).to.exist + expect(privacies[2]).to.exist + expect(privacies[3]).to.exist + expect(privacies[4]).to.exist + } + + { + const playlistPrivacies = await server.playlists.getPrivacies() + + expect(playlistPrivacies[1]).to.exist + expect(playlistPrivacies[2]).to.exist + expect(playlistPrivacies[3]).to.exist + } + }) + + it('Should be able to reset categories', async function () { + await server.plugins.install({ path: PluginsCommand.getPluginTestPath('-video-constants') }) + + { + const categories = await server.videos.getCategories() + + expect(categories[1]).to.not.exist + expect(categories[2]).to.not.exist + + expect(categories[42]).to.exist + expect(categories[43]).to.exist + } + + await makeGetRequest({ + url: server.url, + token: server.accessToken, + path: '/plugins/test-video-constants/router/reset-categories', + expectedStatus: HttpStatusCode.NO_CONTENT_204 + }) + + { + const categories = await server.videos.getCategories() - expect(licences[ 1 ]).to.equal('Attribution') - expect(licences[ 7 ]).to.equal('Public Domain Dedication') + expect(categories[1]).to.exist + expect(categories[2]).to.exist - expect(licences[ 42 ]).to.not.exist - expect(licences[ 43 ]).to.not.exist + expect(categories[42]).to.not.exist + expect(categories[43]).to.not.exist } })