/* eslint-disable @typescript-eslint/no-unused-expressions,@typescript-eslint/require-await */
-import 'mocha'
-import * as chai from 'chai'
-import { HttpStatusCode } from '@shared/core-utils'
-import { PeerTubeProblemDocument, ServerErrorCode } from '@shared/models'
+import { expect } from 'chai'
+import { HttpStatusCode, PeerTubeProblemDocument, ServerErrorCode } from '@shared/models'
import {
cleanupTests,
+ createMultipleServers,
doubleFollow,
- flushAndRunMultipleServers,
- getAccountVideos,
- getVideo,
- getVideoChannelVideos,
- getVideoWithToken,
- ServerInfo,
+ PeerTubeServer,
setAccessTokensToServers,
- uploadVideo
-} from '../../../../shared/extra-utils'
-
-const expect = chai.expect
+ waitJobs
+} from '@shared/server-commands'
describe('Test follow constraints', function () {
- let servers: ServerInfo[] = []
+ let servers: PeerTubeServer[] = []
let video1UUID: string
let video2UUID: string
- let userAccessToken: string
+ let userToken: string
before(async function () {
- this.timeout(90000)
+ this.timeout(240000)
- servers = await flushAndRunMultipleServers(2)
+ servers = await createMultipleServers(2)
// Get the access tokens
await setAccessTokensToServers(servers)
{
- const res = await uploadVideo(servers[0].url, servers[0].accessToken, { name: 'video server 1' })
- video1UUID = res.body.video.uuid
+ const { uuid } = await servers[0].videos.upload({ attributes: { name: 'video server 1' } })
+ video1UUID = uuid
}
{
- const res = await uploadVideo(servers[1].url, servers[1].accessToken, { name: 'video server 2' })
- video2UUID = res.body.video.uuid
+ const { uuid } = await servers[1].videos.upload({ attributes: { name: 'video server 2' } })
+ video2UUID = uuid
}
const user = {
username: 'user1',
password: 'super_password'
}
- await servers[0].usersCommand.create({ username: user.username, password: user.password })
- userAccessToken = await servers[0].loginCommand.getAccessToken(user)
+ await servers[0].users.create({ username: user.username, password: user.password })
+ userToken = await servers[0].login.getAccessToken(user)
await doubleFollow(servers[0], servers[1])
})
describe('With an unlogged user', function () {
it('Should get the local video', async function () {
- await getVideo(servers[0].url, video1UUID, HttpStatusCode.OK_200)
+ await servers[0].videos.get({ id: video1UUID })
})
it('Should get the remote video', async function () {
- await getVideo(servers[0].url, video2UUID, HttpStatusCode.OK_200)
+ await servers[0].videos.get({ id: video2UUID })
})
it('Should list local account videos', async function () {
- const res = await getAccountVideos(servers[0].url, undefined, 'root@localhost:' + servers[0].port, 0, 5)
+ const { total, data } = await servers[0].videos.listByAccount({ handle: 'root@' + servers[0].host })
- expect(res.body.total).to.equal(1)
- expect(res.body.data).to.have.lengthOf(1)
+ expect(total).to.equal(1)
+ expect(data).to.have.lengthOf(1)
})
it('Should list remote account videos', async function () {
- const res = await getAccountVideos(servers[0].url, undefined, 'root@localhost:' + servers[1].port, 0, 5)
+ const { total, data } = await servers[0].videos.listByAccount({ handle: 'root@' + servers[1].host })
- expect(res.body.total).to.equal(1)
- expect(res.body.data).to.have.lengthOf(1)
+ expect(total).to.equal(1)
+ expect(data).to.have.lengthOf(1)
})
it('Should list local channel videos', async function () {
- const videoChannelName = 'root_channel@localhost:' + servers[0].port
- const res = await getVideoChannelVideos(servers[0].url, undefined, videoChannelName, 0, 5)
+ const handle = 'root_channel@' + servers[0].host
+ const { total, data } = await servers[0].videos.listByChannel({ handle })
- expect(res.body.total).to.equal(1)
- expect(res.body.data).to.have.lengthOf(1)
+ expect(total).to.equal(1)
+ expect(data).to.have.lengthOf(1)
})
it('Should list remote channel videos', async function () {
- const videoChannelName = 'root_channel@localhost:' + servers[1].port
- const res = await getVideoChannelVideos(servers[0].url, undefined, videoChannelName, 0, 5)
+ const handle = 'root_channel@' + servers[1].host
+ const { total, data } = await servers[0].videos.listByChannel({ handle })
- expect(res.body.total).to.equal(1)
- expect(res.body.data).to.have.lengthOf(1)
+ expect(total).to.equal(1)
+ expect(data).to.have.lengthOf(1)
})
})
describe('With a logged user', function () {
it('Should get the local video', async function () {
- await getVideoWithToken(servers[0].url, userAccessToken, video1UUID, HttpStatusCode.OK_200)
+ await servers[0].videos.getWithToken({ token: userToken, id: video1UUID })
})
it('Should get the remote video', async function () {
- await getVideoWithToken(servers[0].url, userAccessToken, video2UUID, HttpStatusCode.OK_200)
+ await servers[0].videos.getWithToken({ token: userToken, id: video2UUID })
})
it('Should list local account videos', async function () {
- const res = await getAccountVideos(servers[0].url, userAccessToken, 'root@localhost:' + servers[0].port, 0, 5)
+ const { total, data } = await servers[0].videos.listByAccount({ token: userToken, handle: 'root@' + servers[0].host })
- expect(res.body.total).to.equal(1)
- expect(res.body.data).to.have.lengthOf(1)
+ expect(total).to.equal(1)
+ expect(data).to.have.lengthOf(1)
})
it('Should list remote account videos', async function () {
- const res = await getAccountVideos(servers[0].url, userAccessToken, 'root@localhost:' + servers[1].port, 0, 5)
+ const { total, data } = await servers[0].videos.listByAccount({ token: userToken, handle: 'root@' + servers[1].host })
- expect(res.body.total).to.equal(1)
- expect(res.body.data).to.have.lengthOf(1)
+ expect(total).to.equal(1)
+ expect(data).to.have.lengthOf(1)
})
it('Should list local channel videos', async function () {
- const videoChannelName = 'root_channel@localhost:' + servers[0].port
- const res = await getVideoChannelVideos(servers[0].url, userAccessToken, videoChannelName, 0, 5)
+ const handle = 'root_channel@' + servers[0].host
+ const { total, data } = await servers[0].videos.listByChannel({ token: userToken, handle })
- expect(res.body.total).to.equal(1)
- expect(res.body.data).to.have.lengthOf(1)
+ expect(total).to.equal(1)
+ expect(data).to.have.lengthOf(1)
})
it('Should list remote channel videos', async function () {
- const videoChannelName = 'root_channel@localhost:' + servers[1].port
- const res = await getVideoChannelVideos(servers[0].url, userAccessToken, videoChannelName, 0, 5)
+ const handle = 'root_channel@' + servers[1].host
+ const { total, data } = await servers[0].videos.listByChannel({ token: userToken, handle })
- expect(res.body.total).to.equal(1)
- expect(res.body.data).to.have.lengthOf(1)
+ expect(total).to.equal(1)
+ expect(data).to.have.lengthOf(1)
})
})
})
before(async function () {
this.timeout(30000)
- await servers[0].followsCommand.unfollow({ target: servers[1] })
+ await servers[0].follows.unfollow({ target: servers[1] })
})
describe('With an unlogged user', function () {
it('Should get the local video', async function () {
- await getVideo(servers[0].url, video1UUID, HttpStatusCode.OK_200)
+ await servers[0].videos.get({ id: video1UUID })
})
it('Should not get the remote video', async function () {
- const res = await getVideo(servers[0].url, video2UUID, HttpStatusCode.FORBIDDEN_403)
-
- const error = res.body as PeerTubeProblemDocument
+ const body = await servers[0].videos.get({ id: video2UUID, expectedStatus: HttpStatusCode.FORBIDDEN_403 })
+ const error = body as unknown as PeerTubeProblemDocument
const doc = 'https://docs.joinpeertube.org/api-rest-reference.html#section/Errors/does_not_respect_follow_constraints'
expect(error.type).to.equal(doc)
})
it('Should list local account videos', async function () {
- const res = await getAccountVideos(servers[0].url, undefined, 'root@localhost:' + servers[0].port, 0, 5)
+ const { total, data } = await servers[0].videos.listByAccount({
+ token: null,
+ handle: 'root@' + servers[0].host
+ })
- expect(res.body.total).to.equal(1)
- expect(res.body.data).to.have.lengthOf(1)
+ expect(total).to.equal(1)
+ expect(data).to.have.lengthOf(1)
})
it('Should not list remote account videos', async function () {
- const res = await getAccountVideos(servers[0].url, undefined, 'root@localhost:' + servers[1].port, 0, 5)
+ const { total, data } = await servers[0].videos.listByAccount({
+ token: null,
+ handle: 'root@' + servers[1].host
+ })
- expect(res.body.total).to.equal(0)
- expect(res.body.data).to.have.lengthOf(0)
+ expect(total).to.equal(0)
+ expect(data).to.have.lengthOf(0)
})
it('Should list local channel videos', async function () {
- const videoChannelName = 'root_channel@localhost:' + servers[0].port
- const res = await getVideoChannelVideos(servers[0].url, undefined, videoChannelName, 0, 5)
+ const handle = 'root_channel@' + servers[0].host
+ const { total, data } = await servers[0].videos.listByChannel({ token: null, handle })
- expect(res.body.total).to.equal(1)
- expect(res.body.data).to.have.lengthOf(1)
+ expect(total).to.equal(1)
+ expect(data).to.have.lengthOf(1)
})
it('Should not list remote channel videos', async function () {
- const videoChannelName = 'root_channel@localhost:' + servers[1].port
- const res = await getVideoChannelVideos(servers[0].url, undefined, videoChannelName, 0, 5)
+ const handle = 'root_channel@' + servers[1].host
+ const { total, data } = await servers[0].videos.listByChannel({ token: null, handle })
- expect(res.body.total).to.equal(0)
- expect(res.body.data).to.have.lengthOf(0)
+ expect(total).to.equal(0)
+ expect(data).to.have.lengthOf(0)
})
})
describe('With a logged user', function () {
+
it('Should get the local video', async function () {
- await getVideoWithToken(servers[0].url, userAccessToken, video1UUID, HttpStatusCode.OK_200)
+ await servers[0].videos.getWithToken({ token: userToken, id: video1UUID })
})
it('Should get the remote video', async function () {
- await getVideoWithToken(servers[0].url, userAccessToken, video2UUID, HttpStatusCode.OK_200)
+ await servers[0].videos.getWithToken({ token: userToken, id: video2UUID })
})
it('Should list local account videos', async function () {
- const res = await getAccountVideos(servers[0].url, userAccessToken, 'root@localhost:' + servers[0].port, 0, 5)
+ const { total, data } = await servers[0].videos.listByAccount({ token: userToken, handle: 'root@' + servers[0].host })
- expect(res.body.total).to.equal(1)
- expect(res.body.data).to.have.lengthOf(1)
+ expect(total).to.equal(1)
+ expect(data).to.have.lengthOf(1)
})
it('Should list remote account videos', async function () {
- const res = await getAccountVideos(servers[0].url, userAccessToken, 'root@localhost:' + servers[1].port, 0, 5)
+ const { total, data } = await servers[0].videos.listByAccount({ token: userToken, handle: 'root@' + servers[1].host })
- expect(res.body.total).to.equal(1)
- expect(res.body.data).to.have.lengthOf(1)
+ expect(total).to.equal(1)
+ expect(data).to.have.lengthOf(1)
})
it('Should list local channel videos', async function () {
- const videoChannelName = 'root_channel@localhost:' + servers[0].port
- const res = await getVideoChannelVideos(servers[0].url, userAccessToken, videoChannelName, 0, 5)
+ const handle = 'root_channel@' + servers[0].host
+ const { total, data } = await servers[0].videos.listByChannel({ token: userToken, handle })
- expect(res.body.total).to.equal(1)
- expect(res.body.data).to.have.lengthOf(1)
+ expect(total).to.equal(1)
+ expect(data).to.have.lengthOf(1)
})
it('Should list remote channel videos', async function () {
- const videoChannelName = 'root_channel@localhost:' + servers[1].port
- const res = await getVideoChannelVideos(servers[0].url, userAccessToken, videoChannelName, 0, 5)
+ const handle = 'root_channel@' + servers[1].host
+ const { total, data } = await servers[0].videos.listByChannel({ token: userToken, handle })
- expect(res.body.total).to.equal(1)
- expect(res.body.data).to.have.lengthOf(1)
+ expect(total).to.equal(1)
+ expect(data).to.have.lengthOf(1)
})
})
})
+ describe('When following a remote account', function () {
+
+ before(async function () {
+ this.timeout(60000)
+
+ await servers[0].follows.follow({ handles: [ 'root@' + servers[1].host ] })
+ await waitJobs(servers)
+ })
+
+ it('Should get the remote video with an unlogged user', async function () {
+ await servers[0].videos.get({ id: video2UUID })
+ })
+
+ it('Should get the remote video with a logged in user', async function () {
+ await servers[0].videos.getWithToken({ token: userToken, id: video2UUID })
+ })
+ })
+
+ describe('When unfollowing a remote account', function () {
+
+ before(async function () {
+ this.timeout(60000)
+
+ await servers[0].follows.unfollow({ target: 'root@' + servers[1].host })
+ await waitJobs(servers)
+ })
+
+ it('Should not get the remote video with an unlogged user', async function () {
+ const body = await servers[0].videos.get({ id: video2UUID, expectedStatus: HttpStatusCode.FORBIDDEN_403 })
+
+ const error = body as unknown as PeerTubeProblemDocument
+ expect(error.code).to.equal(ServerErrorCode.DOES_NOT_RESPECT_FOLLOW_CONSTRAINTS)
+ })
+
+ it('Should get the remote video with a logged in user', async function () {
+ await servers[0].videos.getWithToken({ token: userToken, id: video2UUID })
+ })
+ })
+
+ describe('When following a remote channel', function () {
+
+ before(async function () {
+ this.timeout(60000)
+
+ await servers[0].follows.follow({ handles: [ 'root_channel@' + servers[1].host ] })
+ await waitJobs(servers)
+ })
+
+ it('Should get the remote video with an unlogged user', async function () {
+ await servers[0].videos.get({ id: video2UUID })
+ })
+
+ it('Should get the remote video with a logged in user', async function () {
+ await servers[0].videos.getWithToken({ token: userToken, id: video2UUID })
+ })
+ })
+
+ describe('When unfollowing a remote channel', function () {
+
+ before(async function () {
+ this.timeout(60000)
+
+ await servers[0].follows.unfollow({ target: 'root_channel@' + servers[1].host })
+ await waitJobs(servers)
+ })
+
+ it('Should not get the remote video with an unlogged user', async function () {
+ const body = await servers[0].videos.get({ id: video2UUID, expectedStatus: HttpStatusCode.FORBIDDEN_403 })
+
+ const error = body as unknown as PeerTubeProblemDocument
+ expect(error.code).to.equal(ServerErrorCode.DOES_NOT_RESPECT_FOLLOW_CONSTRAINTS)
+ })
+
+ it('Should get the remote video with a logged in user', async function () {
+ await servers[0].videos.getWithToken({ token: userToken, id: video2UUID })
+ })
+ })
+
after(async function () {
await cleanupTests(servers)
})