import 'mocha'
import * as chai from 'chai'
-import { HttpStatusCode } from '../../../../shared/core-utils/miscs/http-error-codes'
import {
ChangeOwnershipCommand,
cleanupTests,
+ createMultipleServers,
+ createSingleServer,
doubleFollow,
- flushAndRunMultipleServers,
- flushAndRunServer,
- getVideo,
- getVideosList,
- ServerInfo,
+ PeerTubeServer,
setAccessTokensToServers,
setDefaultVideoChannel,
- uploadVideo
-} from '../../../../shared/extra-utils'
-import { waitJobs } from '../../../../shared/extra-utils/server/jobs'
-import { VideoDetails, VideoPrivacy } from '../../../../shared/models/videos'
+ 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[] = []
+ let servers: PeerTubeServer[] = []
const firstUser = 'first'
const secondUser = 'second'
before(async function () {
this.timeout(50000)
- servers = await flushAndRunMultipleServers(2)
+ servers = await createMultipleServers(2)
await setAccessTokensToServers(servers)
await setDefaultVideoChannel(servers)
- await servers[0].configCommand.updateCustomSubConfig({
+ await servers[0].config.updateCustomSubConfig({
newConfig: {
transcoding: {
enabled: false
}
})
- firstUserToken = await servers[0].usersCommand.generateUserAndToken(firstUser)
- secondUserToken = await servers[0].usersCommand.generateUserAndToken(secondUser)
+ firstUserToken = await servers[0].users.generateUserAndToken(firstUser)
+ secondUserToken = await servers[0].users.generateUserAndToken(secondUser)
{
- const { videoChannels } = await servers[0].usersCommand.getMyInfo({ token: firstUserToken })
+ const { videoChannels } = await servers[0].users.getMyInfo({ token: firstUserToken })
firstUserChannelId = videoChannels[0].id
}
{
- const { videoChannels } = await servers[0].usersCommand.getMyInfo({ token: secondUserToken })
+ const { videoChannels } = await servers[0].users.getMyInfo({ token: secondUserToken })
secondUserChannelId = videoChannels[0].id
}
{
- const videoAttributes = {
+ const attributes = {
name: 'my super name',
description: 'my super description'
}
- const res = await uploadVideo(servers[0].url, firstUserToken, videoAttributes)
+ const { id } = await servers[0].videos.upload({ token: firstUserToken, attributes })
- const resVideo = await getVideo(servers[0].url, res.body.video.id)
- servers[0].video = resVideo.body
+ servers[0].store.videoCreated = await servers[0].videos.get({ id })
}
{
const attributes = { name: 'live', channelId: firstUserChannelId, privacy: VideoPrivacy.PUBLIC }
- const video = await servers[0].liveCommand.create({ token: firstUserToken, fields: attributes })
+ const video = await servers[0].live.create({ token: firstUserToken, fields: attributes })
liveId = video.id
}
- command = servers[0].changeOwnershipCommand
+ command = servers[0].changeOwnership
await doubleFollow(servers[0], servers[1])
})
it('Should send a request to change ownership of a video', async function () {
this.timeout(15000)
- await command.create({ token: firstUserToken, videoId: servers[0].video.id, username: secondUser })
+ 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 () {
it('Should accept the same change ownership request without crashing', async function () {
this.timeout(10000)
- await command.create({ token: firstUserToken, videoId: servers[0].video.id, username: secondUser })
+ 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 () {
it('Should send a new request to change ownership of a video', async function () {
this.timeout(15000)
- await command.create({ token: firstUserToken, videoId: servers[0].video.id, username: secondUser })
+ 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 () {
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
+ 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')
await waitJobs(servers)
for (const server of servers) {
- const res = await getVideo(server.url, servers[0].video.uuid)
-
- const video: VideoDetails = res.body
+ 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
+ let server: PeerTubeServer
const firstUser = 'first'
const secondUser = 'second'
this.timeout(50000)
// Run one server
- server = await flushAndRunServer(1)
+ server = await createSingleServer(1)
await setAccessTokensToServers([ server ])
- await server.usersCommand.create({ username: secondUser, videoQuota: 10 })
+ await server.users.create({ username: secondUser, videoQuota: 10 })
- firstUserToken = await server.usersCommand.generateUserAndToken(firstUser)
- secondUserToken = await server.loginCommand.getAccessToken(secondUser)
+ 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, firstUserToken, 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 server.changeOwnershipCommand.create({ token: firstUserToken, videoId: server.video.id, username: secondUser })
+ 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 body = await server.changeOwnershipCommand.list({ token: firstUserToken })
+ const body = await server.changeOwnership.list({ token: firstUserToken })
expect(body.total).to.equal(0)
expect(body.data).to.be.an('array')
}
{
- const body = await server.changeOwnershipCommand.list({ token: secondUserToken })
+ const body = await server.changeOwnership.list({ token: secondUserToken })
expect(body.total).to.equal(1)
expect(body.data).to.be.an('array')
it('Should not be possible to accept the change of ownership from second user because of exceeded quota', async function () {
this.timeout(10000)
- const { videoChannels } = await server.usersCommand.getMyInfo({ token: secondUserToken })
+ const { videoChannels } = await server.users.getMyInfo({ token: secondUserToken })
const channelId = videoChannels[0].id
- await server.changeOwnershipCommand.accept({
+ await server.changeOwnership.accept({
token: secondUserToken,
ownershipId: lastRequestId,
channelId,