123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404 |
- /* eslint-disable @typescript-eslint/no-unused-expressions,@typescript-eslint/require-await */
- import * as chai from 'chai'
- import 'mocha'
- import {
- cleanupTests,
- createUser,
- doubleFollow,
- flushAndRunMultipleServers,
- follow,
- getVideosList,
- unfollow,
- updateVideo,
- userLogin
- } from '../../../../shared/extra-utils'
- import { ServerInfo, uploadVideo } from '../../../../shared/extra-utils/index'
- import { setAccessTokensToServers } from '../../../../shared/extra-utils/users/login'
- import { Video, VideoChannel } from '../../../../shared/models/videos'
- import { waitJobs } from '../../../../shared/extra-utils/server/jobs'
- import {
- addUserSubscription,
- areSubscriptionsExist,
- getUserSubscription,
- listUserSubscriptions,
- listUserSubscriptionVideos,
- removeUserSubscription
- } from '../../../../shared/extra-utils/users/user-subscriptions'
- const expect = chai.expect
- describe('Test users subscriptions', function () {
- let servers: ServerInfo[] = []
- const users: { accessToken: string }[] = []
- let video3UUID: string
- before(async function () {
- this.timeout(120000)
- servers = await flushAndRunMultipleServers(3)
- // Get the access tokens
- await setAccessTokensToServers(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 createUser({ url: server.url, accessToken: server.accessToken, username: user.username, password: user.password })
- const accessToken = await userLogin(server, user)
- users.push({ accessToken })
- const videoName1 = 'video 1-' + server.serverNumber
- await uploadVideo(server.url, accessToken, { name: videoName1 })
- const videoName2 = 'video 2-' + server.serverNumber
- await uploadVideo(server.url, accessToken, { name: videoName2 })
- }
- }
- await waitJobs(servers)
- })
- it('Should display videos of server 2 on server 1', async function () {
- const res = await getVideosList(servers[0].url)
- expect(res.body.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 addUserSubscription(servers[0].url, users[0].accessToken, 'user3_channel@localhost:' + servers[2].port)
- await addUserSubscription(servers[0].url, users[0].accessToken, 'root_channel@localhost:' + servers[0].port)
- await waitJobs(servers)
- const res = await uploadVideo(servers[2].url, users[2].accessToken, { name: 'video server 3 added after follow' })
- video3UUID = res.body.video.uuid
- await waitJobs(servers)
- })
- it('Should not display videos of server 3 on server 1', async function () {
- const res = await getVideosList(servers[0].url)
- expect(res.body.total).to.equal(4)
- for (const video of res.body.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 list subscriptions', async function () {
- {
- const res = await listUserSubscriptions({ url: servers[0].url, token: servers[0].accessToken })
- expect(res.body.total).to.equal(0)
- expect(res.body.data).to.be.an('array')
- expect(res.body.data).to.have.lengthOf(0)
- }
- {
- const res = await listUserSubscriptions({ url: servers[0].url, token: users[0].accessToken, sort: 'createdAt' })
- expect(res.body.total).to.equal(2)
- const subscriptions: VideoChannel[] = res.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 res = await getUserSubscription(servers[0].url, users[0].accessToken, 'user3_channel@localhost:' + servers[2].port)
- const videoChannel: VideoChannel = res.body
- 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 res = await getUserSubscription(servers[0].url, users[0].accessToken, 'root_channel@localhost:' + servers[0].port)
- const videoChannel: VideoChannel = res.body
- 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 res = await areSubscriptionsExist(servers[0].url, users[0].accessToken, uris)
- const body = res.body
- 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 res = await listUserSubscriptions({
- url: servers[0].url,
- token: users[0].accessToken,
- sort: '-createdAt',
- search: 'user3_channel'
- })
- expect(res.body.total).to.equal(1)
- const subscriptions = res.body.data
- expect(subscriptions).to.have.lengthOf(1)
- }
- {
- const res = await listUserSubscriptions({
- url: servers[0].url,
- token: users[0].accessToken,
- sort: '-createdAt',
- search: 'toto'
- })
- expect(res.body.total).to.equal(0)
- const subscriptions = res.body.data
- expect(subscriptions).to.have.lengthOf(0)
- }
- })
- it('Should list subscription videos', async function () {
- {
- const res = await listUserSubscriptionVideos(servers[0].url, servers[0].accessToken)
- expect(res.body.total).to.equal(0)
- expect(res.body.data).to.be.an('array')
- expect(res.body.data).to.have.lengthOf(0)
- }
- {
- const res = await listUserSubscriptionVideos(servers[0].url, users[0].accessToken, 'createdAt')
- expect(res.body.total).to.equal(3)
- const videos: Video[] = res.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 uploadVideo(servers[0].url, servers[0].accessToken, { name: videoName })
- await waitJobs(servers)
- {
- const res = await listUserSubscriptionVideos(servers[0].url, servers[0].accessToken)
- expect(res.body.total).to.equal(0)
- expect(res.body.data).to.be.an('array')
- expect(res.body.data).to.have.lengthOf(0)
- }
- {
- const res = await listUserSubscriptionVideos(servers[0].url, users[0].accessToken, 'createdAt')
- expect(res.body.total).to.equal(4)
- const videos: Video[] = res.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 res = await getVideosList(servers[0].url)
- expect(res.body.total).to.equal(5)
- for (const video of res.body.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 follow server 3 and display server 3 videos', async function () {
- this.timeout(60000)
- await follow(servers[0].url, [ servers[2].url ], servers[0].accessToken)
- await waitJobs(servers)
- const res = await getVideosList(servers[0].url)
- expect(res.body.total).to.equal(8)
- const names = [ '1-3', '2-3', 'video server 3 added after follow' ]
- for (const name of names) {
- const video = res.body.data.find(v => v.name.indexOf(name) === -1)
- 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 unfollow(servers[0].url, servers[0].accessToken, servers[2])
- await waitJobs(servers)
- const res = await getVideosList(servers[0].url)
- expect(res.body.total).to.equal(5)
- for (const video of res.body.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 res = await listUserSubscriptionVideos(servers[0].url, servers[0].accessToken)
- expect(res.body.total).to.equal(0)
- expect(res.body.data).to.be.an('array')
- expect(res.body.data).to.have.lengthOf(0)
- }
- {
- const res = await listUserSubscriptionVideos(servers[0].url, users[0].accessToken, 'createdAt')
- expect(res.body.total).to.equal(4)
- const videos: Video[] = res.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')
- }
- })
- it('Should update a video of server 3 and see the updated video on server 1', async function () {
- this.timeout(30000)
- await updateVideo(servers[2].url, users[2].accessToken, video3UUID, { name: 'video server 3 added after follow updated' })
- await waitJobs(servers)
- const res = await listUserSubscriptionVideos(servers[0].url, users[0].accessToken, 'createdAt')
- const videos: Video[] = res.body.data
- expect(videos[2].name).to.equal('video server 3 added after follow updated')
- })
- it('Should remove user of server 3 subscription', async function () {
- this.timeout(30000)
- await removeUserSubscription(servers[0].url, users[0].accessToken, 'user3_channel@localhost:' + servers[2].port)
- await waitJobs(servers)
- })
- it('Should not display its videos anymore', async function () {
- {
- const res = await listUserSubscriptionVideos(servers[0].url, users[0].accessToken, 'createdAt')
- expect(res.body.total).to.equal(1)
- const videos: Video[] = res.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 removeUserSubscription(servers[0].url, users[0].accessToken, 'root_channel@localhost:' + servers[0].port)
- await waitJobs(servers)
- {
- const res = await listUserSubscriptionVideos(servers[0].url, users[0].accessToken, 'createdAt')
- expect(res.body.total).to.equal(0)
- const videos: Video[] = res.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 res = await getVideosList(servers[0].url)
- expect(res.body.total).to.equal(5)
- for (const video of res.body.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 of server 3 again', async function () {
- this.timeout(60000)
- await addUserSubscription(servers[0].url, users[0].accessToken, 'user3_channel@localhost:' + servers[2].port)
- await waitJobs(servers)
- {
- const res = await listUserSubscriptionVideos(servers[0].url, users[0].accessToken, 'createdAt')
- expect(res.body.total).to.equal(3)
- const videos: Video[] = res.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 res = await getVideosList(servers[0].url)
- expect(res.body.total).to.equal(5)
- for (const video of res.body.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')
- }
- }
- })
- after(async function () {
- await cleanupTests(servers)
- })
- })
|