-/* tslint:disable:no-unused-expression */
+/* eslint-disable @typescript-eslint/no-unused-expressions,@typescript-eslint/require-await */
-import * as chai from 'chai'
import 'mocha'
-import { createUser, doubleFollow, flushAndRunMultipleServers, follow, getVideosList, unfollow, updateVideo, userLogin } from '../../utils'
-import { killallServers, ServerInfo, uploadVideo } from '../../utils/index'
-import { setAccessTokensToServers } from '../../utils/users/login'
-import { Video, VideoChannel } from '../../../../shared/models/videos'
-import { waitJobs } from '../../utils/server/jobs'
+import * as chai from 'chai'
import {
- addUserSubscription,
- listUserSubscriptions,
- listUserSubscriptionVideos,
- removeUserSubscription,
- getUserSubscription, areSubscriptionsExist
-} from '../../utils/users/user-subscriptions'
+ cleanupTests,
+ createUser,
+ doubleFollow,
+ flushAndRunMultipleServers,
+ getVideosList,
+ ServerInfo,
+ setAccessTokensToServers,
+ SubscriptionsCommand,
+ updateVideo,
+ uploadVideo,
+ userLogin,
+ waitJobs
+} from '@shared/extra-utils'
const expect = chai.expect
const users: { accessToken: string }[] = []
let video3UUID: string
+ let command: SubscriptionsCommand
+
before(async function () {
this.timeout(120000)
{
for (const server of servers) {
const user = { username: 'user' + server.serverNumber, password: 'password' }
- await createUser(server.url, server.accessToken, user.username, user.password)
+ await createUser({ url: server.url, accessToken: server.accessToken, username: user.username, password: user.password })
const accessToken = await userLogin(server, user)
users.push({ accessToken })
}
await waitJobs(servers)
+
+ command = servers[0].subscriptionsCommand
})
it('Should display videos of server 2 on server 1', async function () {
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:9003')
- await addUserSubscription(servers[0].url, users[0].accessToken, 'root_channel@localhost:9001')
+ 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)
it('Should list subscriptions', async function () {
{
- const res = await listUserSubscriptions(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 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 res = await listUserSubscriptions(servers[0].url, users[0].accessToken)
- expect(res.body.total).to.equal(2)
+ const body = await command.list({ token: users[0].accessToken, sort: 'createdAt' })
+ expect(body.total).to.equal(2)
- const subscriptions: VideoChannel[] = res.body.data
+ const subscriptions = body.data
expect(subscriptions).to.be.an('array')
expect(subscriptions).to.have.lengthOf(2)
it('Should get subscription', async function () {
{
- const res = await getUserSubscription(servers[ 0 ].url, users[ 0 ].accessToken, 'user3_channel@localhost:9003')
- const videoChannel: VideoChannel = res.body
+ 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:9003')
+ 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:9001')
- const videoChannel: VideoChannel = res.body
+ 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:9001')
+ 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:9003',
- 'root2_channel@localhost:9001',
- 'root_channel@localhost:9001',
- 'user3_channel@localhost:9001'
+ '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
+ 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)
+ }
- expect(body['user3_channel@localhost:9003']).to.be.true
- expect(body['root2_channel@localhost:9001']).to.be.false
- expect(body['root_channel@localhost:9001']).to.be.true
- expect(body['user3_channel@localhost:9001']).to.be.false
+ {
+ 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)
+ }
})
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 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 res = await listUserSubscriptionVideos(servers[0].url, users[0].accessToken, 'createdAt')
- expect(res.body.total).to.equal(3)
+ const body = await command.listVideos({ token: users[0].accessToken, sort: 'createdAt' })
+ expect(body.total).to.equal(3)
- const videos: Video[] = res.body.data
+ const videos = body.data
expect(videos).to.be.an('array')
expect(videos).to.have.lengthOf(3)
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 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 res = await listUserSubscriptionVideos(servers[0].url, users[0].accessToken, 'createdAt')
- expect(res.body.total).to.equal(4)
+ const body = await command.listVideos({ token: users[0].accessToken, sort: 'createdAt' })
+ expect(body.total).to.equal(4)
- const videos: Video[] = res.body.data
+ const videos = body.data
expect(videos).to.be.an('array')
expect(videos).to.have.lengthOf(4)
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 servers[0].followsCommand.follow({ targets: [ servers[2].url ] })
await waitJobs(servers)
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 servers[0].followsCommand.unfollow({ target: servers[2] })
await waitJobs(servers)
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 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 res = await listUserSubscriptionVideos(servers[0].url, users[0].accessToken, 'createdAt')
- expect(res.body.total).to.equal(4)
+ const body = await command.listVideos({ token: users[0].accessToken, sort: 'createdAt' })
+ expect(body.total).to.equal(4)
- const videos: Video[] = res.body.data
+ const videos = body.data
expect(videos).to.be.an('array')
expect(videos).to.have.lengthOf(4)
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')
+ 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')
})
it('Should remove user of server 3 subscription', async function () {
this.timeout(30000)
- await removeUserSubscription(servers[0].url, users[0].accessToken, 'user3_channel@localhost:9003')
+ 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 res = await listUserSubscriptionVideos(servers[0].url, users[0].accessToken, 'createdAt')
- expect(res.body.total).to.equal(1)
+ const body = await command.listVideos({ token: users[0].accessToken, sort: 'createdAt' })
+ expect(body.total).to.equal(1)
- const videos: Video[] = res.body.data
- expect(videos).to.be.an('array')
- expect(videos).to.have.lengthOf(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')
- }
+ 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:9001')
+ await command.remove({ token: users[0].accessToken, uri: '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 body = await command.list({ token: users[0].accessToken, sort: 'createdAt' })
+ expect(body.total).to.equal(0)
- const videos: Video[] = res.body.data
+ const videos = body.data
expect(videos).to.be.an('array')
expect(videos).to.have.lengthOf(0)
}
it('Should follow user of server 3 again', async function () {
this.timeout(60000)
- await addUserSubscription(servers[0].url, users[0].accessToken, 'user3_channel@localhost:9003')
+ await command.add({ token: users[0].accessToken, targetUri: '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 body = await command.listVideos({ token: users[0].accessToken, sort: 'createdAt' })
+ expect(body.total).to.equal(3)
- const videos: Video[] = res.body.data
+ const videos = body.data
expect(videos).to.be.an('array')
expect(videos).to.have.lengthOf(3)
})
after(async function () {
- killallServers(servers)
+ await cleanupTests(servers)
})
})