123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603 |
- /* eslint-disable @typescript-eslint/no-unused-expressions,@typescript-eslint/require-await */
- import { expect } from 'chai'
- import { VideoPrivacy } from '@shared/models'
- import {
- cleanupTests,
- createMultipleServers,
- doubleFollow,
- PeerTubeServer,
- setAccessTokensToServers,
- setDefaultAccountAvatar,
- setDefaultChannelAvatar,
- SubscriptionsCommand,
- waitJobs
- } from '@shared/server-commands'
- describe('Test users subscriptions', function () {
- let servers: PeerTubeServer[] = []
- const users: { accessToken: string }[] = []
- let video3UUID: string
- let command: SubscriptionsCommand
- before(async function () {
- this.timeout(240000)
- servers = await createMultipleServers(3)
- // Get the access tokens
- await setAccessTokensToServers(servers)
- await setDefaultChannelAvatar(servers)
- await setDefaultAccountAvatar(servers)
- // Server 1 and server 2 follow each other
- await doubleFollow(servers[0], servers[1])
- for (const server of servers) {
- const user = { username: 'user' + server.serverNumber, password: 'password' }
- await server.users.create({ username: user.username, password: user.password })
- const accessToken = await server.login.getAccessToken(user)
- users.push({ accessToken })
- const videoName1 = 'video 1-' + server.serverNumber
- await server.videos.upload({ token: accessToken, attributes: { name: videoName1 } })
- const videoName2 = 'video 2-' + server.serverNumber
- await server.videos.upload({ token: accessToken, attributes: { name: videoName2 } })
- }
- await waitJobs(servers)
- command = servers[0].subscriptions
- })
- describe('Destinction between server videos and user videos', function () {
- it('Should display videos of server 2 on server 1', async function () {
- const { total } = await servers[0].videos.list()
- expect(total).to.equal(4)
- })
- it('User of server 1 should follow user of server 3 and root of server 1', async function () {
- this.timeout(60000)
- await command.add({ token: users[0].accessToken, targetUri: 'user3_channel@localhost:' + servers[2].port })
- await command.add({ token: users[0].accessToken, targetUri: 'root_channel@localhost:' + servers[0].port })
- await waitJobs(servers)
- const attributes = { name: 'video server 3 added after follow' }
- const { uuid } = await servers[2].videos.upload({ token: users[2].accessToken, attributes })
- video3UUID = uuid
- await waitJobs(servers)
- })
- it('Should not display videos of server 3 on server 1', async function () {
- const { total, data } = await servers[0].videos.list()
- expect(total).to.equal(4)
- for (const video of data) {
- expect(video.name).to.not.contain('1-3')
- expect(video.name).to.not.contain('2-3')
- expect(video.name).to.not.contain('video server 3 added after follow')
- }
- })
- })
- describe('Subscription endpoints', function () {
- it('Should list subscriptions', async function () {
- {
- const body = await command.list()
- expect(body.total).to.equal(0)
- expect(body.data).to.be.an('array')
- expect(body.data).to.have.lengthOf(0)
- }
- {
- const body = await command.list({ token: users[0].accessToken, sort: 'createdAt' })
- expect(body.total).to.equal(2)
- const subscriptions = body.data
- expect(subscriptions).to.be.an('array')
- expect(subscriptions).to.have.lengthOf(2)
- expect(subscriptions[0].name).to.equal('user3_channel')
- expect(subscriptions[1].name).to.equal('root_channel')
- }
- })
- it('Should get subscription', async function () {
- {
- const videoChannel = await command.get({ token: users[0].accessToken, uri: 'user3_channel@localhost:' + servers[2].port })
- expect(videoChannel.name).to.equal('user3_channel')
- expect(videoChannel.host).to.equal('localhost:' + servers[2].port)
- expect(videoChannel.displayName).to.equal('Main user3 channel')
- expect(videoChannel.followingCount).to.equal(0)
- expect(videoChannel.followersCount).to.equal(1)
- }
- {
- const videoChannel = await command.get({ token: users[0].accessToken, uri: 'root_channel@localhost:' + servers[0].port })
- expect(videoChannel.name).to.equal('root_channel')
- expect(videoChannel.host).to.equal('localhost:' + servers[0].port)
- expect(videoChannel.displayName).to.equal('Main root channel')
- expect(videoChannel.followingCount).to.equal(0)
- expect(videoChannel.followersCount).to.equal(1)
- }
- })
- it('Should return the existing subscriptions', async function () {
- const uris = [
- 'user3_channel@localhost:' + servers[2].port,
- 'root2_channel@localhost:' + servers[0].port,
- 'root_channel@localhost:' + servers[0].port,
- 'user3_channel@localhost:' + servers[0].port
- ]
- const body = await command.exist({ token: users[0].accessToken, uris })
- expect(body['user3_channel@localhost:' + servers[2].port]).to.be.true
- expect(body['root2_channel@localhost:' + servers[0].port]).to.be.false
- expect(body['root_channel@localhost:' + servers[0].port]).to.be.true
- expect(body['user3_channel@localhost:' + servers[0].port]).to.be.false
- })
- it('Should search among subscriptions', async function () {
- {
- const body = await command.list({ token: users[0].accessToken, sort: '-createdAt', search: 'user3_channel' })
- expect(body.total).to.equal(1)
- expect(body.data).to.have.lengthOf(1)
- }
- {
- const body = await command.list({ token: users[0].accessToken, sort: '-createdAt', search: 'toto' })
- expect(body.total).to.equal(0)
- expect(body.data).to.have.lengthOf(0)
- }
- })
- })
- describe('Subscription videos', function () {
- it('Should list subscription videos', async function () {
- {
- const body = await command.listVideos()
- expect(body.total).to.equal(0)
- expect(body.data).to.be.an('array')
- expect(body.data).to.have.lengthOf(0)
- }
- {
- const body = await command.listVideos({ token: users[0].accessToken, sort: 'createdAt' })
- expect(body.total).to.equal(3)
- const videos = body.data
- expect(videos).to.be.an('array')
- expect(videos).to.have.lengthOf(3)
- expect(videos[0].name).to.equal('video 1-3')
- expect(videos[1].name).to.equal('video 2-3')
- expect(videos[2].name).to.equal('video server 3 added after follow')
- }
- })
- it('Should upload a video by root on server 1 and see it in the subscription videos', async function () {
- this.timeout(60000)
- const videoName = 'video server 1 added after follow'
- await servers[0].videos.upload({ attributes: { name: videoName } })
- await waitJobs(servers)
- {
- const body = await command.listVideos()
- expect(body.total).to.equal(0)
- expect(body.data).to.be.an('array')
- expect(body.data).to.have.lengthOf(0)
- }
- {
- const body = await command.listVideos({ token: users[0].accessToken, sort: 'createdAt' })
- expect(body.total).to.equal(4)
- const videos = body.data
- expect(videos).to.be.an('array')
- expect(videos).to.have.lengthOf(4)
- expect(videos[0].name).to.equal('video 1-3')
- expect(videos[1].name).to.equal('video 2-3')
- expect(videos[2].name).to.equal('video server 3 added after follow')
- expect(videos[3].name).to.equal('video server 1 added after follow')
- }
- {
- const { data, total } = await servers[0].videos.list()
- expect(total).to.equal(5)
- for (const video of data) {
- expect(video.name).to.not.contain('1-3')
- expect(video.name).to.not.contain('2-3')
- expect(video.name).to.not.contain('video server 3 added after follow')
- }
- }
- })
- it('Should have server 1 following server 3 and display server 3 videos', async function () {
- this.timeout(60000)
- await servers[0].follows.follow({ hosts: [ servers[2].url ] })
- await waitJobs(servers)
- const { data, total } = await servers[0].videos.list()
- expect(total).to.equal(8)
- const names = [ '1-3', '2-3', 'video server 3 added after follow' ]
- for (const name of names) {
- const video = data.find(v => v.name.includes(name))
- expect(video).to.not.be.undefined
- }
- })
- it('Should remove follow server 1 -> server 3 and hide server 3 videos', async function () {
- this.timeout(60000)
- await servers[0].follows.unfollow({ target: servers[2] })
- await waitJobs(servers)
- const { total, data } = await servers[0].videos.list()
- expect(total).to.equal(5)
- for (const video of data) {
- expect(video.name).to.not.contain('1-3')
- expect(video.name).to.not.contain('2-3')
- expect(video.name).to.not.contain('video server 3 added after follow')
- }
- })
- it('Should still list subscription videos', async function () {
- {
- const body = await command.listVideos()
- expect(body.total).to.equal(0)
- expect(body.data).to.be.an('array')
- expect(body.data).to.have.lengthOf(0)
- }
- {
- const body = await command.listVideos({ token: users[0].accessToken, sort: 'createdAt' })
- expect(body.total).to.equal(4)
- const videos = body.data
- expect(videos).to.be.an('array')
- expect(videos).to.have.lengthOf(4)
- expect(videos[0].name).to.equal('video 1-3')
- expect(videos[1].name).to.equal('video 2-3')
- expect(videos[2].name).to.equal('video server 3 added after follow')
- expect(videos[3].name).to.equal('video server 1 added after follow')
- }
- })
- })
- describe('Existing subscription video update', function () {
- it('Should update a video of server 3 and see the updated video on server 1', async function () {
- this.timeout(30000)
- await servers[2].videos.update({ id: video3UUID, attributes: { name: 'video server 3 added after follow updated' } })
- await waitJobs(servers)
- const body = await command.listVideos({ token: users[0].accessToken, sort: 'createdAt' })
- expect(body.data[2].name).to.equal('video server 3 added after follow updated')
- })
- })
- describe('Subscription removal', function () {
- it('Should remove user of server 3 subscription', async function () {
- this.timeout(30000)
- await command.remove({ token: users[0].accessToken, uri: 'user3_channel@localhost:' + servers[2].port })
- await waitJobs(servers)
- })
- it('Should not display its videos anymore', async function () {
- const body = await command.listVideos({ token: users[0].accessToken, sort: 'createdAt' })
- expect(body.total).to.equal(1)
- const videos = body.data
- expect(videos).to.be.an('array')
- expect(videos).to.have.lengthOf(1)
- expect(videos[0].name).to.equal('video server 1 added after follow')
- })
- it('Should remove the root subscription and not display the videos anymore', async function () {
- this.timeout(30000)
- await command.remove({ token: users[0].accessToken, uri: 'root_channel@localhost:' + servers[0].port })
- await waitJobs(servers)
- {
- const body = await command.list({ token: users[0].accessToken, sort: 'createdAt' })
- expect(body.total).to.equal(0)
- const videos = body.data
- expect(videos).to.be.an('array')
- expect(videos).to.have.lengthOf(0)
- }
- })
- it('Should correctly display public videos on server 1', async function () {
- const { total, data } = await servers[0].videos.list()
- expect(total).to.equal(5)
- for (const video of data) {
- expect(video.name).to.not.contain('1-3')
- expect(video.name).to.not.contain('2-3')
- expect(video.name).to.not.contain('video server 3 added after follow updated')
- }
- })
- })
- describe('Re-follow', function () {
- it('Should follow user of server 3 again', async function () {
- this.timeout(60000)
- await command.add({ token: users[0].accessToken, targetUri: 'user3_channel@localhost:' + servers[2].port })
- await waitJobs(servers)
- {
- const body = await command.listVideos({ token: users[0].accessToken, sort: 'createdAt' })
- expect(body.total).to.equal(3)
- const videos = body.data
- expect(videos).to.be.an('array')
- expect(videos).to.have.lengthOf(3)
- expect(videos[0].name).to.equal('video 1-3')
- expect(videos[1].name).to.equal('video 2-3')
- expect(videos[2].name).to.equal('video server 3 added after follow updated')
- }
- {
- const { total, data } = await servers[0].videos.list()
- expect(total).to.equal(5)
- for (const video of data) {
- expect(video.name).to.not.contain('1-3')
- expect(video.name).to.not.contain('2-3')
- expect(video.name).to.not.contain('video server 3 added after follow updated')
- }
- }
- })
- it('Should follow user channels of server 3 by root of server 3', async function () {
- this.timeout(60000)
- await servers[2].channels.create({ token: users[2].accessToken, attributes: { name: 'user3_channel2' } })
- await servers[2].subscriptions.add({ token: servers[2].accessToken, targetUri: 'user3_channel@localhost:' + servers[2].port })
- await servers[2].subscriptions.add({ token: servers[2].accessToken, targetUri: 'user3_channel2@localhost:' + servers[2].port })
- await waitJobs(servers)
- })
- })
- describe('Followers listing', function () {
- it('Should list user 3 followers', async function () {
- {
- const { total, data } = await servers[2].accounts.listFollowers({
- token: users[2].accessToken,
- accountName: 'user3',
- start: 0,
- count: 5,
- sort: 'createdAt'
- })
- expect(total).to.equal(3)
- expect(data).to.have.lengthOf(3)
- expect(data[0].following.host).to.equal(servers[2].host)
- expect(data[0].following.name).to.equal('user3_channel')
- expect(data[0].follower.host).to.equal(servers[0].host)
- expect(data[0].follower.name).to.equal('user1')
- expect(data[1].following.host).to.equal(servers[2].host)
- expect(data[1].following.name).to.equal('user3_channel')
- expect(data[1].follower.host).to.equal(servers[2].host)
- expect(data[1].follower.name).to.equal('root')
- expect(data[2].following.host).to.equal(servers[2].host)
- expect(data[2].following.name).to.equal('user3_channel2')
- expect(data[2].follower.host).to.equal(servers[2].host)
- expect(data[2].follower.name).to.equal('root')
- }
- {
- const { total, data } = await servers[2].accounts.listFollowers({
- token: users[2].accessToken,
- accountName: 'user3',
- start: 0,
- count: 1,
- sort: '-createdAt'
- })
- expect(total).to.equal(3)
- expect(data).to.have.lengthOf(1)
- expect(data[0].following.host).to.equal(servers[2].host)
- expect(data[0].following.name).to.equal('user3_channel2')
- expect(data[0].follower.host).to.equal(servers[2].host)
- expect(data[0].follower.name).to.equal('root')
- }
- {
- const { total, data } = await servers[2].accounts.listFollowers({
- token: users[2].accessToken,
- accountName: 'user3',
- start: 1,
- count: 1,
- sort: '-createdAt'
- })
- expect(total).to.equal(3)
- expect(data).to.have.lengthOf(1)
- expect(data[0].following.host).to.equal(servers[2].host)
- expect(data[0].following.name).to.equal('user3_channel')
- expect(data[0].follower.host).to.equal(servers[2].host)
- expect(data[0].follower.name).to.equal('root')
- }
- {
- const { total, data } = await servers[2].accounts.listFollowers({
- token: users[2].accessToken,
- accountName: 'user3',
- search: 'user1',
- sort: '-createdAt'
- })
- expect(total).to.equal(1)
- expect(data).to.have.lengthOf(1)
- expect(data[0].following.host).to.equal(servers[2].host)
- expect(data[0].following.name).to.equal('user3_channel')
- expect(data[0].follower.host).to.equal(servers[0].host)
- expect(data[0].follower.name).to.equal('user1')
- }
- })
- it('Should list user3_channel followers', async function () {
- {
- const { total, data } = await servers[2].channels.listFollowers({
- token: users[2].accessToken,
- channelName: 'user3_channel',
- start: 0,
- count: 5,
- sort: 'createdAt'
- })
- expect(total).to.equal(2)
- expect(data).to.have.lengthOf(2)
- expect(data[0].following.host).to.equal(servers[2].host)
- expect(data[0].following.name).to.equal('user3_channel')
- expect(data[0].follower.host).to.equal(servers[0].host)
- expect(data[0].follower.name).to.equal('user1')
- expect(data[1].following.host).to.equal(servers[2].host)
- expect(data[1].following.name).to.equal('user3_channel')
- expect(data[1].follower.host).to.equal(servers[2].host)
- expect(data[1].follower.name).to.equal('root')
- }
- {
- const { total, data } = await servers[2].channels.listFollowers({
- token: users[2].accessToken,
- channelName: 'user3_channel',
- start: 0,
- count: 1,
- sort: '-createdAt'
- })
- expect(total).to.equal(2)
- expect(data).to.have.lengthOf(1)
- expect(data[0].following.host).to.equal(servers[2].host)
- expect(data[0].following.name).to.equal('user3_channel')
- expect(data[0].follower.host).to.equal(servers[2].host)
- expect(data[0].follower.name).to.equal('root')
- }
- {
- const { total, data } = await servers[2].channels.listFollowers({
- token: users[2].accessToken,
- channelName: 'user3_channel',
- start: 1,
- count: 1,
- sort: '-createdAt'
- })
- expect(total).to.equal(2)
- expect(data).to.have.lengthOf(1)
- expect(data[0].following.host).to.equal(servers[2].host)
- expect(data[0].following.name).to.equal('user3_channel')
- expect(data[0].follower.host).to.equal(servers[0].host)
- expect(data[0].follower.name).to.equal('user1')
- }
- {
- const { total, data } = await servers[2].channels.listFollowers({
- token: users[2].accessToken,
- channelName: 'user3_channel',
- search: 'user1',
- sort: '-createdAt'
- })
- expect(total).to.equal(1)
- expect(data).to.have.lengthOf(1)
- expect(data[0].following.host).to.equal(servers[2].host)
- expect(data[0].following.name).to.equal('user3_channel')
- expect(data[0].follower.host).to.equal(servers[0].host)
- expect(data[0].follower.name).to.equal('user1')
- }
- })
- })
- describe('Subscription videos privacy', function () {
- it('Should update video as internal and not see from remote server', async function () {
- this.timeout(30000)
- await servers[2].videos.update({ id: video3UUID, attributes: { name: 'internal', privacy: VideoPrivacy.INTERNAL } })
- await waitJobs(servers)
- {
- const { data } = await command.listVideos({ token: users[0].accessToken })
- expect(data.find(v => v.name === 'internal')).to.not.exist
- }
- })
- it('Should see internal from local user', async function () {
- const { data } = await servers[2].subscriptions.listVideos({ token: servers[2].accessToken })
- expect(data.find(v => v.name === 'internal')).to.exist
- })
- it('Should update video as private and not see from anyone server', async function () {
- this.timeout(30000)
- await servers[2].videos.update({ id: video3UUID, attributes: { name: 'private', privacy: VideoPrivacy.PRIVATE } })
- await waitJobs(servers)
- {
- const { data } = await command.listVideos({ token: users[0].accessToken })
- expect(data.find(v => v.name === 'private')).to.not.exist
- }
- {
- const { data } = await servers[2].subscriptions.listVideos({ token: servers[2].accessToken })
- expect(data.find(v => v.name === 'private')).to.not.exist
- }
- })
- })
- after(async function () {
- await cleanupTests(servers)
- })
- })
|