+ 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
+ })
+
+ 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`)
+ })
+
+ it('Should remember the user', async function () {
+ this.timeout(60000)
+
+ const stdout = await cliCommand.execWithEnv(`${cmd} auth list`)
+ expect(stdout).to.contain(server.url)
+ })
+ })
+
+ 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 ${FIXTURE_URLS.youtube} --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
+ })
+
+ it('Should not import again the same video', async function () {
+ if (areHttpImportTestsDisabled()) return
+
+ this.timeout(60000)
+
+ const params = `--target-url ${FIXTURE_URLS.youtube} --channel-name user_channel`
+ await cliCommand.execWithEnv(`${cmd} import ${params}`)
+
+ await waitJobs([ server ])
+
+ const { total, data } = await server.videos.list()
+ expect(total).to.equal(2)
+
+ const videos = data.filter(v => v.name === 'small video - youtube')
+ expect(videos).to.have.lengthOf(1)
+
+ // So we can reimport it
+ await server.videos.remove({ token: userAccessToken, id: videos[0].id })
+ })
+
+ it('Should import and override some imported attributes', async function () {
+ if (areHttpImportTestsDisabled()) return
+
+ this.timeout(60000)
+
+ const params = `--target-url ${FIXTURE_URLS.youtube} ` +
+ `--channel-name user_channel --video-name toto --nsfw --support support`
+ await cliCommand.execWithEnv(`${cmd} import ${params}`)
+
+ await waitJobs([ server ])
+
+ {
+ 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}`)
+ })