import 'mocha'
import * as chai from 'chai'
+import { advancedVideoChannelSearch } from '@shared/extra-utils/search/video-channels'
import { ServerConfig } from '@shared/models'
+import { HttpStatusCode } from '../../../shared/core-utils/miscs/http-error-codes'
import {
addVideoCommentReply,
addVideoCommentThread,
+ advancedVideoPlaylistSearch,
+ advancedVideosSearch,
createLive,
+ createVideoPlaylist,
doubleFollow,
getAccountVideos,
getConfig,
getVideo,
getVideoChannelVideos,
getVideoCommentThreads,
+ getVideoPlaylist,
getVideosList,
getVideosListPagination,
getVideoThreadComments,
uploadVideoAndGetId,
waitJobs
} from '../../../shared/extra-utils'
-import { cleanupTests, flushAndRunMultipleServers, ServerInfo } from '../../../shared/extra-utils/server/servers'
+import { cleanupTests, flushAndRunMultipleServers, ServerInfo, waitUntilLog } from '../../../shared/extra-utils/server/servers'
import { getGoodVideoUrl, getMyVideoImports, importVideo } from '../../../shared/extra-utils/videos/video-imports'
-import { VideoDetails, VideoImport, VideoImportState, VideoPrivacy } from '../../../shared/models/videos'
-import { VideoCommentThreadTree } from '../../../shared/models/videos/video-comment.model'
-import { HttpStatusCode } from '../../../shared/core-utils/miscs/http-error-codes'
+import {
+ VideoCommentThreadTree,
+ VideoDetails,
+ VideoImport,
+ VideoImportState,
+ VideoPlaylist,
+ VideoPlaylistPrivacy,
+ VideoPrivacy
+} from '../../../shared/models/videos'
const expect = chai.expect
let threadId: number
before(async function () {
- this.timeout(30000)
+ this.timeout(60000)
servers = await flushAndRunMultipleServers(2)
await setAccessTokensToServers(servers)
await installPlugin({
url: servers[0].url,
accessToken: servers[0].accessToken,
- path: getPluginTestPath('-two')
+ path: getPluginTestPath('-filter-translations')
})
for (let i = 0; i < 10; i++) {
})
it('Should blacklist on remote upload', async function () {
- this.timeout(45000)
+ this.timeout(120000)
const res = await uploadVideo(servers[1].url, servers[1].accessToken, { name: 'remote please blacklist me' })
await waitJobs(servers)
})
it('Should blacklist on remote update', async function () {
- this.timeout(45000)
+ this.timeout(120000)
const res = await uploadVideo(servers[1].url, servers[1].accessToken, { name: 'video' })
await waitJobs(servers)
const downloadVideos: VideoDetails[] = []
before(async function () {
- this.timeout(60000)
+ this.timeout(120000)
await updateCustomSubConfig(servers[0].url, servers[0].accessToken, {
transcoding: {
})
})
+ describe('Embed filters', function () {
+ const embedVideos: VideoDetails[] = []
+ const embedPlaylists: VideoPlaylist[] = []
+
+ before(async function () {
+ this.timeout(60000)
+
+ await updateCustomSubConfig(servers[0].url, servers[0].accessToken, {
+ transcoding: {
+ enabled: false
+ }
+ })
+
+ for (const name of [ 'bad embed', 'good embed' ]) {
+ {
+ const uuid = (await uploadVideoAndGetId({ server: servers[0], videoName: name })).uuid
+ const res = await getVideo(servers[0].url, uuid)
+ embedVideos.push(res.body)
+ }
+
+ {
+ const playlistAttrs = { displayName: name, videoChannelId: servers[0].videoChannel.id, privacy: VideoPlaylistPrivacy.PUBLIC }
+ const res = await createVideoPlaylist({ url: servers[0].url, token: servers[0].accessToken, playlistAttrs })
+
+ const resPlaylist = await getVideoPlaylist(servers[0].url, res.body.videoPlaylist.id)
+ embedPlaylists.push(resPlaylist.body)
+ }
+ }
+ })
+
+ it('Should run filter:html.embed.video.allowed.result', async function () {
+ const res = await makeRawRequest(servers[0].url + embedVideos[0].embedPath, 200)
+ expect(res.text).to.equal('Lu Bu')
+ })
+
+ it('Should run filter:html.embed.video-playlist.allowed.result', async function () {
+ const res = await makeRawRequest(servers[0].url + embedPlaylists[0].embedPath, 200)
+ expect(res.text).to.equal('Diao Chan')
+ })
+ })
+
+ describe('Search filters', function () {
+
+ before(async function () {
+ await updateCustomSubConfig(servers[0].url, servers[0].accessToken, {
+ search: {
+ searchIndex: {
+ enabled: true,
+ isDefaultSearch: false,
+ disableLocalSearch: false
+ }
+ }
+ })
+ })
+
+ it('Should run filter:api.search.videos.local.list.{params,result}', async function () {
+ await advancedVideosSearch(servers[0].url, {
+ search: 'Sun Quan'
+ })
+
+ await waitUntilLog(servers[0], 'Run hook filter:api.search.videos.local.list.params', 1)
+ await waitUntilLog(servers[0], 'Run hook filter:api.search.videos.local.list.result', 1)
+ })
+
+ it('Should run filter:api.search.videos.index.list.{params,result}', async function () {
+ await advancedVideosSearch(servers[0].url, {
+ search: 'Sun Quan',
+ searchTarget: 'search-index'
+ })
+
+ await waitUntilLog(servers[0], 'Run hook filter:api.search.videos.local.list.params', 1)
+ await waitUntilLog(servers[0], 'Run hook filter:api.search.videos.local.list.result', 1)
+ await waitUntilLog(servers[0], 'Run hook filter:api.search.videos.index.list.params', 1)
+ await waitUntilLog(servers[0], 'Run hook filter:api.search.videos.index.list.result', 1)
+ })
+
+ it('Should run filter:api.search.video-channels.local.list.{params,result}', async function () {
+ await advancedVideoChannelSearch(servers[0].url, {
+ search: 'Sun Ce'
+ })
+
+ await waitUntilLog(servers[0], 'Run hook filter:api.search.video-channels.local.list.params', 1)
+ await waitUntilLog(servers[0], 'Run hook filter:api.search.video-channels.local.list.result', 1)
+ })
+
+ it('Should run filter:api.search.video-channels.index.list.{params,result}', async function () {
+ await advancedVideoChannelSearch(servers[0].url, {
+ search: 'Sun Ce',
+ searchTarget: 'search-index'
+ })
+
+ await waitUntilLog(servers[0], 'Run hook filter:api.search.video-channels.local.list.params', 1)
+ await waitUntilLog(servers[0], 'Run hook filter:api.search.video-channels.local.list.result', 1)
+ await waitUntilLog(servers[0], 'Run hook filter:api.search.video-channels.index.list.params', 1)
+ await waitUntilLog(servers[0], 'Run hook filter:api.search.video-channels.index.list.result', 1)
+ })
+
+ it('Should run filter:api.search.video-playlists.local.list.{params,result}', async function () {
+ await advancedVideoPlaylistSearch(servers[0].url, {
+ search: 'Sun Jian'
+ })
+
+ await waitUntilLog(servers[0], 'Run hook filter:api.search.video-playlists.local.list.params', 1)
+ await waitUntilLog(servers[0], 'Run hook filter:api.search.video-playlists.local.list.result', 1)
+ })
+
+ it('Should run filter:api.search.video-playlists.index.list.{params,result}', async function () {
+ await advancedVideoPlaylistSearch(servers[0].url, {
+ search: 'Sun Jian',
+ searchTarget: 'search-index'
+ })
+
+ await waitUntilLog(servers[0], 'Run hook filter:api.search.video-playlists.local.list.params', 1)
+ await waitUntilLog(servers[0], 'Run hook filter:api.search.video-playlists.local.list.result', 1)
+ await waitUntilLog(servers[0], 'Run hook filter:api.search.video-playlists.index.list.params', 1)
+ await waitUntilLog(servers[0], 'Run hook filter:api.search.video-playlists.index.list.result', 1)
+ })
+ })
+
after(async function () {
await cleanupTests(servers)
})