Add user adminFlags
[oweals/peertube.git] / server / tests / api / users / users-multiple-servers.ts
1 /* tslint:disable:no-unused-expression */
2
3 import * as chai from 'chai'
4 import 'mocha'
5 import { Account } from '../../../../shared/models/actors'
6 import {
7   checkTmpIsEmpty,
8   checkVideoFilesWereRemoved,
9   createUser,
10   doubleFollow,
11   flushAndRunMultipleServers,
12   getAccountVideos,
13   getVideoChannelsList,
14   removeUser,
15   updateMyUser,
16   userLogin
17 } from '../../../../shared/utils'
18 import { getMyUserInformation, killallServers, ServerInfo, testImage, updateMyAvatar, uploadVideo } from '../../../../shared/utils/index'
19 import { checkActorFilesWereRemoved, getAccount, getAccountsList } from '../../../../shared/utils/users/accounts'
20 import { setAccessTokensToServers } from '../../../../shared/utils/users/login'
21 import { User } from '../../../../shared/models/users'
22 import { VideoChannel } from '../../../../shared/models/videos'
23 import { waitJobs } from '../../../../shared/utils/server/jobs'
24
25 const expect = chai.expect
26
27 describe('Test users with multiple servers', function () {
28   let servers: ServerInfo[] = []
29   let user: User
30   let userAccountName: string
31   let userAccountUUID: string
32   let userVideoChannelUUID: string
33   let userId: number
34   let videoUUID: string
35   let userAccessToken: string
36
37   before(async function () {
38     this.timeout(120000)
39
40     servers = await flushAndRunMultipleServers(3)
41
42     // Get the access tokens
43     await setAccessTokensToServers(servers)
44
45     // Server 1 and server 2 follow each other
46     await doubleFollow(servers[0], servers[1])
47     // Server 1 and server 3 follow each other
48     await doubleFollow(servers[0], servers[2])
49     // Server 2 and server 3 follow each other
50     await doubleFollow(servers[1], servers[2])
51
52     // The root user of server 1 is propagated to servers 2 and 3
53     await uploadVideo(servers[0].url, servers[0].accessToken, {})
54
55     {
56       const user = {
57         username: 'user1',
58         password: 'password'
59       }
60       const res = await createUser({
61         url: servers[ 0 ].url,
62         accessToken: servers[ 0 ].accessToken,
63         username: user.username,
64         password: user.password
65       })
66       userId = res.body.user.id
67       userAccessToken = await userLogin(servers[ 0 ], user)
68     }
69
70     {
71       const res = await getMyUserInformation(servers[0].url, userAccessToken)
72       const account: Account = res.body.account
73       userAccountName = account.name + '@' + account.host
74       userAccountUUID = account.uuid
75     }
76
77     {
78       const res = await getMyUserInformation(servers[ 0 ].url, servers[ 0 ].accessToken)
79       const user: User = res.body
80       userVideoChannelUUID = user.videoChannels[0].uuid
81     }
82
83     {
84       const resVideo = await uploadVideo(servers[ 0 ].url, userAccessToken, {})
85       videoUUID = resVideo.body.video.uuid
86     }
87
88     await waitJobs(servers)
89   })
90
91   it('Should be able to update my display name', async function () {
92     this.timeout(10000)
93
94     await updateMyUser({
95       url: servers[0].url,
96       accessToken: servers[0].accessToken,
97       displayName: 'my super display name'
98     })
99
100     const res = await getMyUserInformation(servers[0].url, servers[0].accessToken)
101     user = res.body
102     expect(user.account.displayName).to.equal('my super display name')
103
104     await waitJobs(servers)
105   })
106
107   it('Should be able to update my description', async function () {
108     this.timeout(10000)
109
110     await updateMyUser({
111       url: servers[0].url,
112       accessToken: servers[0].accessToken,
113       description: 'my super description updated'
114     })
115
116     const res = await getMyUserInformation(servers[0].url, servers[0].accessToken)
117     user = res.body
118     expect(user.account.displayName).to.equal('my super display name')
119     expect(user.account.description).to.equal('my super description updated')
120
121     await waitJobs(servers)
122   })
123
124   it('Should be able to update my avatar', async function () {
125     this.timeout(10000)
126
127     const fixture = 'avatar2.png'
128
129     await updateMyAvatar({
130       url: servers[0].url,
131       accessToken: servers[0].accessToken,
132       fixture
133     })
134
135     const res = await getMyUserInformation(servers[0].url, servers[0].accessToken)
136     user = res.body
137
138     await testImage(servers[0].url, 'avatar2-resized', user.account.avatar.path, '.png')
139
140     await waitJobs(servers)
141   })
142
143   it('Should have updated my profile on other servers too', async function () {
144     for (const server of servers) {
145       const resAccounts = await getAccountsList(server.url, '-createdAt')
146
147       const rootServer1List = resAccounts.body.data.find(a => a.name === 'root' && a.host === 'localhost:9001') as Account
148       expect(rootServer1List).not.to.be.undefined
149
150       const resAccount = await getAccount(server.url, rootServer1List.name + '@' + rootServer1List.host)
151       const rootServer1Get = resAccount.body as Account
152       expect(rootServer1Get.name).to.equal('root')
153       expect(rootServer1Get.host).to.equal('localhost:9001')
154       expect(rootServer1Get.displayName).to.equal('my super display name')
155       expect(rootServer1Get.description).to.equal('my super description updated')
156
157       if (server.serverNumber === 1) {
158         expect(rootServer1Get.userId).to.be.a('number')
159       } else {
160         expect(rootServer1Get.userId).to.be.undefined
161       }
162
163       await testImage(server.url, 'avatar2-resized', rootServer1Get.avatar.path, '.png')
164     }
165   })
166
167   it('Should list account videos', async function () {
168     for (const server of servers) {
169       const res = await getAccountVideos(server.url, server.accessToken, userAccountName, 0, 5)
170
171       expect(res.body.total).to.equal(1)
172       expect(res.body.data).to.be.an('array')
173       expect(res.body.data).to.have.lengthOf(1)
174       expect(res.body.data[0].uuid).to.equal(videoUUID)
175     }
176   })
177
178   it('Should remove the user', async function () {
179     this.timeout(10000)
180
181     for (const server of servers) {
182       const resAccounts = await getAccountsList(server.url, '-createdAt')
183
184       const accountDeleted = resAccounts.body.data.find(a => a.name === 'user1' && a.host === 'localhost:9001') as Account
185       expect(accountDeleted).not.to.be.undefined
186
187       const resVideoChannels = await getVideoChannelsList(server.url, 0, 10)
188       const videoChannelDeleted = resVideoChannels.body.data.find(a => {
189         return a.displayName === 'Main user1 channel' && a.host === 'localhost:9001'
190       }) as VideoChannel
191       expect(videoChannelDeleted).not.to.be.undefined
192     }
193
194     await removeUser(servers[0].url, userId, servers[0].accessToken)
195
196     await waitJobs(servers)
197
198     for (const server of servers) {
199       const resAccounts = await getAccountsList(server.url, '-createdAt')
200
201       const accountDeleted = resAccounts.body.data.find(a => a.name === 'user1' && a.host === 'localhost:9001') as Account
202       expect(accountDeleted).to.be.undefined
203
204       const resVideoChannels = await getVideoChannelsList(server.url, 0, 10)
205       const videoChannelDeleted = resVideoChannels.body.data.find(a => {
206         return a.name === 'Main user1 channel' && a.host === 'localhost:9001'
207       }) as VideoChannel
208       expect(videoChannelDeleted).to.be.undefined
209     }
210   })
211
212   it('Should not have actor files', async () => {
213     for (const server of servers) {
214       await checkActorFilesWereRemoved(userAccountUUID, server.serverNumber)
215       await checkActorFilesWereRemoved(userVideoChannelUUID, server.serverNumber)
216     }
217   })
218
219   it('Should not have video files', async () => {
220     for (const server of servers) {
221       await checkVideoFilesWereRemoved(videoUUID, server.serverNumber)
222     }
223   })
224
225   it('Should have an empty tmp directory', async function () {
226     for (const server of servers) {
227       await checkTmpIsEmpty(server)
228     }
229   })
230
231   after(async function () {
232     killallServers(servers)
233   })
234 })