223 lines
7.2 KiB
TypeScript
223 lines
7.2 KiB
TypeScript
/* eslint-disable @typescript-eslint/no-unused-expressions,@typescript-eslint/require-await */
|
|
|
|
import * as chai from 'chai'
|
|
import 'mocha'
|
|
import { Account } from '../../../../shared/models/actors'
|
|
import {
|
|
checkTmpIsEmpty,
|
|
checkVideoFilesWereRemoved,
|
|
cleanupTests,
|
|
createUser,
|
|
doubleFollow,
|
|
flushAndRunMultipleServers,
|
|
getAccountVideos,
|
|
getVideoChannelsList,
|
|
removeUser,
|
|
updateMyUser,
|
|
userLogin
|
|
} from '../../../../shared/extra-utils'
|
|
import { getMyUserInformation, ServerInfo, testImage, updateMyAvatar, uploadVideo } from '../../../../shared/extra-utils/index'
|
|
import { checkActorFilesWereRemoved, getAccount, getAccountsList } from '../../../../shared/extra-utils/users/accounts'
|
|
import { setAccessTokensToServers } from '../../../../shared/extra-utils/users/login'
|
|
import { User } from '../../../../shared/models/users'
|
|
import { VideoChannel } from '../../../../shared/models/videos'
|
|
import { waitJobs } from '../../../../shared/extra-utils/server/jobs'
|
|
|
|
const expect = chai.expect
|
|
|
|
describe('Test users with multiple servers', function () {
|
|
let servers: ServerInfo[] = []
|
|
let user: User
|
|
let userId: number
|
|
let videoUUID: string
|
|
let userAccessToken: string
|
|
let userAvatarFilename: string
|
|
|
|
before(async function () {
|
|
this.timeout(120000)
|
|
|
|
servers = await flushAndRunMultipleServers(3)
|
|
|
|
// Get the access tokens
|
|
await setAccessTokensToServers(servers)
|
|
|
|
// Server 1 and server 2 follow each other
|
|
await doubleFollow(servers[0], servers[1])
|
|
// Server 1 and server 3 follow each other
|
|
await doubleFollow(servers[0], servers[2])
|
|
// Server 2 and server 3 follow each other
|
|
await doubleFollow(servers[1], servers[2])
|
|
|
|
// The root user of server 1 is propagated to servers 2 and 3
|
|
await uploadVideo(servers[0].url, servers[0].accessToken, {})
|
|
|
|
{
|
|
const user = {
|
|
username: 'user1',
|
|
password: 'password'
|
|
}
|
|
const res = await createUser({
|
|
url: servers[0].url,
|
|
accessToken: servers[0].accessToken,
|
|
username: user.username,
|
|
password: user.password
|
|
})
|
|
userId = res.body.user.id
|
|
userAccessToken = await userLogin(servers[0], user)
|
|
}
|
|
|
|
{
|
|
const resVideo = await uploadVideo(servers[0].url, userAccessToken, {})
|
|
videoUUID = resVideo.body.video.uuid
|
|
}
|
|
|
|
await waitJobs(servers)
|
|
})
|
|
|
|
it('Should be able to update my display name', async function () {
|
|
this.timeout(10000)
|
|
|
|
await updateMyUser({
|
|
url: servers[0].url,
|
|
accessToken: servers[0].accessToken,
|
|
displayName: 'my super display name'
|
|
})
|
|
|
|
const res = await getMyUserInformation(servers[0].url, servers[0].accessToken)
|
|
user = res.body
|
|
|
|
expect(user.account.displayName).to.equal('my super display name')
|
|
|
|
await waitJobs(servers)
|
|
})
|
|
|
|
it('Should be able to update my description', async function () {
|
|
this.timeout(10000)
|
|
|
|
await updateMyUser({
|
|
url: servers[0].url,
|
|
accessToken: servers[0].accessToken,
|
|
description: 'my super description updated'
|
|
})
|
|
|
|
const res = await getMyUserInformation(servers[0].url, servers[0].accessToken)
|
|
user = res.body
|
|
expect(user.account.displayName).to.equal('my super display name')
|
|
expect(user.account.description).to.equal('my super description updated')
|
|
|
|
await waitJobs(servers)
|
|
})
|
|
|
|
it('Should be able to update my avatar', async function () {
|
|
this.timeout(10000)
|
|
|
|
const fixture = 'avatar2.png'
|
|
|
|
await updateMyAvatar({
|
|
url: servers[0].url,
|
|
accessToken: servers[0].accessToken,
|
|
fixture
|
|
})
|
|
|
|
const res = await getMyUserInformation(servers[0].url, servers[0].accessToken)
|
|
user = res.body
|
|
|
|
userAvatarFilename = user.account.avatar.path
|
|
|
|
await testImage(servers[0].url, 'avatar2-resized', userAvatarFilename, '.png')
|
|
|
|
await waitJobs(servers)
|
|
})
|
|
|
|
it('Should have updated my profile on other servers too', async function () {
|
|
for (const server of servers) {
|
|
const resAccounts = await getAccountsList(server.url, '-createdAt')
|
|
|
|
const rootServer1List = resAccounts.body.data.find(a => a.name === 'root' && a.host === 'localhost:' + servers[0].port) as Account
|
|
expect(rootServer1List).not.to.be.undefined
|
|
|
|
const resAccount = await getAccount(server.url, rootServer1List.name + '@' + rootServer1List.host)
|
|
const rootServer1Get = resAccount.body as Account
|
|
expect(rootServer1Get.name).to.equal('root')
|
|
expect(rootServer1Get.host).to.equal('localhost:' + servers[0].port)
|
|
expect(rootServer1Get.displayName).to.equal('my super display name')
|
|
expect(rootServer1Get.description).to.equal('my super description updated')
|
|
|
|
if (server.serverNumber === 1) {
|
|
expect(rootServer1Get.userId).to.be.a('number')
|
|
} else {
|
|
expect(rootServer1Get.userId).to.be.undefined
|
|
}
|
|
|
|
await testImage(server.url, 'avatar2-resized', rootServer1Get.avatar.path, '.png')
|
|
}
|
|
})
|
|
|
|
it('Should list account videos', async function () {
|
|
for (const server of servers) {
|
|
const res = await getAccountVideos(server.url, server.accessToken, 'user1@localhost:' + servers[0].port, 0, 5)
|
|
|
|
expect(res.body.total).to.equal(1)
|
|
expect(res.body.data).to.be.an('array')
|
|
expect(res.body.data).to.have.lengthOf(1)
|
|
expect(res.body.data[0].uuid).to.equal(videoUUID)
|
|
}
|
|
})
|
|
|
|
it('Should remove the user', async function () {
|
|
this.timeout(10000)
|
|
|
|
for (const server of servers) {
|
|
const resAccounts = await getAccountsList(server.url, '-createdAt')
|
|
|
|
const accountDeleted = resAccounts.body.data.find(a => a.name === 'user1' && a.host === 'localhost:' + servers[0].port) as Account
|
|
expect(accountDeleted).not.to.be.undefined
|
|
|
|
const resVideoChannels = await getVideoChannelsList(server.url, 0, 10)
|
|
const videoChannelDeleted = resVideoChannels.body.data.find(a => {
|
|
return a.displayName === 'Main user1 channel' && a.host === 'localhost:' + servers[0].port
|
|
}) as VideoChannel
|
|
expect(videoChannelDeleted).not.to.be.undefined
|
|
}
|
|
|
|
await removeUser(servers[0].url, userId, servers[0].accessToken)
|
|
|
|
await waitJobs(servers)
|
|
|
|
for (const server of servers) {
|
|
const resAccounts = await getAccountsList(server.url, '-createdAt')
|
|
|
|
const accountDeleted = resAccounts.body.data.find(a => a.name === 'user1' && a.host === 'localhost:' + servers[0].port) as Account
|
|
expect(accountDeleted).to.be.undefined
|
|
|
|
const resVideoChannels = await getVideoChannelsList(server.url, 0, 10)
|
|
const videoChannelDeleted = resVideoChannels.body.data.find(a => {
|
|
return a.name === 'Main user1 channel' && a.host === 'localhost:' + servers[0].port
|
|
}) as VideoChannel
|
|
expect(videoChannelDeleted).to.be.undefined
|
|
}
|
|
})
|
|
|
|
it('Should not have actor files', async () => {
|
|
for (const server of servers) {
|
|
await checkActorFilesWereRemoved(userAvatarFilename, server.internalServerNumber)
|
|
}
|
|
})
|
|
|
|
it('Should not have video files', async () => {
|
|
for (const server of servers) {
|
|
await checkVideoFilesWereRemoved(videoUUID, server.internalServerNumber)
|
|
}
|
|
})
|
|
|
|
it('Should have an empty tmp directory', async function () {
|
|
for (const server of servers) {
|
|
await checkTmpIsEmpty(server)
|
|
}
|
|
})
|
|
|
|
after(async function () {
|
|
await cleanupTests(servers)
|
|
})
|
|
})
|