X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=server%2Ftests%2Fapi%2Fvideos%2Fvideo-imports.ts;h=d211859e401ca191aee42f8d1c9d7078182c22bd;hb=9a7fd9600bf513adffbf2127be7c3a8b4d31073f;hp=f21ade5c381782f8dc873f33411ae76d3f50d863;hpb=3d52b300ea79bec21f090e2447c4808307078618;p=github%2FChocobozzz%2FPeerTube.git diff --git a/server/tests/api/videos/video-imports.ts b/server/tests/api/videos/video-imports.ts index f21ade5c3..d211859e4 100644 --- a/server/tests/api/videos/video-imports.ts +++ b/server/tests/api/videos/video-imports.ts @@ -1,21 +1,25 @@ -/* tslint:disable:no-unused-expression */ +/* eslint-disable @typescript-eslint/no-unused-expressions,@typescript-eslint/require-await */ import * as chai from 'chai' import 'mocha' -import { VideoDetails, VideoPrivacy } from '../../../../shared/models/videos' +import { VideoDetails, VideoImport, VideoPrivacy, VideoCaption } from '../../../../shared/models/videos' import { + cleanupTests, doubleFollow, flushAndRunMultipleServers, getMyUserInformation, getMyVideos, getVideo, getVideosList, - killallServers, + listVideoCaptions, + testCaptionFile, + immutableAssign, ServerInfo, setAccessTokensToServers -} from '../../utils' -import { waitJobs } from '../../utils/server/jobs' -import { getMyVideoImports, getYoutubeVideoUrl, importVideo } from '../../utils/videos/video-imports' +} from '../../../../shared/extra-utils' +import { waitJobs } from '../../../../shared/extra-utils/server/jobs' +import { getMagnetURI, getMyVideoImports, getYoutubeVideoUrl, importVideo } from '../../../../shared/extra-utils/videos/video-imports' +import { testImage } from '../../../../shared/extra-utils/miscs/miscs' const expect = chai.expect @@ -24,24 +28,49 @@ describe('Test video imports', function () { let channelIdServer1: number let channelIdServer2: number - async function checkVideoServer1 (url: string, id: number | string) { - const res = await getVideo(url, id) - const video: VideoDetails = res.body + async function checkVideosServer1 (url: string, idHttp: string, idMagnet: string, idTorrent: string) { + const resHttp = await getVideo(url, idHttp) + const videoHttp: VideoDetails = resHttp.body + + expect(videoHttp.name).to.equal('small video - youtube') + expect(videoHttp.category.label).to.equal('News & Politics') + expect(videoHttp.licence.label).to.equal('Attribution') + expect(videoHttp.language.label).to.equal('Unknown') + expect(videoHttp.nsfw).to.be.false + expect(videoHttp.description).to.equal('this is a super description') + expect(videoHttp.tags).to.deep.equal([ 'tag1', 'tag2' ]) + expect(videoHttp.files).to.have.lengthOf(1) + + const originallyPublishedAt = new Date(videoHttp.originallyPublishedAt) + expect(originallyPublishedAt.getDate()).to.equal(14) + expect(originallyPublishedAt.getMonth()).to.equal(0) + expect(originallyPublishedAt.getFullYear()).to.equal(2019) + + const resMagnet = await getVideo(url, idMagnet) + const videoMagnet: VideoDetails = resMagnet.body + const resTorrent = await getVideo(url, idTorrent) + const videoTorrent: VideoDetails = resTorrent.body + + for (const video of [ videoMagnet, videoTorrent ]) { + expect(video.category.label).to.equal('Misc') + expect(video.licence.label).to.equal('Unknown') + expect(video.language.label).to.equal('Unknown') + expect(video.nsfw).to.be.false + expect(video.description).to.equal('this is a super torrent description') + expect(video.tags).to.deep.equal([ 'tag_torrent1', 'tag_torrent2' ]) + expect(video.files).to.have.lengthOf(1) + } - expect(video.name).to.equal('small video - youtube') - expect(video.category.label).to.equal('News') - expect(video.licence.label).to.equal('Attribution') - expect(video.language.label).to.equal('Unknown') - expect(video.nsfw).to.be.false - expect(video.description).to.equal('this is a super description') - expect(video.tags).to.deep.equal([ 'tag1', 'tag2' ]) + expect(videoTorrent.name).to.contain('你好 世界 720p.mp4') + expect(videoMagnet.name).to.contain('super peertube2 video') - expect(video.files).to.have.lengthOf(1) + const resCaptions = await listVideoCaptions(url, idHttp) + expect(resCaptions.body.total).to.equal(2) } async function checkVideoServer2 (url: string, id: number | string) { const res = await getVideo(url, id) - const video = res.body + const video: VideoDetails = res.body expect(video.name).to.equal('my super name') expect(video.category.label).to.equal('Entertainment') @@ -52,6 +81,9 @@ describe('Test video imports', function () { expect(video.tags).to.deep.equal([ 'supertag1', 'supertag2' ]) expect(video.files).to.have.lengthOf(1) + + const resCaptions = await listVideoCaptions(url, id) + expect(resCaptions.body.total).to.equal(2) } before(async function () { @@ -64,61 +96,141 @@ describe('Test video imports', function () { { const res = await getMyUserInformation(servers[0].url, servers[0].accessToken) - channelIdServer1 = res.body.videoChannels[ 0 ].id + channelIdServer1 = res.body.videoChannels[0].id } { const res = await getMyUserInformation(servers[1].url, servers[1].accessToken) - channelIdServer2 = res.body.videoChannels[ 0 ].id + channelIdServer2 = res.body.videoChannels[0].id } await doubleFollow(servers[0], servers[1]) }) - it('Should import a video on server 1', async function () { + it('Should import videos on server 1', async function () { this.timeout(60000) - const attributes = { - targetUrl: getYoutubeVideoUrl(), + const baseAttributes = { channelId: channelIdServer1, privacy: VideoPrivacy.PUBLIC } - const res = await importVideo(servers[0].url, servers[0].accessToken, attributes) - expect(res.body.video.name).to.equal('small video - youtube') + + { + const attributes = immutableAssign(baseAttributes, { targetUrl: getYoutubeVideoUrl() }) + const res = await importVideo(servers[0].url, servers[0].accessToken, attributes) + expect(res.body.video.name).to.equal('small video - youtube') + expect(res.body.video.thumbnailPath).to.equal(`/static/thumbnails/${res.body.video.uuid}.jpg`) + expect(res.body.video.previewPath).to.equal(`/static/previews/${res.body.video.uuid}.jpg`) + await testImage(servers[0].url, 'video_import_thumbnail', res.body.video.thumbnailPath) + await testImage(servers[0].url, 'video_import_preview', res.body.video.previewPath) + + const resCaptions = await listVideoCaptions(servers[0].url, res.body.video.id) + const videoCaptions: VideoCaption[] = resCaptions.body.data + expect(videoCaptions).to.have.lengthOf(2) + + const enCaption = videoCaptions.find(caption => caption.language.id === 'en') + expect(enCaption).to.exist + expect(enCaption.language.label).to.equal('English') + expect(enCaption.captionPath).to.equal(`/static/video-captions/${res.body.video.uuid}-en.vtt`) + await testCaptionFile(servers[0].url, enCaption.captionPath, `WEBVTT +Kind: captions +Language: en + +00:00:01.600 --> 00:00:04.200 +English (US) + +00:00:05.900 --> 00:00:07.999 +This is a subtitle in American English + +00:00:10.000 --> 00:00:14.000 +Adding subtitles is very easy to do`) + + const frCaption = videoCaptions.find(caption => caption.language.id === 'fr') + expect(frCaption).to.exist + expect(frCaption.language.label).to.equal('French') + expect(frCaption.captionPath).to.equal(`/static/video-captions/${res.body.video.uuid}-fr.vtt`) + await testCaptionFile(servers[0].url, frCaption.captionPath, `WEBVTT +Kind: captions +Language: fr + +00:00:01.600 --> 00:00:04.200 +Français (FR) + +00:00:05.900 --> 00:00:07.999 +C'est un sous-titre français + +00:00:10.000 --> 00:00:14.000 +Ajouter un sous-titre est vraiment facile`) + } + + { + const attributes = immutableAssign(baseAttributes, { + magnetUri: getMagnetURI(), + description: 'this is a super torrent description', + tags: [ 'tag_torrent1', 'tag_torrent2' ] + }) + const res = await importVideo(servers[0].url, servers[0].accessToken, attributes) + expect(res.body.video.name).to.equal('super peertube2 video') + } + + { + const attributes = immutableAssign(baseAttributes, { + torrentfile: 'video-720p.torrent' as any, + description: 'this is a super torrent description', + tags: [ 'tag_torrent1', 'tag_torrent2' ] + }) + const res = await importVideo(servers[0].url, servers[0].accessToken, attributes) + expect(res.body.video.name).to.equal('你好 世界 720p.mp4') + } }) - it('Should list the video to import in my videos on server 1', async function () { - const res = await getMyVideos(servers[0].url, servers[0].accessToken, 0, 5) + it('Should list the videos to import in my videos on server 1', async function () { + const res = await getMyVideos(servers[0].url, servers[0].accessToken, 0, 5, 'createdAt') - expect(res.body.total).to.equal(1) + expect(res.body.total).to.equal(3) const videos = res.body.data - expect(videos).to.have.lengthOf(1) + expect(videos).to.have.lengthOf(3) expect(videos[0].name).to.equal('small video - youtube') + expect(videos[1].name).to.equal('super peertube2 video') + expect(videos[2].name).to.equal('你好 世界 720p.mp4') }) - it('Should list the video to import in my imports on server 1', async function () { - const res = await getMyVideoImports(servers[0].url, servers[0].accessToken) + it('Should list the videos to import in my imports on server 1', async function () { + const res = await getMyVideoImports(servers[0].url, servers[0].accessToken, '-createdAt') + + expect(res.body.total).to.equal(3) + const videoImports: VideoImport[] = res.body.data + expect(videoImports).to.have.lengthOf(3) - expect(res.body.total).to.equal(1) - const videoImports = res.body.data - expect(videoImports).to.have.lengthOf(1) + expect(videoImports[2].targetUrl).to.equal(getYoutubeVideoUrl()) + expect(videoImports[2].magnetUri).to.be.null + expect(videoImports[2].torrentName).to.be.null + expect(videoImports[2].video.name).to.equal('small video - youtube') - expect(videoImports[0].targetUrl).to.equal(getYoutubeVideoUrl()) - expect(videoImports[0].video.name).to.equal('small video - youtube') + expect(videoImports[1].targetUrl).to.be.null + expect(videoImports[1].magnetUri).to.equal(getMagnetURI()) + expect(videoImports[1].torrentName).to.be.null + expect(videoImports[1].video.name).to.equal('super peertube2 video') + + expect(videoImports[0].targetUrl).to.be.null + expect(videoImports[0].magnetUri).to.be.null + expect(videoImports[0].torrentName).to.equal('video-720p.torrent') + expect(videoImports[0].video.name).to.equal('你好 世界 720p.mp4') }) - it('Should have the video listed on the two instances1', async function () { + it('Should have the video listed on the two instances', async function () { this.timeout(120000) await waitJobs(servers) for (const server of servers) { const res = await getVideosList(server.url) - expect(res.body.total).to.equal(1) - expect(res.body.data).to.have.lengthOf(1) + expect(res.body.total).to.equal(3) + expect(res.body.data).to.have.lengthOf(3) - await checkVideoServer1(server.url, res.body.data[0].uuid) + const [ videoHttp, videoMagnet, videoTorrent ] = res.body.data + await checkVideosServer1(server.url, videoHttp.uuid, videoMagnet.uuid, videoTorrent.uuid) } }) @@ -127,7 +239,7 @@ describe('Test video imports', function () { const attributes = { targetUrl: getYoutubeVideoUrl(), - channelId: channelIdServer1, + channelId: channelIdServer2, privacy: VideoPrivacy.PUBLIC, category: 10, licence: 7, @@ -140,22 +252,47 @@ describe('Test video imports', function () { expect(res.body.video.name).to.equal('my super name') }) - it('Should have the video listed on the two instances', async function () { + it('Should have the videos listed on the two instances', async function () { this.timeout(120000) await waitJobs(servers) for (const server of servers) { const res = await getVideosList(server.url) - expect(res.body.total).to.equal(2) - expect(res.body.data).to.have.lengthOf(2) + expect(res.body.total).to.equal(4) + expect(res.body.data).to.have.lengthOf(4) await checkVideoServer2(server.url, res.body.data[0].uuid) - await checkVideoServer1(server.url, res.body.data[1].uuid) + + const [ , videoHttp, videoMagnet, videoTorrent ] = res.body.data + await checkVideosServer1(server.url, videoHttp.uuid, videoMagnet.uuid, videoTorrent.uuid) + } + }) + + it('Should import a video that will be transcoded', async function () { + this.timeout(120000) + + const attributes = { + name: 'transcoded video', + magnetUri: getMagnetURI(), + channelId: channelIdServer2, + privacy: VideoPrivacy.PUBLIC + } + const res = await importVideo(servers[1].url, servers[1].accessToken, attributes) + const videoUUID = res.body.video.uuid + + await waitJobs(servers) + + for (const server of servers) { + const res = await getVideo(server.url, videoUUID) + const video: VideoDetails = res.body + + expect(video.name).to.equal('transcoded video') + expect(video.files).to.have.lengthOf(4) } }) after(async function () { - killallServers(servers) + await cleanupTests(servers) }) })