2020-06-25 10:32:17 +02:00
|
|
|
/* eslint-disable @typescript-eslint/no-unused-expressions,@typescript-eslint/require-await */
|
|
|
|
|
|
|
|
import 'mocha'
|
|
|
|
import { expect } from 'chai'
|
|
|
|
import { Video, VideoBlacklist } from '@shared/models'
|
|
|
|
import {
|
|
|
|
doubleFollow,
|
|
|
|
getBlacklistedVideosList,
|
|
|
|
getVideosList,
|
|
|
|
installPlugin,
|
|
|
|
MockBlocklist,
|
|
|
|
removeVideoFromBlacklist,
|
|
|
|
setAccessTokensToServers,
|
|
|
|
updatePluginSettings,
|
|
|
|
uploadVideoAndGetId,
|
|
|
|
wait
|
|
|
|
} from '../../../shared/extra-utils'
|
|
|
|
import {
|
|
|
|
cleanupTests,
|
|
|
|
flushAndRunMultipleServers,
|
|
|
|
killallServers,
|
|
|
|
reRunServer,
|
|
|
|
ServerInfo
|
|
|
|
} from '../../../shared/extra-utils/server/servers'
|
|
|
|
|
|
|
|
async function check (server: ServerInfo, videoUUID: string, exists = true) {
|
|
|
|
const res = await getVideosList(server.url)
|
|
|
|
|
|
|
|
const video = res.body.data.find(v => v.uuid === videoUUID)
|
|
|
|
|
|
|
|
if (exists) {
|
|
|
|
expect(video).to.not.be.undefined
|
|
|
|
} else {
|
|
|
|
expect(video).to.be.undefined
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
describe('Official plugin auto-block videos', function () {
|
|
|
|
let servers: ServerInfo[]
|
|
|
|
let blocklistServer: MockBlocklist
|
|
|
|
let server1Videos: Video[] = []
|
|
|
|
let server2Videos: Video[] = []
|
|
|
|
|
|
|
|
before(async function () {
|
|
|
|
this.timeout(60000)
|
|
|
|
|
|
|
|
servers = await flushAndRunMultipleServers(2)
|
|
|
|
await setAccessTokensToServers(servers)
|
|
|
|
|
|
|
|
for (const server of servers) {
|
|
|
|
await installPlugin({
|
|
|
|
url: server.url,
|
|
|
|
accessToken: server.accessToken,
|
|
|
|
npmName: 'peertube-plugin-auto-block-videos'
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
blocklistServer = new MockBlocklist()
|
|
|
|
await blocklistServer.initialize()
|
|
|
|
|
|
|
|
await uploadVideoAndGetId({ server: servers[0], videoName: 'video server 1' })
|
|
|
|
await uploadVideoAndGetId({ server: servers[1], videoName: 'video server 2' })
|
|
|
|
await uploadVideoAndGetId({ server: servers[1], videoName: 'video 2 server 2' })
|
|
|
|
await uploadVideoAndGetId({ server: servers[1], videoName: 'video 3 server 2' })
|
|
|
|
|
|
|
|
{
|
|
|
|
const res = await getVideosList(servers[0].url)
|
|
|
|
server1Videos = res.body.data.map(v => Object.assign(v, { url: servers[0].url + '/videos/watch/' + v.uuid }))
|
|
|
|
}
|
|
|
|
|
|
|
|
{
|
|
|
|
const res = await getVideosList(servers[1].url)
|
|
|
|
server2Videos = res.body.data.map(v => Object.assign(v, { url: servers[1].url + '/videos/watch/' + v.uuid }))
|
|
|
|
}
|
|
|
|
|
|
|
|
await doubleFollow(servers[0], servers[1])
|
|
|
|
})
|
|
|
|
|
|
|
|
it('Should update plugin settings', async function () {
|
|
|
|
await updatePluginSettings({
|
|
|
|
url: servers[0].url,
|
|
|
|
accessToken: servers[0].accessToken,
|
|
|
|
npmName: 'peertube-plugin-auto-block-videos',
|
|
|
|
settings: {
|
|
|
|
'blocklist-urls': 'http://localhost:42100/blocklist',
|
|
|
|
'check-seconds-interval': 1
|
|
|
|
}
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
it('Should auto block a video', async function () {
|
|
|
|
this.timeout(10000)
|
|
|
|
|
|
|
|
await check(servers[0], server2Videos[0].uuid, true)
|
|
|
|
|
|
|
|
blocklistServer.replace({
|
|
|
|
data: [
|
|
|
|
{
|
|
|
|
value: server2Videos[0].url
|
|
|
|
}
|
|
|
|
]
|
|
|
|
})
|
|
|
|
|
|
|
|
await wait(2000)
|
|
|
|
|
|
|
|
await check(servers[0], server2Videos[0].uuid, false)
|
|
|
|
})
|
|
|
|
|
|
|
|
it('Should have video in blacklists', async function () {
|
|
|
|
const res = await getBlacklistedVideosList({ url: servers[0].url, token: servers[0].accessToken })
|
|
|
|
|
|
|
|
const videoBlacklists = res.body.data as VideoBlacklist[]
|
|
|
|
|
|
|
|
expect(videoBlacklists).to.have.lengthOf(1)
|
|
|
|
expect(videoBlacklists[0].reason).to.contains('Automatically blocked from auto block plugin')
|
|
|
|
expect(videoBlacklists[0].video.name).to.equal(server2Videos[0].name)
|
|
|
|
})
|
|
|
|
|
|
|
|
it('Should not block a local video', async function () {
|
|
|
|
this.timeout(10000)
|
|
|
|
|
|
|
|
await check(servers[0], server1Videos[0].uuid, true)
|
|
|
|
|
|
|
|
blocklistServer.replace({
|
|
|
|
data: [
|
|
|
|
{
|
|
|
|
value: server1Videos[0].url
|
|
|
|
}
|
|
|
|
]
|
|
|
|
})
|
|
|
|
|
|
|
|
await wait(2000)
|
|
|
|
|
|
|
|
await check(servers[0], server1Videos[0].uuid, true)
|
|
|
|
})
|
|
|
|
|
|
|
|
it('Should remove a video block', async function () {
|
|
|
|
this.timeout(10000)
|
|
|
|
|
|
|
|
await check(servers[0], server2Videos[0].uuid, false)
|
|
|
|
|
|
|
|
blocklistServer.replace({
|
|
|
|
data: [
|
|
|
|
{
|
|
|
|
value: server2Videos[0].url,
|
|
|
|
action: 'remove'
|
|
|
|
}
|
|
|
|
]
|
|
|
|
})
|
|
|
|
|
|
|
|
await wait(2000)
|
|
|
|
|
|
|
|
await check(servers[0], server2Videos[0].uuid, true)
|
|
|
|
})
|
|
|
|
|
|
|
|
it('Should auto block a video, manually unblock it and do not reblock it automatically', async function () {
|
|
|
|
this.timeout(20000)
|
|
|
|
|
|
|
|
const video = server2Videos[1]
|
|
|
|
|
|
|
|
await check(servers[0], video.uuid, true)
|
|
|
|
|
|
|
|
blocklistServer.replace({
|
|
|
|
data: [
|
|
|
|
{
|
|
|
|
value: video.url,
|
|
|
|
updatedAt: new Date().toISOString()
|
|
|
|
}
|
|
|
|
]
|
|
|
|
})
|
|
|
|
|
|
|
|
await wait(2000)
|
|
|
|
|
|
|
|
await check(servers[0], video.uuid, false)
|
|
|
|
|
|
|
|
await removeVideoFromBlacklist(servers[0].url, servers[0].accessToken, video.uuid)
|
|
|
|
|
|
|
|
await check(servers[0], video.uuid, true)
|
|
|
|
|
|
|
|
killallServers([ servers[0] ])
|
|
|
|
await reRunServer(servers[0])
|
|
|
|
await wait(2000)
|
|
|
|
|
|
|
|
await check(servers[0], video.uuid, true)
|
|
|
|
})
|
|
|
|
|
|
|
|
after(async function () {
|
2020-06-26 14:50:40 +02:00
|
|
|
await blocklistServer.terminate()
|
|
|
|
|
2020-06-25 10:32:17 +02:00
|
|
|
await cleanupTests(servers)
|
|
|
|
})
|
|
|
|
})
|