X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=server%2Ftests%2Fapi%2Fcheck-params%2Fservices.ts;h=d45868f36f7f2fa0cf9ea99651ac2f2fafad8b48;hb=cffef25313bdf7a6c435f56ac6715fdd91acf7b3;hp=780254df5ccc1f4d41b2f2849ca52da660f990a9;hpb=d8755eed1e452d2efbfc983af0e9d228d152bf6b;p=github%2FChocobozzz%2FPeerTube.git diff --git a/server/tests/api/check-params/services.ts b/server/tests/api/check-params/services.ts index 780254df5..d45868f36 100644 --- a/server/tests/api/check-params/services.ts +++ b/server/tests/api/check-params/services.ts @@ -1,159 +1,195 @@ -/* tslint:disable:no-unused-expression */ - -import * as request from 'supertest' -import 'mocha' +/* eslint-disable @typescript-eslint/no-unused-expressions,@typescript-eslint/require-await */ +import { HttpStatusCode, VideoCreateResult, VideoPlaylistCreateResult, VideoPlaylistPrivacy, VideoPrivacy } from '@shared/models' import { - flushTests, - runServer, + cleanupTests, + createSingleServer, + makeGetRequest, + PeerTubeServer, setAccessTokensToServers, - killallServers -} from '../../utils' -import { getVideosList, uploadVideo } from '../../utils/videos' + setDefaultVideoChannel +} from '@shared/server-commands' describe('Test services API validators', function () { - let server + let server: PeerTubeServer + let playlistUUID: string + + let privateVideo: VideoCreateResult + let unlistedVideo: VideoCreateResult + + let privatePlaylist: VideoPlaylistCreateResult + let unlistedPlaylist: VideoPlaylistCreateResult // --------------------------------------------------------------- before(async function () { this.timeout(60000) - await flushTests() - - server = await runServer(1) + server = await createSingleServer(1) await setAccessTokensToServers([ server ]) - - const videoAttributes = { - name: 'my super name' + await setDefaultVideoChannel([ server ]) + + server.store.videoCreated = await server.videos.upload({ attributes: { name: 'my super name' } }) + + privateVideo = await server.videos.quickUpload({ name: 'private', privacy: VideoPrivacy.PRIVATE }) + unlistedVideo = await server.videos.quickUpload({ name: 'unlisted', privacy: VideoPrivacy.UNLISTED }) + + { + const created = await server.playlists.create({ + attributes: { + displayName: 'super playlist', + privacy: VideoPlaylistPrivacy.PUBLIC, + videoChannelId: server.store.channel.id + } + }) + + playlistUUID = created.uuid + + privatePlaylist = await server.playlists.create({ + attributes: { + displayName: 'private', + privacy: VideoPlaylistPrivacy.PRIVATE, + videoChannelId: server.store.channel.id + } + }) + + unlistedPlaylist = await server.playlists.create({ + attributes: { + displayName: 'unlisted', + privacy: VideoPlaylistPrivacy.UNLISTED, + videoChannelId: server.store.channel.id + } + }) } - await uploadVideo(server.url, server.accessToken, videoAttributes) - - const res = await getVideosList(server.url) - server.video = res.body.data[0] }) describe('Test oEmbed API validators', function () { - const path = '/services/oembed' it('Should fail with an invalid url', async function () { const embedUrl = 'hello.com' - - await request(server.url) - .get(path) - .query({ url: embedUrl }) - .set('Accept', 'application/json') - .set('Authorization', 'Bearer ' + server.accessToken) - .expect(400) + await checkParamEmbed(server, embedUrl) }) it('Should fail with an invalid host', async function () { - const embedUrl = 'http://hello.com/videos/watch/' + server.video.uuid - - await request(server.url) - .get(path) - .query({ url: embedUrl }) - .set('Accept', 'application/json') - .set('Authorization', 'Bearer ' + server.accessToken) - .expect(400) + const embedUrl = 'http://hello.com/videos/watch/' + server.store.videoCreated.uuid + await checkParamEmbed(server, embedUrl) }) - it('Should fail with an invalid video id', async function () { - const embedUrl = 'http://localhost:9001/videos/watch/blabla' - - await request(server.url) - .get(path) - .query({ url: embedUrl }) - .set('Accept', 'application/json') - .set('Authorization', 'Bearer ' + server.accessToken) - .expect(400) + it('Should fail with an invalid element id', async function () { + const embedUrl = `${server.url}/videos/watch/blabla` + await checkParamEmbed(server, embedUrl) }) - it('Should fail with an unknown video', async function () { - const embedUrl = 'http://localhost:9001/videos/watch/88fc0165-d1f0-4a35-a51a-3b47f668689c' - - await request(server.url) - .get(path) - .query({ url: embedUrl }) - .set('Accept', 'application/json') - .set('Authorization', 'Bearer ' + server.accessToken) - .expect(404) + it('Should fail with an unknown element', async function () { + const embedUrl = `${server.url}/videos/watch/88fc0165-d1f0-4a35-a51a-3b47f668689c` + await checkParamEmbed(server, embedUrl, HttpStatusCode.NOT_FOUND_404) }) it('Should fail with an invalid path', async function () { - const embedUrl = 'http://localhost:9001/videos/watchs/' + server.video.uuid + const embedUrl = `${server.url}/videos/watchs/${server.store.videoCreated.uuid}` - await request(server.url) - .get(path) - .query({ url: embedUrl }) - .set('Accept', 'application/json') - .set('Authorization', 'Bearer ' + server.accessToken) - .expect(400) + await checkParamEmbed(server, embedUrl) }) it('Should fail with an invalid max height', async function () { - const embedUrl = 'http://localhost:9001/videos/watch/' + server.video.uuid + const embedUrl = `${server.url}/videos/watch/${server.store.videoCreated.uuid}` - await request(server.url) - .get(path) - .query({ - url: embedUrl, - maxheight: 'hello' - }) - .set('Accept', 'application/json') - .set('Authorization', 'Bearer ' + server.accessToken) - .expect(400) + await checkParamEmbed(server, embedUrl, HttpStatusCode.BAD_REQUEST_400, { maxheight: 'hello' }) }) it('Should fail with an invalid max width', async function () { - const embedUrl = 'http://localhost:9001/videos/watch/' + server.video.uuid + const embedUrl = `${server.url}/videos/watch/${server.store.videoCreated.uuid}` - await request(server.url) - .get(path) - .query({ - url: embedUrl, - maxwidth: 'hello' - }) - .set('Accept', 'application/json') - .set('Authorization', 'Bearer ' + server.accessToken) - .expect(400) + await checkParamEmbed(server, embedUrl, HttpStatusCode.BAD_REQUEST_400, { maxwidth: 'hello' }) }) it('Should fail with an invalid format', async function () { - const embedUrl = 'http://localhost:9001/videos/watch/' + server.video.uuid + const embedUrl = `${server.url}/videos/watch/${server.store.videoCreated.uuid}` - await request(server.url) - .get(path) - .query({ - url: embedUrl, - format: 'blabla' - }) - .set('Accept', 'application/json') - .set('Authorization', 'Bearer ' + server.accessToken) - .expect(400) + await checkParamEmbed(server, embedUrl, HttpStatusCode.BAD_REQUEST_400, { format: 'blabla' }) }) it('Should fail with a non supported format', async function () { - const embedUrl = 'http://localhost:9001/videos/watch/' + server.video.uuid - - await request(server.url) - .get(path) - .query({ - url: embedUrl, - format: 'xml' - }) - .set('Accept', 'application/json') - .set('Authorization', 'Bearer ' + server.accessToken) - .expect(501) + const embedUrl = `${server.url}/videos/watch/${server.store.videoCreated.uuid}` + + await checkParamEmbed(server, embedUrl, HttpStatusCode.NOT_IMPLEMENTED_501, { format: 'xml' }) + }) + + it('Should fail with a private video', async function () { + const embedUrl = `${server.url}/videos/watch/${privateVideo.uuid}` + + await checkParamEmbed(server, embedUrl, HttpStatusCode.FORBIDDEN_403) + }) + + it('Should fail with an unlisted video with the int id', async function () { + const embedUrl = `${server.url}/videos/watch/${unlistedVideo.id}` + + await checkParamEmbed(server, embedUrl, HttpStatusCode.FORBIDDEN_403) + }) + + it('Should succeed with an unlisted video using the uuid id', async function () { + for (const uuid of [ unlistedVideo.uuid, unlistedVideo.shortUUID ]) { + const embedUrl = `${server.url}/videos/watch/${uuid}` + + await checkParamEmbed(server, embedUrl, HttpStatusCode.OK_200) + } + }) + + it('Should fail with a private playlist', async function () { + const embedUrl = `${server.url}/videos/watch/playlist/${privatePlaylist.uuid}` + + await checkParamEmbed(server, embedUrl, HttpStatusCode.FORBIDDEN_403) + }) + + it('Should fail with an unlisted playlist using the int id', async function () { + const embedUrl = `${server.url}/videos/watch/playlist/${unlistedPlaylist.id}` + + await checkParamEmbed(server, embedUrl, HttpStatusCode.FORBIDDEN_403) + }) + + it('Should succeed with an unlisted playlist using the uuid id', async function () { + for (const uuid of [ unlistedPlaylist.uuid, unlistedPlaylist.shortUUID ]) { + const embedUrl = `${server.url}/videos/watch/playlist/${uuid}` + + await checkParamEmbed(server, embedUrl, HttpStatusCode.OK_200) + } + }) + + it('Should succeed with the correct params with a video', async function () { + const embedUrl = `${server.url}/videos/watch/${server.store.videoCreated.uuid}` + const query = { + format: 'json', + maxheight: 400, + maxwidth: 400 + } + + await checkParamEmbed(server, embedUrl, HttpStatusCode.OK_200, query) + }) + + it('Should succeed with the correct params with a playlist', async function () { + const embedUrl = `${server.url}/videos/watch/playlist/${playlistUUID}` + const query = { + format: 'json', + maxheight: 400, + maxwidth: 400 + } + + await checkParamEmbed(server, embedUrl, HttpStatusCode.OK_200, query) }) }) after(async function () { - killallServers([ server ]) - - // Keep the logs if the test failed - if (this['ok']) { - await flushTests() - } + await cleanupTests([ server ]) }) }) + +function checkParamEmbed (server: PeerTubeServer, embedUrl: string, expectedStatus = HttpStatusCode.BAD_REQUEST_400, query = {}) { + const path = '/services/oembed' + + return makeGetRequest({ + url: server.url, + path, + query: Object.assign(query, { url: embedUrl }), + expectedStatus + }) +}