mirror of https://github.com/Chocobozzz/PeerTube
Add AP fetch tests
parent
e5cb43e071
commit
a130f33c9c
|
@ -0,0 +1,86 @@
|
||||||
|
/* tslint:disable:no-unused-expression */
|
||||||
|
|
||||||
|
import 'mocha'
|
||||||
|
|
||||||
|
import {
|
||||||
|
createUser,
|
||||||
|
doubleFollow,
|
||||||
|
flushAndRunMultipleServers,
|
||||||
|
flushTests,
|
||||||
|
getVideosListSort,
|
||||||
|
killallServers,
|
||||||
|
ServerInfo,
|
||||||
|
setAccessTokensToServers,
|
||||||
|
uploadVideo,
|
||||||
|
userLogin
|
||||||
|
} from '../../utils'
|
||||||
|
import * as chai from 'chai'
|
||||||
|
import { setActorField, setVideoField } from '../../utils/miscs/sql'
|
||||||
|
import { waitJobs } from '../../utils/server/jobs'
|
||||||
|
import { Video } from '../../../../shared/models/videos'
|
||||||
|
|
||||||
|
const expect = chai.expect
|
||||||
|
|
||||||
|
describe('Test ActivityPub fetcher', function () {
|
||||||
|
let servers: ServerInfo[]
|
||||||
|
|
||||||
|
// ---------------------------------------------------------------
|
||||||
|
|
||||||
|
before(async function () {
|
||||||
|
this.timeout(60000)
|
||||||
|
|
||||||
|
servers = await flushAndRunMultipleServers(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)
|
||||||
|
}
|
||||||
|
|
||||||
|
const userAccessToken = await userLogin(servers[0], 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' })
|
||||||
|
|
||||||
|
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)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('Should add only the video with a valid actor URL', async function () {
|
||||||
|
this.timeout(60000)
|
||||||
|
|
||||||
|
await doubleFollow(servers[0], servers[1])
|
||||||
|
await waitJobs(servers)
|
||||||
|
|
||||||
|
{
|
||||||
|
const res = await getVideosListSort(servers[0].url, 'createdAt')
|
||||||
|
expect(res.body.total).to.equal(3)
|
||||||
|
|
||||||
|
const data: Video[] = res.body.data
|
||||||
|
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 data: Video[] = res.body.data
|
||||||
|
expect(data[0].name).to.equal('video root')
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
after(async function () {
|
||||||
|
killallServers(servers)
|
||||||
|
|
||||||
|
// Keep the logs if the test failed
|
||||||
|
if (this['ok']) {
|
||||||
|
await flushTests()
|
||||||
|
}
|
||||||
|
})
|
||||||
|
})
|
|
@ -1,3 +1,4 @@
|
||||||
import './client'
|
import './client'
|
||||||
|
import './fetch'
|
||||||
import './helpers'
|
import './helpers'
|
||||||
import './security'
|
import './security'
|
||||||
|
|
|
@ -24,6 +24,15 @@ function setActorField (serverNumber: number, to: string, field: string, value:
|
||||||
return seq.query(`UPDATE actor SET "${field}" = '${value}' WHERE url = '${to}'`, options)
|
return seq.query(`UPDATE actor SET "${field}" = '${value}' WHERE url = '${to}'`, options)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function setVideoField (serverNumber: number, uuid: string, field: string, value: string) {
|
||||||
|
const seq = getSequelize(serverNumber)
|
||||||
|
|
||||||
|
const options = { type: Sequelize.QueryTypes.UPDATE }
|
||||||
|
|
||||||
|
return seq.query(`UPDATE video SET "${field}" = '${value}' WHERE uuid = '${uuid}'`, options)
|
||||||
|
}
|
||||||
|
|
||||||
export {
|
export {
|
||||||
|
setVideoField,
|
||||||
setActorField
|
setActorField
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue