248 lines
7.4 KiB
TypeScript
248 lines
7.4 KiB
TypeScript
/* eslint-disable @typescript-eslint/no-unused-expressions,@typescript-eslint/require-await */
|
|
|
|
import 'mocha'
|
|
import * as chai from 'chai'
|
|
import {
|
|
checkActorFilesWereRemoved,
|
|
checkTmpIsEmpty,
|
|
checkVideoFilesWereRemoved,
|
|
cleanupTests,
|
|
createUser,
|
|
doubleFollow,
|
|
flushAndRunMultipleServers,
|
|
getAccountVideos,
|
|
getMyUserInformation,
|
|
getVideoChannelsList,
|
|
removeUser,
|
|
ServerInfo,
|
|
setAccessTokensToServers,
|
|
testImage,
|
|
updateMyAvatar,
|
|
updateMyUser,
|
|
uploadVideo,
|
|
userLogin,
|
|
waitJobs
|
|
} from '@shared/extra-utils'
|
|
import { User, VideoChannel } from '@shared/models'
|
|
|
|
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(120_000)
|
|
|
|
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(10_000)
|
|
|
|
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(10_000)
|
|
|
|
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 () {
|
|
let createdAt: string | Date
|
|
|
|
for (const server of servers) {
|
|
const body = await server.accountsCommand.list({ sort: '-createdAt' })
|
|
|
|
const resList = body.data.find(a => a.name === 'root' && a.host === 'localhost:' + servers[0].port)
|
|
expect(resList).not.to.be.undefined
|
|
|
|
const account = await server.accountsCommand.get({ accountName: resList.name + '@' + resList.host })
|
|
|
|
if (!createdAt) createdAt = account.createdAt
|
|
|
|
expect(account.name).to.equal('root')
|
|
expect(account.host).to.equal('localhost:' + servers[0].port)
|
|
expect(account.displayName).to.equal('my super display name')
|
|
expect(account.description).to.equal('my super description updated')
|
|
expect(createdAt).to.equal(account.createdAt)
|
|
|
|
if (server.serverNumber === 1) {
|
|
expect(account.userId).to.be.a('number')
|
|
} else {
|
|
expect(account.userId).to.be.undefined
|
|
}
|
|
|
|
await testImage(server.url, 'avatar2-resized', account.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 search through account videos', async function () {
|
|
this.timeout(10_000)
|
|
|
|
const resVideo = await uploadVideo(servers[0].url, userAccessToken, { name: 'Kami no chikara' })
|
|
|
|
await waitJobs(servers)
|
|
|
|
for (const server of servers) {
|
|
const res = await getAccountVideos(server.url, server.accessToken, 'user1@localhost:' + servers[0].port, 0, 5, undefined, {
|
|
search: 'Kami'
|
|
})
|
|
|
|
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(resVideo.body.video.uuid)
|
|
}
|
|
})
|
|
|
|
it('Should remove the user', async function () {
|
|
this.timeout(10_000)
|
|
|
|
for (const server of servers) {
|
|
const body = await server.accountsCommand.list({ sort: '-createdAt' })
|
|
|
|
const accountDeleted = body.data.find(a => a.name === 'user1' && a.host === 'localhost:' + servers[0].port)
|
|
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 body = await server.accountsCommand.list({ sort: '-createdAt' })
|
|
|
|
const accountDeleted = body.data.find(a => a.name === 'user1' && a.host === 'localhost:' + servers[0].port)
|
|
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)
|
|
})
|
|
})
|