/* eslint-disable @typescript-eslint/no-unused-expressions,@typescript-eslint/require-await */ import * as chai from 'chai' import 'mocha' import { acceptChangeOwnership, changeVideoOwnership, cleanupTests, createUser, doubleFollow, flushAndRunMultipleServers, flushAndRunServer, getMyUserInformation, getVideo, getVideoChangeOwnershipList, getVideosList, refuseChangeOwnership, ServerInfo, setAccessTokensToServers, uploadVideo, userLogin } from '../../../../shared/extra-utils' import { waitJobs } from '../../../../shared/extra-utils/server/jobs' import { User } from '../../../../shared/models/users' import { VideoDetails } from '../../../../shared/models/videos' const expect = chai.expect describe('Test video change ownership - nominal', function () { let servers: ServerInfo[] = [] const firstUser = { username: 'first', password: 'My great password' } const secondUser = { username: 'second', password: 'My other password' } let firstUserAccessToken = '' let secondUserAccessToken = '' let lastRequestChangeOwnershipId = '' before(async function () { this.timeout(50000) servers = await flushAndRunMultipleServers(2) await setAccessTokensToServers(servers) const videoQuota = 42000000 await createUser({ url: servers[0].url, accessToken: servers[0].accessToken, username: firstUser.username, password: firstUser.password, videoQuota: videoQuota }) await createUser({ url: servers[0].url, accessToken: servers[0].accessToken, username: secondUser.username, password: secondUser.password, videoQuota: videoQuota }) firstUserAccessToken = await userLogin(servers[0], firstUser) secondUserAccessToken = await userLogin(servers[0], secondUser) const videoAttributes = { name: 'my super name', description: 'my super description' } await uploadVideo(servers[0].url, firstUserAccessToken, videoAttributes) await waitJobs(servers) const res = await getVideosList(servers[0].url) const videos = res.body.data expect(videos.length).to.equal(1) const video = videos.find(video => video.name === 'my super name') expect(video.channel.name).to.equal('first_channel') servers[0].video = video await doubleFollow(servers[0], servers[1]) }) it('Should not have video change ownership', async function () { const resFirstUser = await getVideoChangeOwnershipList(servers[0].url, firstUserAccessToken) expect(resFirstUser.body.total).to.equal(0) expect(resFirstUser.body.data).to.be.an('array') expect(resFirstUser.body.data.length).to.equal(0) const resSecondUser = await getVideoChangeOwnershipList(servers[0].url, secondUserAccessToken) expect(resSecondUser.body.total).to.equal(0) expect(resSecondUser.body.data).to.be.an('array') expect(resSecondUser.body.data.length).to.equal(0) }) it('Should send a request to change ownership of a video', async function () { this.timeout(15000) await changeVideoOwnership(servers[0].url, firstUserAccessToken, servers[0].video.id, secondUser.username) }) it('Should only return a request to change ownership for the second user', async function () { const resFirstUser = await getVideoChangeOwnershipList(servers[0].url, firstUserAccessToken) expect(resFirstUser.body.total).to.equal(0) expect(resFirstUser.body.data).to.be.an('array') expect(resFirstUser.body.data.length).to.equal(0) const resSecondUser = await getVideoChangeOwnershipList(servers[0].url, secondUserAccessToken) expect(resSecondUser.body.total).to.equal(1) expect(resSecondUser.body.data).to.be.an('array') expect(resSecondUser.body.data.length).to.equal(1) lastRequestChangeOwnershipId = resSecondUser.body.data[0].id }) it('Should accept the same change ownership request without crashing', async function () { this.timeout(10000) await changeVideoOwnership(servers[0].url, firstUserAccessToken, servers[0].video.id, secondUser.username) }) it('Should not create multiple change ownership requests while one is waiting', async function () { this.timeout(10000) const resSecondUser = await getVideoChangeOwnershipList(servers[0].url, secondUserAccessToken) expect(resSecondUser.body.total).to.equal(1) expect(resSecondUser.body.data).to.be.an('array') expect(resSecondUser.body.data.length).to.equal(1) }) it('Should not be possible to refuse the change of ownership from first user', async function () { this.timeout(10000) await refuseChangeOwnership(servers[0].url, firstUserAccessToken, lastRequestChangeOwnershipId, 403) }) it('Should be possible to refuse the change of ownership from second user', async function () { this.timeout(10000) await refuseChangeOwnership(servers[0].url, secondUserAccessToken, lastRequestChangeOwnershipId) }) it('Should send a new request to change ownership of a video', async function () { this.timeout(15000) await changeVideoOwnership(servers[0].url, firstUserAccessToken, servers[0].video.id, secondUser.username) }) it('Should return two requests to change ownership for the second user', async function () { const resFirstUser = await getVideoChangeOwnershipList(servers[0].url, firstUserAccessToken) expect(resFirstUser.body.total).to.equal(0) expect(resFirstUser.body.data).to.be.an('array') expect(resFirstUser.body.data.length).to.equal(0) const resSecondUser = await getVideoChangeOwnershipList(servers[0].url, secondUserAccessToken) expect(resSecondUser.body.total).to.equal(2) expect(resSecondUser.body.data).to.be.an('array') expect(resSecondUser.body.data.length).to.equal(2) lastRequestChangeOwnershipId = resSecondUser.body.data[0].id }) it('Should not be possible to accept the change of ownership from first user', async function () { this.timeout(10000) const secondUserInformationResponse = await getMyUserInformation(servers[0].url, secondUserAccessToken) const secondUserInformation: User = secondUserInformationResponse.body const channelId = secondUserInformation.videoChannels[0].id await acceptChangeOwnership(servers[0].url, firstUserAccessToken, lastRequestChangeOwnershipId, channelId, 403) }) it('Should be possible to accept the change of ownership from second user', async function () { this.timeout(10000) const secondUserInformationResponse = await getMyUserInformation(servers[0].url, secondUserAccessToken) const secondUserInformation: User = secondUserInformationResponse.body const channelId = secondUserInformation.videoChannels[0].id await acceptChangeOwnership(servers[0].url, secondUserAccessToken, lastRequestChangeOwnershipId, channelId) await waitJobs(servers) }) it('Should have the channel of the video updated', async function () { for (const server of servers) { const res = await getVideo(server.url, servers[0].video.uuid) const video: VideoDetails = res.body expect(video.name).to.equal('my super name') expect(video.channel.displayName).to.equal('Main second channel') expect(video.channel.name).to.equal('second_channel') } }) after(async function () { await cleanupTests(servers) }) }) describe('Test video change ownership - quota too small', function () { let server: ServerInfo const firstUser = { username: 'first', password: 'My great password' } const secondUser = { username: 'second', password: 'My other password' } let firstUserAccessToken = '' let secondUserAccessToken = '' let lastRequestChangeOwnershipId = '' before(async function () { this.timeout(50000) // Run one server server = await flushAndRunServer(1) await setAccessTokensToServers([ server ]) const videoQuota = 42000000 const limitedVideoQuota = 10 await createUser({ url: server.url, accessToken: server.accessToken, username: firstUser.username, password: firstUser.password, videoQuota: videoQuota }) await createUser({ url: server.url, accessToken: server.accessToken, username: secondUser.username, password: secondUser.password, videoQuota: limitedVideoQuota }) firstUserAccessToken = await userLogin(server, firstUser) secondUserAccessToken = await userLogin(server, secondUser) // Upload some videos on the server const video1Attributes = { name: 'my super name', description: 'my super description' } await uploadVideo(server.url, firstUserAccessToken, video1Attributes) await waitJobs(server) const res = await getVideosList(server.url) const videos = res.body.data expect(videos.length).to.equal(1) server.video = videos.find(video => video.name === 'my super name') }) it('Should send a request to change ownership of a video', async function () { this.timeout(15000) await changeVideoOwnership(server.url, firstUserAccessToken, server.video.id, secondUser.username) }) it('Should only return a request to change ownership for the second user', async function () { const resFirstUser = await getVideoChangeOwnershipList(server.url, firstUserAccessToken) expect(resFirstUser.body.total).to.equal(0) expect(resFirstUser.body.data).to.be.an('array') expect(resFirstUser.body.data.length).to.equal(0) const resSecondUser = await getVideoChangeOwnershipList(server.url, secondUserAccessToken) expect(resSecondUser.body.total).to.equal(1) expect(resSecondUser.body.data).to.be.an('array') expect(resSecondUser.body.data.length).to.equal(1) lastRequestChangeOwnershipId = resSecondUser.body.data[0].id }) it('Should not be possible to accept the change of ownership from second user because of exceeded quota', async function () { this.timeout(10000) const secondUserInformationResponse = await getMyUserInformation(server.url, secondUserAccessToken) const secondUserInformation: User = secondUserInformationResponse.body const channelId = secondUserInformation.videoChannels[0].id await acceptChangeOwnership(server.url, secondUserAccessToken, lastRequestChangeOwnershipId, channelId, 403) }) after(async function () { await cleanupTests([ server ]) }) })