-/* tslint:disable:no-unused-expression */
+/* eslint-disable @typescript-eslint/no-unused-expressions,@typescript-eslint/require-await */
import 'mocha'
-
-import {
- createUser,
- doubleFollow,
- flushAndRunMultipleServers,
- flushTests,
- getVideosListSort,
- killallServers,
- ServerInfo,
- setAccessTokensToServers,
- setActorField,
- setVideoField,
- uploadVideo,
- userLogin,
- waitJobs
-} from '../../../../shared/utils'
import * as chai from 'chai'
-import { Video } from '../../../../shared/models/videos'
+import { cleanupTests, createMultipleServers, doubleFollow, PeerTubeServer, setAccessTokensToServers, waitJobs } from '@shared/extra-utils'
const expect = chai.expect
describe('Test ActivityPub fetcher', function () {
- let servers: ServerInfo[]
+ let servers: PeerTubeServer[]
// ---------------------------------------------------------------
before(async function () {
this.timeout(60000)
- servers = await flushAndRunMultipleServers(3)
+ servers = await createMultipleServers(3)
// Get the access tokens
await setAccessTokensToServers(servers)
const user = { username: 'user1', password: 'password' }
for (const server of servers) {
- await createUser(server.url, server.accessToken, user.username, user.password)
+ await server.users.create({ username: user.username, password: user.password })
}
- const userAccessToken = await userLogin(servers[0], user)
+ const userAccessToken = await servers[0].login.getAccessToken(user)
+
+ await servers[0].videos.upload({ attributes: { name: 'video root' } })
+ const { uuid } = await servers[0].videos.upload({ attributes: { name: 'bad video root' } })
+ await servers[0].videos.upload({ token: userAccessToken, attributes: { name: 'video user' } })
- await uploadVideo(servers[0].url, servers[0].accessToken, { name: 'video root' })
- const res = await uploadVideo(servers[0].url, servers[0].accessToken, { name: 'bad video root' })
- const badVideoUUID = res.body.video.uuid
- await uploadVideo(servers[0].url, userAccessToken, { name: 'video user' })
+ {
+ const to = 'http://localhost:' + servers[0].port + '/accounts/user1'
+ const value = 'http://localhost:' + servers[1].port + '/accounts/user1'
+ await servers[0].sql.setActorField(to, 'url', value)
+ }
- await setActorField(1, 'http://localhost:9001/accounts/user1', 'url', 'http://localhost:9002/accounts/user1')
- await setVideoField(1, badVideoUUID, 'url', 'http://localhost:9003/videos/watch/' + badVideoUUID)
+ {
+ const value = 'http://localhost:' + servers[2].port + '/videos/watch/' + uuid
+ await servers[0].sql.setVideoField(uuid, 'url', value)
+ }
})
it('Should add only the video with a valid actor URL', async function () {
await waitJobs(servers)
{
- const res = await getVideosListSort(servers[0].url, 'createdAt')
- expect(res.body.total).to.equal(3)
+ const { total, data } = await servers[0].videos.list({ sort: 'createdAt' })
- const data: Video[] = res.body.data
+ expect(total).to.equal(3)
expect(data[0].name).to.equal('video root')
expect(data[1].name).to.equal('bad video root')
expect(data[2].name).to.equal('video user')
}
{
- const res = await getVideosListSort(servers[1].url, 'createdAt')
- expect(res.body.total).to.equal(1)
+ const { total, data } = await servers[1].videos.list({ sort: 'createdAt' })
- const data: Video[] = res.body.data
+ expect(total).to.equal(1)
expect(data[0].name).to.equal('video root')
}
})
after(async function () {
- killallServers(servers)
+ this.timeout(20000)
- // Keep the logs if the test failed
- if (this['ok']) {
- await flushTests()
- }
+ await cleanupTests(servers)
})
})