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