]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blame - server/tests/external-plugins/auto-block-videos.ts
Fix CLI tools
[github/Chocobozzz/PeerTube.git] / server / tests / external-plugins / auto-block-videos.ts
CommitLineData
d4bf24df
C
1/* eslint-disable @typescript-eslint/no-unused-expressions,@typescript-eslint/require-await */
2
3import 'mocha'
4import { expect } from 'chai'
e3d15a6a 5import { Video } from '@shared/models'
d4bf24df
C
6import {
7 doubleFollow,
d4bf24df 8 getVideosList,
d4bf24df 9 MockBlocklist,
d4bf24df 10 setAccessTokensToServers,
d4bf24df
C
11 uploadVideoAndGetId,
12 wait
13} from '../../../shared/extra-utils'
14import {
15 cleanupTests,
16 flushAndRunMultipleServers,
17 killallServers,
18 reRunServer,
19 ServerInfo
20} from '../../../shared/extra-utils/server/servers'
21
22async function check (server: ServerInfo, videoUUID: string, exists = true) {
23 const res = await getVideosList(server.url)
24
25 const video = res.body.data.find(v => v.uuid === videoUUID)
26
ae2abfd3
C
27 if (exists) expect(video).to.not.be.undefined
28 else expect(video).to.be.undefined
d4bf24df
C
29}
30
31describe('Official plugin auto-block videos', function () {
32 let servers: ServerInfo[]
33 let blocklistServer: MockBlocklist
34 let server1Videos: Video[] = []
35 let server2Videos: Video[] = []
63da15eb 36 let port: number
d4bf24df
C
37
38 before(async function () {
39 this.timeout(60000)
40
41 servers = await flushAndRunMultipleServers(2)
42 await setAccessTokensToServers(servers)
43
44 for (const server of servers) {
ae2abfd3 45 await server.pluginsCommand.install({ npmName: 'peertube-plugin-auto-block-videos' })
d4bf24df
C
46 }
47
48 blocklistServer = new MockBlocklist()
63da15eb 49 port = await blocklistServer.initialize()
d4bf24df
C
50
51 await uploadVideoAndGetId({ server: servers[0], videoName: 'video server 1' })
52 await uploadVideoAndGetId({ server: servers[1], videoName: 'video server 2' })
53 await uploadVideoAndGetId({ server: servers[1], videoName: 'video 2 server 2' })
54 await uploadVideoAndGetId({ server: servers[1], videoName: 'video 3 server 2' })
55
56 {
57 const res = await getVideosList(servers[0].url)
58 server1Videos = res.body.data.map(v => Object.assign(v, { url: servers[0].url + '/videos/watch/' + v.uuid }))
59 }
60
61 {
62 const res = await getVideosList(servers[1].url)
63 server2Videos = res.body.data.map(v => Object.assign(v, { url: servers[1].url + '/videos/watch/' + v.uuid }))
64 }
65
66 await doubleFollow(servers[0], servers[1])
67 })
68
69 it('Should update plugin settings', async function () {
ae2abfd3 70 await servers[0].pluginsCommand.updateSettings({
d4bf24df
C
71 npmName: 'peertube-plugin-auto-block-videos',
72 settings: {
63da15eb 73 'blocklist-urls': `http://localhost:${port}/blocklist`,
d4bf24df
C
74 'check-seconds-interval': 1
75 }
76 })
77 })
78
79 it('Should auto block a video', async function () {
80 this.timeout(10000)
81
82 await check(servers[0], server2Videos[0].uuid, true)
83
84 blocklistServer.replace({
85 data: [
86 {
87 value: server2Videos[0].url
88 }
89 ]
90 })
91
92 await wait(2000)
93
94 await check(servers[0], server2Videos[0].uuid, false)
95 })
96
97 it('Should have video in blacklists', async function () {
e3d15a6a 98 const body = await servers[0].blacklistCommand.list()
d4bf24df 99
e3d15a6a 100 const videoBlacklists = body.data
d4bf24df
C
101 expect(videoBlacklists).to.have.lengthOf(1)
102 expect(videoBlacklists[0].reason).to.contains('Automatically blocked from auto block plugin')
103 expect(videoBlacklists[0].video.name).to.equal(server2Videos[0].name)
104 })
105
106 it('Should not block a local video', async function () {
107 this.timeout(10000)
108
109 await check(servers[0], server1Videos[0].uuid, true)
110
111 blocklistServer.replace({
112 data: [
113 {
114 value: server1Videos[0].url
115 }
116 ]
117 })
118
119 await wait(2000)
120
121 await check(servers[0], server1Videos[0].uuid, true)
122 })
123
124 it('Should remove a video block', async function () {
125 this.timeout(10000)
126
127 await check(servers[0], server2Videos[0].uuid, false)
128
129 blocklistServer.replace({
130 data: [
131 {
132 value: server2Videos[0].url,
133 action: 'remove'
134 }
135 ]
136 })
137
138 await wait(2000)
139
140 await check(servers[0], server2Videos[0].uuid, true)
141 })
142
143 it('Should auto block a video, manually unblock it and do not reblock it automatically', async function () {
144 this.timeout(20000)
145
146 const video = server2Videos[1]
147
148 await check(servers[0], video.uuid, true)
149
150 blocklistServer.replace({
151 data: [
152 {
153 value: video.url,
154 updatedAt: new Date().toISOString()
155 }
156 ]
157 })
158
159 await wait(2000)
160
161 await check(servers[0], video.uuid, false)
162
e3d15a6a 163 await servers[0].blacklistCommand.remove({ videoId: video.uuid })
d4bf24df
C
164
165 await check(servers[0], video.uuid, true)
166
167 killallServers([ servers[0] ])
168 await reRunServer(servers[0])
169 await wait(2000)
170
171 await check(servers[0], video.uuid, true)
172 })
173
174 after(async function () {
7820a54e
C
175 await blocklistServer.terminate()
176
d4bf24df
C
177 await cleanupTests(servers)
178 })
179})