-/* tslint:disable:no-unused-expression */
+/* eslint-disable @typescript-eslint/no-unused-expressions,@typescript-eslint/require-await */
-import * as chai from 'chai'
import 'mocha'
+import * as chai from 'chai'
import {
- acceptChangeOwnership,
- changeVideoOwnership,
+ ChangeOwnershipCommand,
cleanupTests,
- createUser,
+ createMultipleServers,
+ createSingleServer,
doubleFollow,
- flushAndRunMultipleServers,
- flushAndRunServer,
- getMyUserInformation,
- getVideo,
- getVideoChangeOwnershipList,
- getVideosList,
- refuseChangeOwnership,
- ServerInfo,
+ PeerTubeServer,
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'
+ setDefaultVideoChannel,
+ waitJobs
+} from '@shared/server-commands'
+import { HttpStatusCode, VideoPrivacy } from '@shared/models'
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 = undefined
+ let servers: PeerTubeServer[] = []
+
+ const firstUser = 'first'
+ const secondUser = 'second'
+
+ let firstUserToken = ''
+ let firstUserChannelId: number
+
+ let secondUserToken = ''
+ let secondUserChannelId: number
+
+ let lastRequestId: number
+
+ let liveId: number
+
+ let command: ChangeOwnershipCommand
before(async function () {
this.timeout(50000)
- servers = await flushAndRunMultipleServers(2)
+ servers = await createMultipleServers(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
+ await setDefaultVideoChannel(servers)
+
+ await servers[0].config.updateCustomSubConfig({
+ newConfig: {
+ transcoding: {
+ enabled: false
+ },
+ live: {
+ enabled: true
+ }
+ }
})
- firstUserAccessToken = await userLogin(servers[0], firstUser)
- secondUserAccessToken = await userLogin(servers[0], secondUser)
+ firstUserToken = await servers[0].users.generateUserAndToken(firstUser)
+ secondUserToken = await servers[0].users.generateUserAndToken(secondUser)
- const videoAttributes = {
- name: 'my super name',
- description: 'my super description'
+ {
+ const { videoChannels } = await servers[0].users.getMyInfo({ token: firstUserToken })
+ firstUserChannelId = videoChannels[0].id
}
- await uploadVideo(servers[0].url, firstUserAccessToken, videoAttributes)
- await waitJobs(servers)
+ {
+ const { videoChannels } = await servers[0].users.getMyInfo({ token: secondUserToken })
+ secondUserChannelId = videoChannels[0].id
+ }
+
+ {
+ const attributes = {
+ name: 'my super name',
+ description: 'my super description'
+ }
+ const { id } = await servers[0].videos.upload({ token: firstUserToken, attributes })
- const res = await getVideosList(servers[0].url)
- const videos = res.body.data
+ servers[0].store.videoCreated = await servers[0].videos.get({ id })
+ }
- expect(videos.length).to.equal(1)
+ {
+ const attributes = { name: 'live', channelId: firstUserChannelId, privacy: VideoPrivacy.PUBLIC }
+ const video = await servers[0].live.create({ token: firstUserToken, fields: attributes })
- const video = videos.find(video => video.name === 'my super name')
- expect(video.channel.name).to.equal('first_channel')
- servers[0].video = video
+ liveId = video.id
+ }
+
+ command = servers[0].changeOwnership
await doubleFollow(servers[0], servers[1])
})
it('Should not have video change ownership', async function () {
- const resFirstUser = await getVideoChangeOwnershipList(servers[0].url, firstUserAccessToken)
+ {
+ const body = await command.list({ token: firstUserToken })
- expect(resFirstUser.body.total).to.equal(0)
- expect(resFirstUser.body.data).to.be.an('array')
- expect(resFirstUser.body.data.length).to.equal(0)
+ expect(body.total).to.equal(0)
+ expect(body.data).to.be.an('array')
+ expect(body.data.length).to.equal(0)
+ }
- const resSecondUser = await getVideoChangeOwnershipList(servers[0].url, secondUserAccessToken)
+ {
+ const body = await command.list({ token: secondUserToken })
- expect(resSecondUser.body.total).to.equal(0)
- expect(resSecondUser.body.data).to.be.an('array')
- expect(resSecondUser.body.data.length).to.equal(0)
+ expect(body.total).to.equal(0)
+ expect(body.data).to.be.an('array')
+ expect(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)
+ await command.create({ token: firstUserToken, videoId: servers[0].store.videoCreated.id, username: secondUser })
})
it('Should only return a request to change ownership for the second user', async function () {
- const resFirstUser = await getVideoChangeOwnershipList(servers[0].url, firstUserAccessToken)
+ {
+ const body = await command.list({ token: firstUserToken })
- expect(resFirstUser.body.total).to.equal(0)
- expect(resFirstUser.body.data).to.be.an('array')
- expect(resFirstUser.body.data.length).to.equal(0)
+ expect(body.total).to.equal(0)
+ expect(body.data).to.be.an('array')
+ expect(body.data.length).to.equal(0)
+ }
- const resSecondUser = await getVideoChangeOwnershipList(servers[0].url, secondUserAccessToken)
+ {
+ const body = await command.list({ token: secondUserToken })
- expect(resSecondUser.body.total).to.equal(1)
- expect(resSecondUser.body.data).to.be.an('array')
- expect(resSecondUser.body.data.length).to.equal(1)
+ expect(body.total).to.equal(1)
+ expect(body.data).to.be.an('array')
+ expect(body.data.length).to.equal(1)
- lastRequestChangeOwnershipId = resSecondUser.body.data[0].id
+ lastRequestId = 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)
+ await command.create({ token: firstUserToken, videoId: servers[0].store.videoCreated.id, username: secondUser })
})
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)
+ const body = await command.list({ token: secondUserToken })
- expect(resSecondUser.body.total).to.equal(1)
- expect(resSecondUser.body.data).to.be.an('array')
- expect(resSecondUser.body.data.length).to.equal(1)
+ expect(body.total).to.equal(1)
+ expect(body.data).to.be.an('array')
+ expect(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)
+ await command.refuse({ token: firstUserToken, ownershipId: lastRequestId, expectedStatus: HttpStatusCode.FORBIDDEN_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)
+ await command.refuse({ token: secondUserToken, ownershipId: lastRequestId })
})
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)
+ await command.create({ token: firstUserToken, videoId: servers[0].store.videoCreated.id, username: secondUser })
})
it('Should return two requests to change ownership for the second user', async function () {
- const resFirstUser = await getVideoChangeOwnershipList(servers[0].url, firstUserAccessToken)
+ {
+ const body = await command.list({ token: firstUserToken })
- expect(resFirstUser.body.total).to.equal(0)
- expect(resFirstUser.body.data).to.be.an('array')
- expect(resFirstUser.body.data.length).to.equal(0)
+ expect(body.total).to.equal(0)
+ expect(body.data).to.be.an('array')
+ expect(body.data.length).to.equal(0)
+ }
- const resSecondUser = await getVideoChangeOwnershipList(servers[0].url, secondUserAccessToken)
+ {
+ const body = await command.list({ token: secondUserToken })
- expect(resSecondUser.body.total).to.equal(2)
- expect(resSecondUser.body.data).to.be.an('array')
- expect(resSecondUser.body.data.length).to.equal(2)
+ expect(body.total).to.equal(2)
+ expect(body.data).to.be.an('array')
+ expect(body.data.length).to.equal(2)
- lastRequestChangeOwnershipId = resSecondUser.body.data[0].id
+ lastRequestId = 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)
+ await command.accept({
+ token: firstUserToken,
+ ownershipId: lastRequestId,
+ channelId: secondUserChannelId,
+ expectedStatus: HttpStatusCode.FORBIDDEN_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 command.accept({ token: secondUserToken, ownershipId: lastRequestId, channelId: secondUserChannelId })
await waitJobs(servers)
})
- it('Should have video channel updated', async function () {
+ 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 = await server.videos.get({ id: servers[0].store.videoCreated.uuid })
+
+ 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')
+ }
+ })
+
+ it('Should send a request to change ownership of a live', async function () {
+ this.timeout(15000)
+
+ await command.create({ token: firstUserToken, videoId: liveId, username: secondUser })
+
+ const body = await command.list({ token: secondUserToken })
+
+ expect(body.total).to.equal(3)
+ expect(body.data.length).to.equal(3)
+
+ lastRequestId = body.data[0].id
+ })
+
+ it('Should accept a live ownership change', async function () {
+ this.timeout(20000)
- const video: VideoDetails = res.body
+ await command.accept({ token: secondUserToken, ownershipId: lastRequestId, channelId: secondUserChannelId })
+
+ await waitJobs(servers)
+
+ for (const server of servers) {
+ const video = await server.videos.get({ id: servers[0].store.videoCreated.uuid })
expect(video.name).to.equal('my super name')
expect(video.channel.displayName).to.equal('Main second channel')
})
describe('Test video change ownership - quota too small', function () {
- let server: ServerInfo = undefined
- const firstUser = {
- username: 'first',
- password: 'My great password'
- }
- const secondUser = {
- username: 'second',
- password: 'My other password'
- }
- let firstUserAccessToken = ''
- let secondUserAccessToken = ''
- let lastRequestChangeOwnershipId = undefined
+ let server: PeerTubeServer
+ const firstUser = 'first'
+ const secondUser = 'second'
+
+ let firstUserToken = ''
+ let secondUserToken = ''
+ let lastRequestId: number
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
- })
+ server = await createSingleServer(1)
+ await setAccessTokensToServers([ server ])
- firstUserAccessToken = await userLogin(server, firstUser)
- secondUserAccessToken = await userLogin(server, secondUser)
+ await server.users.create({ username: secondUser, videoQuota: 10 })
+
+ firstUserToken = await server.users.generateUserAndToken(firstUser)
+ secondUserToken = await server.login.getAccessToken(secondUser)
// Upload some videos on the server
- const video1Attributes = {
+ const attributes = {
name: 'my super name',
description: 'my super description'
}
- await uploadVideo(server.url, firstUserAccessToken, video1Attributes)
+ await server.videos.upload({ token: firstUserToken, attributes })
await waitJobs(server)
- const res = await getVideosList(server.url)
- const videos = res.body.data
-
- expect(videos.length).to.equal(1)
+ const { data } = await server.videos.list()
+ expect(data.length).to.equal(1)
- server.video = videos.find(video => video.name === 'my super name')
+ server.store.videoCreated = data.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)
+ await server.changeOwnership.create({ token: firstUserToken, videoId: server.store.videoCreated.id, username: secondUser })
})
it('Should only return a request to change ownership for the second user', async function () {
- const resFirstUser = await getVideoChangeOwnershipList(server.url, firstUserAccessToken)
+ {
+ const body = await server.changeOwnership.list({ token: firstUserToken })
- expect(resFirstUser.body.total).to.equal(0)
- expect(resFirstUser.body.data).to.be.an('array')
- expect(resFirstUser.body.data.length).to.equal(0)
+ expect(body.total).to.equal(0)
+ expect(body.data).to.be.an('array')
+ expect(body.data.length).to.equal(0)
+ }
- const resSecondUser = await getVideoChangeOwnershipList(server.url, secondUserAccessToken)
+ {
+ const body = await server.changeOwnership.list({ token: secondUserToken })
- expect(resSecondUser.body.total).to.equal(1)
- expect(resSecondUser.body.data).to.be.an('array')
- expect(resSecondUser.body.data.length).to.equal(1)
+ expect(body.total).to.equal(1)
+ expect(body.data).to.be.an('array')
+ expect(body.data.length).to.equal(1)
- lastRequestChangeOwnershipId = resSecondUser.body.data[0].id
+ lastRequestId = 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)
+ const { videoChannels } = await server.users.getMyInfo({ token: secondUserToken })
+ const channelId = videoChannels[0].id
+
+ await server.changeOwnership.accept({
+ token: secondUserToken,
+ ownershipId: lastRequestId,
+ channelId,
+ expectedStatus: HttpStatusCode.PAYLOAD_TOO_LARGE_413
+ })
})
after(async function () {