2020-01-31 16:56:52 +01:00
|
|
|
/* eslint-disable @typescript-eslint/no-unused-expressions,@typescript-eslint/require-await */
|
2019-06-13 11:09:38 +02:00
|
|
|
|
2018-09-13 14:27:44 +02:00
|
|
|
import 'mocha'
|
2019-06-13 11:09:38 +02:00
|
|
|
import { expect } from 'chai'
|
2020-11-17 14:23:52 +01:00
|
|
|
import { Video, VideoDetails } from '../../../shared'
|
2018-09-13 14:27:44 +02:00
|
|
|
import {
|
2019-06-13 11:09:38 +02:00
|
|
|
addVideoChannel,
|
2020-11-17 14:23:52 +01:00
|
|
|
areHttpImportTestsDisabled,
|
2019-06-13 11:09:38 +02:00
|
|
|
buildAbsoluteFixturePath,
|
|
|
|
cleanupTests,
|
2020-01-31 16:56:52 +01:00
|
|
|
createUser,
|
|
|
|
doubleFollow,
|
2018-09-13 14:27:44 +02:00
|
|
|
execCLI,
|
2019-04-24 10:53:40 +02:00
|
|
|
flushAndRunServer,
|
2020-01-31 16:56:52 +01:00
|
|
|
getEnvCli,
|
|
|
|
getLocalIdByUUID,
|
2019-06-13 13:53:28 +02:00
|
|
|
getVideo,
|
2019-06-13 11:09:38 +02:00
|
|
|
getVideosList,
|
2020-01-31 16:56:52 +01:00
|
|
|
removeVideo,
|
2018-09-13 14:27:44 +02:00
|
|
|
ServerInfo,
|
2020-01-31 16:56:52 +01:00
|
|
|
setAccessTokensToServers,
|
2020-11-27 11:41:38 +01:00
|
|
|
testHelloWorldRegisteredSettings,
|
2020-01-31 16:56:52 +01:00
|
|
|
uploadVideoAndGetId,
|
2019-06-13 13:53:28 +02:00
|
|
|
userLogin,
|
|
|
|
waitJobs
|
2019-04-15 15:26:15 +02:00
|
|
|
} from '../../../shared/extra-utils'
|
2019-06-13 11:09:38 +02:00
|
|
|
import { getYoutubeVideoUrl } from '../../../shared/extra-utils/videos/video-imports'
|
2018-09-13 14:27:44 +02:00
|
|
|
|
|
|
|
describe('Test CLI wrapper', function () {
|
|
|
|
let server: ServerInfo
|
2019-06-13 13:53:28 +02:00
|
|
|
let userAccessToken: string
|
2019-06-13 11:09:38 +02:00
|
|
|
|
2018-09-13 14:27:44 +02:00
|
|
|
const cmd = 'node ./dist/server/tools/peertube.js'
|
|
|
|
|
|
|
|
before(async function () {
|
|
|
|
this.timeout(30000)
|
2019-06-13 11:09:38 +02:00
|
|
|
|
2019-04-24 10:53:40 +02:00
|
|
|
server = await flushAndRunServer(1)
|
2018-09-13 14:27:44 +02:00
|
|
|
await setAccessTokensToServers([ server ])
|
|
|
|
|
2019-06-13 11:09:38 +02:00
|
|
|
await createUser({ url: server.url, accessToken: server.accessToken, username: 'user_1', password: 'super_password' })
|
|
|
|
|
2019-06-13 13:53:28 +02:00
|
|
|
userAccessToken = await userLogin(server, { username: 'user_1', password: 'super_password' })
|
2019-06-13 11:09:38 +02:00
|
|
|
|
|
|
|
{
|
2019-06-13 13:53:28 +02:00
|
|
|
const args = { name: 'user_channel', displayName: 'User channel', support: 'super support text' }
|
|
|
|
await addVideoChannel(server.url, userAccessToken, args)
|
2019-06-13 11:09:38 +02:00
|
|
|
}
|
2018-09-13 14:27:44 +02:00
|
|
|
})
|
|
|
|
|
2019-07-19 10:37:35 +02:00
|
|
|
describe('Authentication and instance selection', function () {
|
2018-09-13 14:27:44 +02:00
|
|
|
|
2019-07-19 10:37:35 +02:00
|
|
|
it('Should display no selected instance', async function () {
|
|
|
|
this.timeout(60000)
|
2018-09-13 14:27:44 +02:00
|
|
|
|
2019-07-19 10:37:35 +02:00
|
|
|
const env = getEnvCli(server)
|
|
|
|
const stdout = await execCLI(`${env} ${cmd} --help`)
|
2019-06-13 11:09:38 +02:00
|
|
|
|
2019-07-19 10:37:35 +02:00
|
|
|
expect(stdout).to.contain('no instance selected')
|
|
|
|
})
|
2019-06-13 11:09:38 +02:00
|
|
|
|
2019-07-19 10:37:35 +02:00
|
|
|
it('Should add a user', async function () {
|
|
|
|
this.timeout(60000)
|
2019-06-13 11:09:38 +02:00
|
|
|
|
2019-07-19 10:37:35 +02:00
|
|
|
const env = getEnvCli(server)
|
|
|
|
await execCLI(`${env} ${cmd} auth add -u ${server.url} -U user_1 -p super_password`)
|
|
|
|
})
|
2019-06-13 11:09:38 +02:00
|
|
|
|
2019-07-19 10:37:35 +02:00
|
|
|
it('Should default to this user', async function () {
|
|
|
|
this.timeout(60000)
|
2019-06-13 11:09:38 +02:00
|
|
|
|
2019-07-19 10:37:35 +02:00
|
|
|
const env = getEnvCli(server)
|
|
|
|
const stdout = await execCLI(`${env} ${cmd} --help`)
|
2019-06-13 11:09:38 +02:00
|
|
|
|
2019-07-19 10:37:35 +02:00
|
|
|
expect(stdout).to.contain(`instance ${server.url} selected`)
|
|
|
|
})
|
2019-06-13 11:09:38 +02:00
|
|
|
|
2019-07-19 10:37:35 +02:00
|
|
|
it('Should remember the user', async function () {
|
|
|
|
this.timeout(60000)
|
2019-06-13 11:09:38 +02:00
|
|
|
|
2019-07-19 10:37:35 +02:00
|
|
|
const env = getEnvCli(server)
|
|
|
|
const stdout = await execCLI(`${env} ${cmd} auth list`)
|
|
|
|
|
|
|
|
expect(stdout).to.contain(server.url)
|
|
|
|
})
|
2019-06-13 11:09:38 +02:00
|
|
|
})
|
|
|
|
|
2019-07-19 10:37:35 +02:00
|
|
|
describe('Video upload/import', function () {
|
2019-06-13 11:09:38 +02:00
|
|
|
|
2019-07-19 10:37:35 +02:00
|
|
|
it('Should upload a video', async function () {
|
|
|
|
this.timeout(60000)
|
2019-06-13 11:09:38 +02:00
|
|
|
|
2019-07-19 10:37:35 +02:00
|
|
|
const env = getEnvCli(server)
|
2019-06-13 11:09:38 +02:00
|
|
|
|
2019-07-19 10:37:35 +02:00
|
|
|
const fixture = buildAbsoluteFixturePath('60fps_720p_small.mp4')
|
2019-06-13 11:09:38 +02:00
|
|
|
|
2019-07-19 10:37:35 +02:00
|
|
|
const params = `-f ${fixture} --video-name 'test upload' --channel-name user_channel --support 'support_text'`
|
2019-06-13 11:09:38 +02:00
|
|
|
|
2019-07-19 10:37:35 +02:00
|
|
|
await execCLI(`${env} ${cmd} upload ${params}`)
|
|
|
|
})
|
2019-06-13 11:09:38 +02:00
|
|
|
|
2019-07-19 10:37:35 +02:00
|
|
|
it('Should have the video uploaded', async function () {
|
|
|
|
const res = await getVideosList(server.url)
|
2019-06-13 11:09:38 +02:00
|
|
|
|
2019-07-19 10:37:35 +02:00
|
|
|
expect(res.body.total).to.equal(1)
|
2019-06-13 13:53:28 +02:00
|
|
|
|
2019-07-19 10:37:35 +02:00
|
|
|
const videos: Video[] = res.body.data
|
2019-06-13 13:53:28 +02:00
|
|
|
|
2020-01-31 16:56:52 +01:00
|
|
|
const video: VideoDetails = (await getVideo(server.url, videos[0].uuid)).body
|
2019-06-13 11:09:38 +02:00
|
|
|
|
2019-07-19 10:37:35 +02:00
|
|
|
expect(video.name).to.equal('test upload')
|
|
|
|
expect(video.support).to.equal('support_text')
|
|
|
|
expect(video.channel.name).to.equal('user_channel')
|
|
|
|
})
|
2019-06-13 11:09:38 +02:00
|
|
|
|
2019-07-19 10:37:35 +02:00
|
|
|
it('Should import a video', async function () {
|
2020-11-17 14:23:52 +01:00
|
|
|
if (areHttpImportTestsDisabled()) return
|
|
|
|
|
2019-07-19 10:37:35 +02:00
|
|
|
this.timeout(60000)
|
2019-06-13 11:09:38 +02:00
|
|
|
|
2019-07-19 10:37:35 +02:00
|
|
|
const env = getEnvCli(server)
|
2019-06-13 11:09:38 +02:00
|
|
|
|
2019-07-19 10:37:35 +02:00
|
|
|
const params = `--target-url ${getYoutubeVideoUrl()} --channel-name user_channel`
|
2018-09-13 14:27:44 +02:00
|
|
|
|
2019-07-19 10:37:35 +02:00
|
|
|
await execCLI(`${env} ${cmd} import ${params}`)
|
|
|
|
})
|
2018-09-13 14:27:44 +02:00
|
|
|
|
2019-07-19 10:37:35 +02:00
|
|
|
it('Should have imported the video', async function () {
|
2020-11-17 14:23:52 +01:00
|
|
|
if (areHttpImportTestsDisabled()) return
|
|
|
|
|
2019-07-19 10:37:35 +02:00
|
|
|
this.timeout(60000)
|
2019-06-13 11:09:38 +02:00
|
|
|
|
2019-07-19 10:37:35 +02:00
|
|
|
await waitJobs([ server ])
|
2019-06-13 11:09:38 +02:00
|
|
|
|
2019-07-19 10:37:35 +02:00
|
|
|
const res = await getVideosList(server.url)
|
2019-06-13 11:09:38 +02:00
|
|
|
|
2019-07-19 10:37:35 +02:00
|
|
|
expect(res.body.total).to.equal(2)
|
2019-06-13 13:53:28 +02:00
|
|
|
|
2019-07-19 10:37:35 +02:00
|
|
|
const videos: Video[] = res.body.data
|
|
|
|
const video = videos.find(v => v.name === 'small video - youtube')
|
|
|
|
expect(video).to.not.be.undefined
|
2019-06-13 13:53:28 +02:00
|
|
|
|
2019-07-19 10:37:35 +02:00
|
|
|
const videoDetails: VideoDetails = (await getVideo(server.url, video.id)).body
|
|
|
|
expect(videoDetails.channel.name).to.equal('user_channel')
|
|
|
|
expect(videoDetails.support).to.equal('super support text')
|
|
|
|
expect(videoDetails.nsfw).to.be.false
|
2019-06-13 13:53:28 +02:00
|
|
|
|
2019-07-19 10:37:35 +02:00
|
|
|
// So we can reimport it
|
|
|
|
await removeVideo(server.url, userAccessToken, video.id)
|
|
|
|
})
|
2019-06-13 13:53:28 +02:00
|
|
|
|
2019-07-19 10:37:35 +02:00
|
|
|
it('Should import and override some imported attributes', async function () {
|
2020-11-17 14:23:52 +01:00
|
|
|
if (areHttpImportTestsDisabled()) return
|
|
|
|
|
2019-07-19 10:37:35 +02:00
|
|
|
this.timeout(60000)
|
2019-06-13 13:53:28 +02:00
|
|
|
|
2019-07-19 10:37:35 +02:00
|
|
|
const env = getEnvCli(server)
|
2019-06-13 13:53:28 +02:00
|
|
|
|
2019-07-19 10:37:35 +02:00
|
|
|
const params = `--target-url ${getYoutubeVideoUrl()} --channel-name user_channel --video-name toto --nsfw --support support`
|
2019-06-13 13:53:28 +02:00
|
|
|
|
2019-07-19 10:37:35 +02:00
|
|
|
await execCLI(`${env} ${cmd} import ${params}`)
|
2019-06-13 13:53:28 +02:00
|
|
|
|
2019-07-19 10:37:35 +02:00
|
|
|
await waitJobs([ server ])
|
2019-06-13 13:53:28 +02:00
|
|
|
|
2019-07-19 10:37:35 +02:00
|
|
|
{
|
|
|
|
const res = await getVideosList(server.url)
|
|
|
|
expect(res.body.total).to.equal(2)
|
2019-06-13 13:53:28 +02:00
|
|
|
|
2019-07-19 10:37:35 +02:00
|
|
|
const videos: Video[] = res.body.data
|
|
|
|
const video = videos.find(v => v.name === 'toto')
|
|
|
|
expect(video).to.not.be.undefined
|
|
|
|
|
|
|
|
const videoDetails: VideoDetails = (await getVideo(server.url, video.id)).body
|
|
|
|
expect(videoDetails.channel.name).to.equal('user_channel')
|
|
|
|
expect(videoDetails.support).to.equal('support')
|
|
|
|
expect(videoDetails.nsfw).to.be.true
|
|
|
|
expect(videoDetails.commentsEnabled).to.be.true
|
|
|
|
}
|
|
|
|
})
|
2019-06-13 11:09:38 +02:00
|
|
|
})
|
|
|
|
|
2019-07-19 10:37:35 +02:00
|
|
|
describe('Admin auth', function () {
|
|
|
|
|
|
|
|
it('Should remove the auth user', async function () {
|
|
|
|
const env = getEnvCli(server)
|
|
|
|
|
|
|
|
await execCLI(`${env} ${cmd} auth del ${server.url}`)
|
|
|
|
|
|
|
|
const stdout = await execCLI(`${env} ${cmd} --help`)
|
|
|
|
|
|
|
|
expect(stdout).to.contain('no instance selected')
|
|
|
|
})
|
|
|
|
|
|
|
|
it('Should add the admin user', async function () {
|
|
|
|
const env = getEnvCli(server)
|
|
|
|
await execCLI(`${env} ${cmd} auth add -u ${server.url} -U root -p test${server.internalServerNumber}`)
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
describe('Manage plugins', function () {
|
|
|
|
|
|
|
|
it('Should install a plugin', async function () {
|
|
|
|
this.timeout(60000)
|
|
|
|
|
|
|
|
const env = getEnvCli(server)
|
|
|
|
await execCLI(`${env} ${cmd} plugins install --npm-name peertube-plugin-hello-world`)
|
|
|
|
})
|
|
|
|
|
2020-11-27 11:41:38 +01:00
|
|
|
it('Should have registered settings', async function () {
|
|
|
|
await testHelloWorldRegisteredSettings(server)
|
|
|
|
})
|
|
|
|
|
2019-07-19 10:37:35 +02:00
|
|
|
it('Should list installed plugins', async function () {
|
|
|
|
const env = getEnvCli(server)
|
|
|
|
const res = await execCLI(`${env} ${cmd} plugins list`)
|
2019-06-13 11:09:38 +02:00
|
|
|
|
2019-07-19 10:37:35 +02:00
|
|
|
expect(res).to.contain('peertube-plugin-hello-world')
|
|
|
|
})
|
2019-06-13 11:09:38 +02:00
|
|
|
|
2019-07-19 10:37:35 +02:00
|
|
|
it('Should uninstall the plugin', async function () {
|
|
|
|
const env = getEnvCli(server)
|
|
|
|
const res = await execCLI(`${env} ${cmd} plugins uninstall --npm-name peertube-plugin-hello-world`)
|
2019-06-13 11:09:38 +02:00
|
|
|
|
2019-07-19 10:37:35 +02:00
|
|
|
expect(res).to.not.contain('peertube-plugin-hello-world')
|
|
|
|
})
|
2018-09-13 14:27:44 +02:00
|
|
|
})
|
|
|
|
|
2020-01-28 11:07:23 +01:00
|
|
|
describe('Manage video redundancies', function () {
|
|
|
|
let anotherServer: ServerInfo
|
|
|
|
let video1Server2: number
|
|
|
|
let servers: ServerInfo[]
|
|
|
|
|
|
|
|
before(async function () {
|
|
|
|
this.timeout(120000)
|
|
|
|
|
|
|
|
anotherServer = await flushAndRunServer(2)
|
|
|
|
await setAccessTokensToServers([ anotherServer ])
|
|
|
|
|
|
|
|
await doubleFollow(server, anotherServer)
|
|
|
|
|
|
|
|
servers = [ server, anotherServer ]
|
|
|
|
await waitJobs(servers)
|
|
|
|
|
|
|
|
const uuid = (await uploadVideoAndGetId({ server: anotherServer, videoName: 'super video' })).uuid
|
|
|
|
await waitJobs(servers)
|
|
|
|
|
|
|
|
video1Server2 = await getLocalIdByUUID(server.url, uuid)
|
|
|
|
})
|
|
|
|
|
|
|
|
it('Should add a redundancy', async function () {
|
|
|
|
this.timeout(60000)
|
|
|
|
|
|
|
|
const env = getEnvCli(server)
|
|
|
|
|
|
|
|
const params = `add --video ${video1Server2}`
|
|
|
|
|
|
|
|
await execCLI(`${env} ${cmd} redundancy ${params}`)
|
|
|
|
|
|
|
|
await waitJobs(servers)
|
|
|
|
})
|
|
|
|
|
|
|
|
it('Should list redundancies', async function () {
|
|
|
|
this.timeout(60000)
|
|
|
|
|
|
|
|
{
|
|
|
|
const env = getEnvCli(server)
|
|
|
|
|
2020-01-31 16:56:52 +01:00
|
|
|
const params = 'list-my-redundancies'
|
2020-01-28 11:07:23 +01:00
|
|
|
const stdout = await execCLI(`${env} ${cmd} redundancy ${params}`)
|
|
|
|
|
|
|
|
expect(stdout).to.contain('super video')
|
|
|
|
expect(stdout).to.contain(`localhost:${server.port}`)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
it('Should remove a redundancy', async function () {
|
|
|
|
this.timeout(60000)
|
|
|
|
|
|
|
|
const env = getEnvCli(server)
|
|
|
|
|
|
|
|
const params = `remove --video ${video1Server2}`
|
|
|
|
|
|
|
|
await execCLI(`${env} ${cmd} redundancy ${params}`)
|
|
|
|
|
|
|
|
await waitJobs(servers)
|
|
|
|
|
|
|
|
{
|
|
|
|
const env = getEnvCli(server)
|
2020-01-31 16:56:52 +01:00
|
|
|
const params = 'list-my-redundancies'
|
2020-01-28 11:07:23 +01:00
|
|
|
const stdout = await execCLI(`${env} ${cmd} redundancy ${params}`)
|
|
|
|
|
|
|
|
expect(stdout).to.not.contain('super video')
|
|
|
|
}
|
|
|
|
})
|
2020-01-28 13:57:04 +01:00
|
|
|
|
|
|
|
after(async function () {
|
|
|
|
this.timeout(10000)
|
|
|
|
|
|
|
|
await cleanupTests([ anotherServer ])
|
|
|
|
})
|
2020-01-28 11:07:23 +01:00
|
|
|
})
|
|
|
|
|
2018-09-13 14:27:44 +02:00
|
|
|
after(async function () {
|
2018-11-14 15:45:50 +01:00
|
|
|
this.timeout(10000)
|
|
|
|
|
2019-04-24 15:10:37 +02:00
|
|
|
await cleanupTests([ server ])
|
2018-09-13 14:27:44 +02:00
|
|
|
})
|
|
|
|
})
|