X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=server%2Ftests%2Fcli%2Fupdate-host.ts;h=2070f16f57176c456a6f8f9ec2ed103bc226b986;hb=f6d6e7f861189a4446f406efb775a29688764b48;hp=d0c6d2042839ecd2ca3e2edb6e0f049a968b1e70;hpb=3cd0734fd9b0ff21aaef02317a874e8f1c06e027;p=github%2FChocobozzz%2FPeerTube.git diff --git a/server/tests/cli/update-host.ts b/server/tests/cli/update-host.ts index d0c6d2042..2070f16f5 100644 --- a/server/tests/cli/update-host.ts +++ b/server/tests/cli/update-host.ts @@ -1,22 +1,28 @@ -/* tslint:disable:no-unused-expression */ +/* eslint-disable @typescript-eslint/no-unused-expressions,@typescript-eslint/require-await */ import 'mocha' import * as chai from 'chai' import { VideoDetails } from '../../../shared/models/videos' +import { waitJobs } from '../../../shared/extra-utils/server/jobs' +import { addVideoCommentThread } from '../../../shared/extra-utils/videos/video-comments' import { + addVideoChannel, + cleanupTests, + createUser, execCLI, - flushTests, + flushAndRunServer, getEnvCli, getVideo, + getVideoChannelsList, getVideosList, killallServers, - parseTorrentVideo, - runServer, + makeActivityPubGetRequest, + parseTorrentVideo, reRunServer, ServerInfo, setAccessTokensToServers, uploadVideo -} from '../utils' -import { waitJobs } from '../utils/server/jobs' +} from '../../../shared/extra-utils' +import { getAccountsList } from '../../../shared/extra-utils/users/accounts' const expect = chai.expect @@ -26,34 +32,93 @@ describe('Test update host scripts', function () { before(async function () { this.timeout(60000) - await flushTests() - const overrideConfig = { webserver: { port: 9256 } } // Run server 2 to have transcoding enabled - server = await runServer(2, overrideConfig) + server = await flushAndRunServer(2, overrideConfig) await setAccessTokensToServers([ server ]) // Upload two videos for our needs const videoAttributes = {} - await uploadVideo(server.url, server.accessToken, videoAttributes) + const resVideo1 = await uploadVideo(server.url, server.accessToken, videoAttributes) + const video1UUID = resVideo1.body.video.uuid await uploadVideo(server.url, server.accessToken, videoAttributes) + // Create a user + await createUser({ url: server.url, accessToken: server.accessToken, username: 'toto', password: 'coucou' }) + + // Create channel + const videoChannel = { + name: 'second_channel', + displayName: 'second video channel', + description: 'super video channel description' + } + await addVideoChannel(server.url, server.accessToken, videoChannel) + + // Create comments + const text = 'my super first comment' + await addVideoCommentThread(server.url, server.accessToken, video1UUID, text) + await waitJobs(server) }) - it('Should update torrent hosts', async function () { + it('Should run update host', async function () { this.timeout(30000) killallServers([ server ]) // Run server with standard configuration - server = await runServer(2) + await reRunServer(server) const env = getEnvCli(server) await execCLI(`${env} npm run update-host`) + }) + + it('Should have updated videos url', async function () { + const res = await getVideosList(server.url) + expect(res.body.total).to.equal(2) + + for (const video of res.body.data) { + const { body } = await makeActivityPubGetRequest(server.url, '/videos/watch/' + video.uuid) + + expect(body.id).to.equal('http://localhost:9002/videos/watch/' + video.uuid) + + const res = await getVideo(server.url, video.uuid) + const videoDetails: VideoDetails = res.body + + expect(videoDetails.trackerUrls[0]).to.include(server.host) + expect(videoDetails.streamingPlaylists[0].playlistUrl).to.include(server.host) + expect(videoDetails.streamingPlaylists[0].segmentsSha256Url).to.include(server.host) + } + }) + + it('Should have updated video channels url', async function () { + const res = await getVideoChannelsList(server.url, 0, 5, '-name') + expect(res.body.total).to.equal(3) + + for (const channel of res.body.data) { + const { body } = await makeActivityPubGetRequest(server.url, '/video-channels/' + channel.name) + + expect(body.id).to.equal('http://localhost:9002/video-channels/' + channel.name) + } + }) + + it('Should have updated accounts url', async function () { + const res = await getAccountsList(server.url) + expect(res.body.total).to.equal(3) + + for (const account of res.body.data) { + const usernameWithDomain = account.name + const { body } = await makeActivityPubGetRequest(server.url, '/accounts/' + usernameWithDomain) + + expect(body.id).to.equal('http://localhost:9002/accounts/' + usernameWithDomain) + } + }) + + it('Should have updated torrent hosts', async function () { + this.timeout(30000) const res = await getVideosList(server.url) const videos = res.body.data @@ -82,6 +147,6 @@ describe('Test update host scripts', function () { }) after(async function () { - killallServers([ server ]) + await cleanupTests([ server ]) }) })