-/* tslint:disable:no-unused-expression */
+/* eslint-disable @typescript-eslint/no-unused-expressions,@typescript-eslint/require-await */
-import * as chai from 'chai'
import 'mocha'
+import * as chai from 'chai'
+import { VideoPlaylistPrivacy } from '@shared/models'
+import { HttpStatusCode } from '../../../../shared/core-utils/miscs/http-error-codes'
import {
+ cleanupTests,
doubleFollow,
flushAndRunMultipleServers,
- flushTests,
- killallServers,
makeActivityPubGetRequest,
- runServer,
ServerInfo,
- setAccessTokensToServers, uploadVideo
-} from '../../utils'
+ setAccessTokensToServers,
+ setDefaultVideoChannel,
+ uploadVideoAndGetId
+} from '../../../../shared/extra-utils'
const expect = chai.expect
describe('Test activitypub', function () {
let servers: ServerInfo[] = []
- let videoUUID: string
+ let video: { id: number, uuid: string, shortUUID: string }
+ let playlist: { id: number, uuid: string, shortUUID: string }
+
+ async function testAccount (path: string) {
+ const res = await makeActivityPubGetRequest(servers[0].url, path)
+ const object = res.body
+
+ expect(object.type).to.equal('Person')
+ expect(object.id).to.equal('http://localhost:' + servers[0].port + '/accounts/root')
+ expect(object.name).to.equal('root')
+ expect(object.preferredUsername).to.equal('root')
+ }
+
+ async function testChannel (path: string) {
+ const res = await makeActivityPubGetRequest(servers[0].url, path)
+ const object = res.body
+
+ expect(object.type).to.equal('Group')
+ expect(object.id).to.equal('http://localhost:' + servers[0].port + '/video-channels/root_channel')
+ expect(object.name).to.equal('Main root channel')
+ expect(object.preferredUsername).to.equal('root_channel')
+ }
+
+ async function testVideo (path: string) {
+ const res = await makeActivityPubGetRequest(servers[0].url, path)
+ const object = res.body
+
+ expect(object.type).to.equal('Video')
+ expect(object.id).to.equal('http://localhost:' + servers[0].port + '/videos/watch/' + video.uuid)
+ expect(object.name).to.equal('video')
+ }
+
+ async function testPlaylist (path: string) {
+ const res = await makeActivityPubGetRequest(servers[0].url, path)
+ const object = res.body
+
+ expect(object.type).to.equal('Playlist')
+ expect(object.id).to.equal('http://localhost:' + servers[0].port + '/video-playlists/' + playlist.uuid)
+ expect(object.name).to.equal('playlist')
+ }
before(async function () {
this.timeout(30000)
- await flushTests()
-
servers = await flushAndRunMultipleServers(2)
await setAccessTokensToServers(servers)
+ await setDefaultVideoChannel(servers)
{
- const res = await uploadVideo(servers[0].url, servers[0].accessToken, { name: 'video' })
- videoUUID = res.body.video.uuid
+ video = await uploadVideoAndGetId({ server: servers[0], videoName: 'video' })
+ }
+
+ {
+ const attributes = { displayName: 'playlist', privacy: VideoPlaylistPrivacy.PUBLIC, videoChannelId: servers[0].videoChannel.id }
+ playlist = await servers[0].playlistsCommand.create({ attributes })
}
await doubleFollow(servers[0], servers[1])
})
it('Should return the account object', async function () {
- const res = await makeActivityPubGetRequest(servers[0].url, '/accounts/root')
- const object = res.body
+ await testAccount('/accounts/root')
+ await testAccount('/a/root')
+ })
- expect(object.type).to.equal('Person')
- expect(object.id).to.equal('http://localhost:9001/accounts/root')
- expect(object.name).to.equal('root')
- expect(object.preferredUsername).to.equal('root')
+ it('Should return the channel object', async function () {
+ await testChannel('/video-channels/root_channel')
+ await testChannel('/c/root_channel')
})
it('Should return the video object', async function () {
- const res = await makeActivityPubGetRequest(servers[0].url, '/videos/watch/' + videoUUID)
- const object = res.body
+ await testVideo('/videos/watch/' + video.id)
+ await testVideo('/videos/watch/' + video.uuid)
+ await testVideo('/videos/watch/' + video.shortUUID)
+ await testVideo('/w/' + video.id)
+ await testVideo('/w/' + video.uuid)
+ await testVideo('/w/' + video.shortUUID)
+ })
- expect(object.type).to.equal('Video')
- expect(object.id).to.equal('http://localhost:9001/videos/watch/' + videoUUID)
- expect(object.name).to.equal('video')
+ it('Should return the playlist object', async function () {
+ await testPlaylist('/video-playlists/' + playlist.id)
+ await testPlaylist('/video-playlists/' + playlist.uuid)
+ await testPlaylist('/video-playlists/' + playlist.shortUUID)
+ await testPlaylist('/w/p/' + playlist.id)
+ await testPlaylist('/w/p/' + playlist.uuid)
+ await testPlaylist('/w/p/' + playlist.shortUUID)
+ await testPlaylist('/videos/watch/playlist/' + playlist.id)
+ await testPlaylist('/videos/watch/playlist/' + playlist.uuid)
+ await testPlaylist('/videos/watch/playlist/' + playlist.shortUUID)
})
it('Should redirect to the origin video object', async function () {
- const res = await makeActivityPubGetRequest(servers[1].url, '/videos/watch/' + videoUUID, 302)
+ const res = await makeActivityPubGetRequest(servers[1].url, '/videos/watch/' + video.uuid, HttpStatusCode.FOUND_302)
- expect(res.header.location).to.equal('http://localhost:9001/videos/watch/' + videoUUID)
+ expect(res.header.location).to.equal('http://localhost:' + servers[0].port + '/videos/watch/' + video.uuid)
})
after(async function () {
- killallServers(servers)
+ await cleanupTests(servers)
})
})