X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=server%2Ftests%2Fcli%2Fpeertube.ts;h=f19b6ae227dde4e26e9a6f5c593b2c0b420d332d;hb=254d3579f5338f5fd775c17d15cdfc37078bcfb4;hp=80bbc98d57382a0bd1b58a48a4ccc41d88663da1;hpb=97567dd81f508dd6295ac4d73d849aa2ce0a6549;p=github%2FChocobozzz%2FPeerTube.git diff --git a/server/tests/cli/peertube.ts b/server/tests/cli/peertube.ts index 80bbc98d5..f19b6ae22 100644 --- a/server/tests/cli/peertube.ts +++ b/server/tests/cli/peertube.ts @@ -1,51 +1,283 @@ +/* eslint-disable @typescript-eslint/no-unused-expressions,@typescript-eslint/require-await */ + import 'mocha' +import { expect } from 'chai' import { - expect -} from 'chai' -import { - createUser, - execCLI, - flushTests, - getEnvCli, - killallServers, - flushAndRunServer, - ServerInfo, - setAccessTokensToServers, cleanupTests + areHttpImportTestsDisabled, + buildAbsoluteFixturePath, + cleanupTests, + CLICommand, + doubleFollow, + createSingleServer, + ImportsCommand, + PeerTubeServer, + setAccessTokensToServers, + testHelloWorldRegisteredSettings, + waitJobs } from '../../../shared/extra-utils' describe('Test CLI wrapper', function () { - let server: ServerInfo + let server: PeerTubeServer + let userAccessToken: string + + let cliCommand: CLICommand + const cmd = 'node ./dist/server/tools/peertube.js' before(async function () { this.timeout(30000) - server = await flushAndRunServer(1) + + server = await createSingleServer(1) await setAccessTokensToServers([ server ]) - await createUser({ url: server.url, accessToken: server.accessToken, username: 'user_1', password: 'super password' }) + await server.users.create({ username: 'user_1', password: 'super_password' }) + + userAccessToken = await server.login.getAccessToken({ username: 'user_1', password: 'super_password' }) + + { + const attributes = { name: 'user_channel', displayName: 'User channel', support: 'super support text' } + await server.channels.create({ token: userAccessToken, attributes }) + } + + cliCommand = server.cli }) - it('Should display no selected instance', async function () { - this.timeout(60000) + describe('Authentication and instance selection', function () { + + it('Should get an access token', async function () { + const stdout = await cliCommand.execWithEnv(`${cmd} token --url ${server.url} --username user_1 --password super_password`) + const token = stdout.trim() + + const body = await server.users.getMyInfo({ token }) + expect(body.username).to.equal('user_1') + }) + + it('Should display no selected instance', async function () { + this.timeout(60000) + + const stdout = await cliCommand.execWithEnv(`${cmd} --help`) + expect(stdout).to.contain('no instance selected') + }) + + it('Should add a user', async function () { + this.timeout(60000) + + await cliCommand.execWithEnv(`${cmd} auth add -u ${server.url} -U user_1 -p super_password`) + }) + + it('Should not fail to add a user if there is a slash at the end of the instance URL', async function () { + this.timeout(60000) + + let fullServerURL = server.url + '/' + + await cliCommand.execWithEnv(`${cmd} auth add -u ${fullServerURL} -U user_1 -p super_password`) + + fullServerURL = server.url + '/asdfasdf' + await cliCommand.execWithEnv(`${cmd} auth add -u ${fullServerURL} -U user_1 -p super_password`) + }) + + it('Should default to this user', async function () { + this.timeout(60000) + + const stdout = await cliCommand.execWithEnv(`${cmd} --help`) + expect(stdout).to.contain(`instance ${server.url} selected`) + }) - const env = getEnvCli(server) - const stdout = await execCLI(`${env} ${cmd} --help`) + it('Should remember the user', async function () { + this.timeout(60000) - expect(stdout).to.contain('selected') + const stdout = await cliCommand.execWithEnv(`${cmd} auth list`) + expect(stdout).to.contain(server.url) + }) }) - it('Should remember the authentifying material of the user', async function () { - this.timeout(60000) + describe('Video upload/import', function () { + + it('Should upload a video', async function () { + this.timeout(60000) + + const fixture = buildAbsoluteFixturePath('60fps_720p_small.mp4') + const params = `-f ${fixture} --video-name 'test upload' --channel-name user_channel --support 'support_text'` + + await cliCommand.execWithEnv(`${cmd} upload ${params}`) + }) + + it('Should have the video uploaded', async function () { + const { total, data } = await server.videos.list() + expect(total).to.equal(1) + + const video = await server.videos.get({ id: data[0].uuid }) + expect(video.name).to.equal('test upload') + expect(video.support).to.equal('support_text') + expect(video.channel.name).to.equal('user_channel') + }) + + it('Should import a video', async function () { + if (areHttpImportTestsDisabled()) return + + this.timeout(60000) + + const params = `--target-url ${ImportsCommand.getYoutubeVideoUrl()} --channel-name user_channel` + await cliCommand.execWithEnv(`${cmd} import ${params}`) + }) + + it('Should have imported the video', async function () { + if (areHttpImportTestsDisabled()) return + + this.timeout(60000) + + await waitJobs([ server ]) + + const { total, data } = await server.videos.list() + expect(total).to.equal(2) + + const video = data.find(v => v.name === 'small video - youtube') + expect(video).to.not.be.undefined + + const videoDetails = await server.videos.get({ id: video.id }) + expect(videoDetails.channel.name).to.equal('user_channel') + expect(videoDetails.support).to.equal('super support text') + expect(videoDetails.nsfw).to.be.false + + // So we can reimport it + await server.videos.remove({ token: userAccessToken, id: video.id }) + }) + + it('Should import and override some imported attributes', async function () { + if (areHttpImportTestsDisabled()) return + + this.timeout(60000) + + const params = `--target-url ${ImportsCommand.getYoutubeVideoUrl()} ` + + `--channel-name user_channel --video-name toto --nsfw --support support` + await cliCommand.execWithEnv(`${cmd} import ${params}`) + + await waitJobs([ server ]) - const env = getEnvCli(server) - await execCLI(`${env} ` + cmd + ` auth add --url ${server.url} -U user_1 -p "super password"`) + { + const { total, data } = await server.videos.list() + expect(total).to.equal(2) + + const video = data.find(v => v.name === 'toto') + expect(video).to.not.be.undefined + + const videoDetails = await server.videos.get({ id: video.id }) + 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 + } + }) + }) + + describe('Admin auth', function () { + + it('Should remove the auth user', async function () { + await cliCommand.execWithEnv(`${cmd} auth del ${server.url}`) + + const stdout = await cliCommand.execWithEnv(`${cmd} --help`) + expect(stdout).to.contain('no instance selected') + }) + + it('Should add the admin user', async function () { + await cliCommand.execWithEnv(`${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) + + await cliCommand.execWithEnv(`${cmd} plugins install --npm-name peertube-plugin-hello-world`) + }) + + it('Should have registered settings', async function () { + await testHelloWorldRegisteredSettings(server) + }) + + it('Should list installed plugins', async function () { + const res = await cliCommand.execWithEnv(`${cmd} plugins list`) + + expect(res).to.contain('peertube-plugin-hello-world') + }) + + it('Should uninstall the plugin', async function () { + const res = await cliCommand.execWithEnv(`${cmd} plugins uninstall --npm-name peertube-plugin-hello-world`) + + expect(res).to.not.contain('peertube-plugin-hello-world') + }) + }) + + describe('Manage video redundancies', function () { + let anotherServer: PeerTubeServer + let video1Server2: number + let servers: PeerTubeServer[] + + before(async function () { + this.timeout(120000) + + anotherServer = await createSingleServer(2) + await setAccessTokensToServers([ anotherServer ]) + + await doubleFollow(server, anotherServer) + + servers = [ server, anotherServer ] + await waitJobs(servers) + + const { uuid } = await anotherServer.videos.quickUpload({ name: 'super video' }) + await waitJobs(servers) + + video1Server2 = await server.videos.getId({ uuid }) + }) + + it('Should add a redundancy', async function () { + this.timeout(60000) + + const params = `add --video ${video1Server2}` + await cliCommand.execWithEnv(`${cmd} redundancy ${params}`) + + await waitJobs(servers) + }) + + it('Should list redundancies', async function () { + this.timeout(60000) + + { + const params = 'list-my-redundancies' + const stdout = await cliCommand.execWithEnv(`${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 params = `remove --video ${video1Server2}` + await cliCommand.execWithEnv(`${cmd} redundancy ${params}`) + + await waitJobs(servers) + + { + const params = 'list-my-redundancies' + const stdout = await cliCommand.execWithEnv(`${cmd} redundancy ${params}`) + + expect(stdout).to.not.contain('super video') + } + }) + + after(async function () { + this.timeout(10000) + + await cleanupTests([ anotherServer ]) + }) }) after(async function () { this.timeout(10000) - await execCLI(cmd + ` auth del ${server.url}`) - await cleanupTests([ server ]) }) })