]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blame - server/tests/api/server/bulk.ts
Cleanup tests imports
[github/Chocobozzz/PeerTube.git] / server / tests / api / server / bulk.ts
CommitLineData
444c0a0e
C
1/* eslint-disable @typescript-eslint/no-unused-expressions,@typescript-eslint/require-await */
2
86347717 3import { expect } from 'chai'
444c0a0e 4import {
a6a79eae 5 BulkCommand,
444c0a0e 6 cleanupTests,
254d3579 7 createMultipleServers,
4c7e60bc 8 doubleFollow,
254d3579 9 PeerTubeServer,
444c0a0e 10 setAccessTokensToServers,
2b02c520 11 waitJobs
bf54587a 12} from '@shared/server-commands'
444c0a0e 13
444c0a0e
C
14describe('Test bulk actions', function () {
15 const commentsUser3: { videoId: number, commentId: number }[] = []
16
254d3579 17 let servers: PeerTubeServer[] = []
12edc149
C
18 let user1Token: string
19 let user2Token: string
20 let user3Token: string
444c0a0e 21
a6a79eae
C
22 let bulkCommand: BulkCommand
23
444c0a0e
C
24 before(async function () {
25 this.timeout(30000)
26
254d3579 27 servers = await createMultipleServers(2)
444c0a0e
C
28
29 // Get the access tokens
30 await setAccessTokensToServers(servers)
31
32 {
33 const user = { username: 'user1', password: 'password' }
89d241a7 34 await servers[0].users.create({ username: user.username, password: user.password })
444c0a0e 35
89d241a7 36 user1Token = await servers[0].login.getAccessToken(user)
444c0a0e
C
37 }
38
39 {
40 const user = { username: 'user2', password: 'password' }
89d241a7 41 await servers[0].users.create({ username: user.username, password: user.password })
444c0a0e 42
89d241a7 43 user2Token = await servers[0].login.getAccessToken(user)
444c0a0e
C
44 }
45
46 {
47 const user = { username: 'user3', password: 'password' }
89d241a7 48 await servers[1].users.create({ username: user.username, password: user.password })
444c0a0e 49
89d241a7 50 user3Token = await servers[1].login.getAccessToken(user)
444c0a0e
C
51 }
52
53 await doubleFollow(servers[0], servers[1])
a6a79eae
C
54
55 bulkCommand = new BulkCommand(servers[0])
444c0a0e
C
56 })
57
58 describe('Bulk remove comments', function () {
59 async function checkInstanceCommentsRemoved () {
60 {
89d241a7 61 const { data } = await servers[0].videos.list()
444c0a0e
C
62
63 // Server 1 should not have these comments anymore
d23dd9fb 64 for (const video of data) {
89d241a7 65 const { data } = await servers[0].comments.listThreads({ videoId: video.id })
12edc149 66 const comment = data.find(c => c.text === 'comment by user 3')
444c0a0e
C
67
68 expect(comment).to.not.exist
69 }
70 }
71
72 {
89d241a7 73 const { data } = await servers[1].videos.list()
444c0a0e
C
74
75 // Server 1 should not have these comments on videos of server 1
d23dd9fb 76 for (const video of data) {
89d241a7 77 const { data } = await servers[1].comments.listThreads({ videoId: video.id })
12edc149 78 const comment = data.find(c => c.text === 'comment by user 3')
444c0a0e
C
79
80 if (video.account.host === 'localhost:' + servers[0].port) {
81 expect(comment).to.not.exist
82 } else {
83 expect(comment).to.exist
84 }
85 }
86 }
87 }
88
89 before(async function () {
0c39df25 90 this.timeout(120000)
444c0a0e 91
89d241a7
C
92 await servers[0].videos.upload({ attributes: { name: 'video 1 server 1' } })
93 await servers[0].videos.upload({ attributes: { name: 'video 2 server 1' } })
94 await servers[0].videos.upload({ token: user1Token, attributes: { name: 'video 3 server 1' } })
444c0a0e 95
89d241a7 96 await servers[1].videos.upload({ attributes: { name: 'video 1 server 2' } })
444c0a0e
C
97
98 await waitJobs(servers)
99
100 {
89d241a7 101 const { data } = await servers[0].videos.list()
d23dd9fb 102 for (const video of data) {
89d241a7
C
103 await servers[0].comments.createThread({ videoId: video.id, text: 'comment by root server 1' })
104 await servers[0].comments.createThread({ token: user1Token, videoId: video.id, text: 'comment by user 1' })
105 await servers[0].comments.createThread({ token: user2Token, videoId: video.id, text: 'comment by user 2' })
444c0a0e
C
106 }
107 }
108
109 {
89d241a7 110 const { data } = await servers[1].videos.list()
12edc149 111
d23dd9fb 112 for (const video of data) {
89d241a7 113 await servers[1].comments.createThread({ videoId: video.id, text: 'comment by root server 2' })
444c0a0e 114
89d241a7 115 const comment = await servers[1].comments.createThread({ token: user3Token, videoId: video.id, text: 'comment by user 3' })
12edc149 116 commentsUser3.push({ videoId: video.id, commentId: comment.id })
444c0a0e
C
117 }
118 }
119
120 await waitJobs(servers)
121 })
122
123 it('Should delete comments of an account on my videos', async function () {
124 this.timeout(60000)
125
a6a79eae 126 await bulkCommand.removeCommentsOf({
12edc149 127 token: user1Token,
444c0a0e
C
128 attributes: {
129 accountName: 'user2',
130 scope: 'my-videos'
131 }
132 })
133
134 await waitJobs(servers)
135
136 for (const server of servers) {
89d241a7 137 const { data } = await server.videos.list()
444c0a0e 138
d23dd9fb 139 for (const video of data) {
89d241a7 140 const { data } = await server.comments.listThreads({ videoId: video.id })
12edc149 141 const comment = data.find(c => c.text === 'comment by user 2')
444c0a0e 142
12edc149
C
143 if (video.name === 'video 3 server 1') expect(comment).to.not.exist
144 else expect(comment).to.exist
444c0a0e
C
145 }
146 }
147 })
148
149 it('Should delete comments of an account on the instance', async function () {
150 this.timeout(60000)
151
a6a79eae 152 await bulkCommand.removeCommentsOf({
444c0a0e
C
153 attributes: {
154 accountName: 'user3@localhost:' + servers[1].port,
155 scope: 'instance'
156 }
157 })
158
159 await waitJobs(servers)
160
161 await checkInstanceCommentsRemoved()
162 })
163
164 it('Should not re create the comment on video update', async function () {
165 this.timeout(60000)
166
167 for (const obj of commentsUser3) {
89d241a7 168 await servers[1].comments.addReply({
12edc149
C
169 token: user3Token,
170 videoId: obj.videoId,
171 toCommentId: obj.commentId,
172 text: 'comment by user 3 bis'
173 })
444c0a0e
C
174 }
175
176 await waitJobs(servers)
177
178 await checkInstanceCommentsRemoved()
179 })
180 })
181
182 after(async function () {
183 await cleanupTests(servers)
184 })
185})