import * as express from 'express'
-import { EMBED_SIZE, PREVIEWS_SIZE, WEBSERVER } from '../initializers/constants'
+import { EMBED_SIZE, PREVIEWS_SIZE, WEBSERVER, THUMBNAILS_SIZE } from '../initializers/constants'
import { asyncMiddleware, oembedValidator } from '../middlewares'
import { accountNameWithHostGetValidator } from '../middlewares/validators'
+import { MChannelSummary } from '@server/types/models'
const servicesRouter = express.Router()
// ---------------------------------------------------------------------------
function generateOEmbed (req: express.Request, res: express.Response) {
+ if (res.locals.videoAll) return generateVideoOEmbed(req, res)
+
+ return generatePlaylistOEmbed(req, res)
+}
+
+function generatePlaylistOEmbed (req: express.Request, res: express.Response) {
+ const playlist = res.locals.videoPlaylistSummary
+
+ const json = buildOEmbed({
+ channel: playlist.VideoChannel,
+ title: playlist.name,
+ embedPath: playlist.getEmbedStaticPath(),
+ previewPath: playlist.getThumbnailStaticPath(),
+ previewSize: THUMBNAILS_SIZE,
+ req
+ })
+
+ return res.json(json)
+}
+
+function generateVideoOEmbed (req: express.Request, res: express.Response) {
const video = res.locals.videoAll
+
+ const json = buildOEmbed({
+ channel: video.VideoChannel,
+ title: video.name,
+ embedPath: video.getEmbedStaticPath(),
+ previewPath: video.getPreviewStaticPath(),
+ previewSize: PREVIEWS_SIZE,
+ req
+ })
+
+ return res.json(json)
+}
+
+function buildOEmbed (options: {
+ req: express.Request
+ title: string
+ channel: MChannelSummary
+ previewPath: string | null
+ embedPath: string
+ previewSize: {
+ height: number
+ width: number
+ }
+}) {
+ const { req, previewSize, previewPath, title, channel, embedPath } = options
+
const webserverUrl = WEBSERVER.URL
const maxHeight = parseInt(req.query.maxheight, 10)
const maxWidth = parseInt(req.query.maxwidth, 10)
- const embedUrl = webserverUrl + video.getEmbedStaticPath()
- let thumbnailUrl = webserverUrl + video.getPreviewStaticPath()
+ const embedUrl = webserverUrl + embedPath
let embedWidth = EMBED_SIZE.width
let embedHeight = EMBED_SIZE.height
+ let thumbnailUrl = previewPath
+ ? webserverUrl + previewPath
+ : undefined
+
if (maxHeight < embedHeight) embedHeight = maxHeight
if (maxWidth < embedWidth) embedWidth = maxWidth
// Our thumbnail is too big for the consumer
if (
- (maxHeight !== undefined && maxHeight < PREVIEWS_SIZE.height) ||
- (maxWidth !== undefined && maxWidth < PREVIEWS_SIZE.width)
+ (maxHeight !== undefined && maxHeight < previewSize.height) ||
+ (maxWidth !== undefined && maxWidth < previewSize.width)
) {
thumbnailUrl = undefined
}
html,
width: embedWidth,
height: embedHeight,
- title: video.name,
- author_name: video.VideoChannel.Account.name,
- author_url: video.VideoChannel.Account.Actor.url,
+ title: title,
+ author_name: channel.name,
+ author_url: channel.Actor.url,
provider_name: 'PeerTube',
provider_url: webserverUrl
}
if (thumbnailUrl !== undefined) {
json.thumbnail_url = thumbnailUrl
- json.thumbnail_width = PREVIEWS_SIZE.width
- json.thumbnail_height = PREVIEWS_SIZE.height
+ json.thumbnail_width = previewSize.width
+ json.thumbnail_height = previewSize.height
}
- return res.json(json)
+ return json
}
function redirectToAccountUrl (req: express.Request, res: express.Response, next: express.NextFunction) {
/* eslint-disable @typescript-eslint/no-unused-expressions,@typescript-eslint/require-await */
-import * as chai from 'chai'
import 'mocha'
-import { getOEmbed, getVideosList, ServerInfo, setAccessTokensToServers, uploadVideo } from '../../../../shared/extra-utils/index'
+import * as chai from 'chai'
+import {
+ getOEmbed,
+ getVideosList,
+ ServerInfo,
+ setAccessTokensToServers,
+ setDefaultVideoChannel,
+ uploadVideo,
+ createVideoPlaylist,
+ addVideoInPlaylist
+} from '../../../../shared/extra-utils'
import { cleanupTests, flushAndRunServer } from '../../../../shared/extra-utils/server/servers'
+import { VideoPlaylistPrivacy } from '@shared/models'
const expect = chai.expect
describe('Test services', function () {
let server: ServerInfo = null
+ let playlistUUID: string
before(async function () {
this.timeout(30000)
server = await flushAndRunServer(1)
await setAccessTokensToServers([ server ])
+ await setDefaultVideoChannel([ server ])
- const videoAttributes = {
- name: 'my super name'
+ {
+ const videoAttributes = {
+ name: 'my super name'
+ }
+ await uploadVideo(server.url, server.accessToken, videoAttributes)
+
+ const res = await getVideosList(server.url)
+ server.video = res.body.data[0]
}
- await uploadVideo(server.url, server.accessToken, videoAttributes)
- const res = await getVideosList(server.url)
- server.video = res.body.data[0]
+ {
+ const res = await createVideoPlaylist({
+ url: server.url,
+ token: server.accessToken,
+ playlistAttrs: {
+ displayName: 'The Life and Times of Scrooge McDuck',
+ privacy: VideoPlaylistPrivacy.PUBLIC,
+ videoChannelId: server.videoChannel.id
+ }
+ })
+
+ playlistUUID = res.body.videoPlaylist.uuid
+
+ await addVideoInPlaylist({
+ url: server.url,
+ token: server.accessToken,
+ playlistId: res.body.videoPlaylist.id,
+ elementAttrs: {
+ videoId: server.video.id
+ }
+ })
+ }
})
- it('Should have a valid oEmbed response', async function () {
+ it('Should have a valid oEmbed video response', async function () {
const oembedUrl = 'http://localhost:' + server.port + '/videos/watch/' + server.video.uuid
const res = await getOEmbed(server.url, oembedUrl)
expect(res.body.html).to.equal(expectedHtml)
expect(res.body.title).to.equal(server.video.name)
- expect(res.body.author_name).to.equal(server.video.account.name)
+ expect(res.body.author_name).to.equal(server.videoChannel.displayName)
expect(res.body.width).to.equal(560)
expect(res.body.height).to.equal(315)
expect(res.body.thumbnail_url).to.equal(expectedThumbnailUrl)
expect(res.body.thumbnail_height).to.equal(480)
})
+ it('Should have a valid playlist oEmbed response', async function () {
+ const oembedUrl = 'http://localhost:' + server.port + '/videos/watch/playlist/' + playlistUUID
+
+ const res = await getOEmbed(server.url, oembedUrl)
+ const expectedHtml = '<iframe width="560" height="315" sandbox="allow-same-origin allow-scripts" ' +
+ `src="http://localhost:${server.port}/video-playlists/embed/${playlistUUID}" ` +
+ 'frameborder="0" allowfullscreen></iframe>'
+
+ expect(res.body.html).to.equal(expectedHtml)
+ expect(res.body.title).to.equal('The Life and Times of Scrooge McDuck')
+ expect(res.body.author_name).to.equal(server.videoChannel.displayName)
+ expect(res.body.width).to.equal(560)
+ expect(res.body.height).to.equal(315)
+ expect(res.body.thumbnail_url).exist
+ expect(res.body.thumbnail_width).to.equal(223)
+ expect(res.body.thumbnail_height).to.equal(122)
+ })
+
it('Should have a valid oEmbed response with small max height query', async function () {
const oembedUrl = 'http://localhost:' + server.port + '/videos/watch/' + server.video.uuid
const format = 'json'
expect(res.body.html).to.equal(expectedHtml)
expect(res.body.title).to.equal(server.video.name)
- expect(res.body.author_name).to.equal(server.video.account.name)
+ expect(res.body.author_name).to.equal(server.videoChannel.displayName)
expect(res.body.height).to.equal(50)
expect(res.body.width).to.equal(50)
expect(res.body).to.not.have.property('thumbnail_url')
account = resAccountRequest.body
})
- it('Should have valid Open Graph tags on the watch page with video id', async function () {
- const res = await request(server.url)
- .get('/videos/watch/' + server.video.id)
- .set('Accept', 'text/html')
- .expect(200)
-
- expect(res.text).to.contain(`<meta property="og:title" content="${videoName}" />`)
- expect(res.text).to.contain(`<meta property="og:description" content="${videoDescription}" />`)
- expect(res.text).to.contain('<meta property="og:type" content="video" />')
- expect(res.text).to.contain(`<meta property="og:url" content="${server.url}/videos/watch/${server.video.uuid}" />`)
- })
+ describe('oEmbed', function () {
+ it('Should have valid oEmbed discovery tags for videos', async function () {
+ const path = '/videos/watch/' + server.video.uuid
+ const res = await request(server.url)
+ .get(path)
+ .set('Accept', 'text/html')
+ .expect(200)
- it('Should have valid Open Graph tags on the watch page with video uuid', async function () {
- const res = await request(server.url)
- .get('/videos/watch/' + server.video.uuid)
- .set('Accept', 'text/html')
- .expect(200)
+ const port = server.port
- expect(res.text).to.contain(`<meta property="og:title" content="${videoName}" />`)
- expect(res.text).to.contain(`<meta property="og:description" content="${videoDescription}" />`)
- expect(res.text).to.contain('<meta property="og:type" content="video" />')
- expect(res.text).to.contain(`<meta property="og:url" content="${server.url}/videos/watch/${server.video.uuid}" />`)
- })
+ const expectedLink = '<link rel="alternate" type="application/json+oembed" href="http://localhost:' + port + '/services/oembed?' +
+ `url=http%3A%2F%2Flocalhost%3A${port}%2Fvideos%2Fwatch%2F${server.video.uuid}" ` +
+ `title="${server.video.name}" />`
- it('Should have valid Open Graph tags on the watch playlist page', async function () {
- const res = await request(server.url)
- .get('/videos/watch/playlist/' + playlistUUID)
- .set('Accept', 'text/html')
- .expect(200)
+ expect(res.text).to.contain(expectedLink)
+ })
- expect(res.text).to.contain(`<meta property="og:title" content="${playlistName}" />`)
- expect(res.text).to.contain(`<meta property="og:description" content="${playlistDescription}" />`)
- expect(res.text).to.contain('<meta property="og:type" content="video" />')
- expect(res.text).to.contain(`<meta property="og:url" content="${server.url}/videos/watch/playlist/${playlistUUID}" />`)
- })
+ it('Should have valid oEmbed discovery tags for a playlist', async function () {
+ const res = await request(server.url)
+ .get('/videos/watch/playlist/' + playlistUUID)
+ .set('Accept', 'text/html')
+ .expect(200)
+
+ const port = server.port
- it('Should have valid Open Graph tags on the account page', async function () {
- const res = await request(server.url)
- .get('/accounts/' + server.user.username)
- .set('Accept', 'text/html')
- .expect(200)
+ const expectedLink = '<link rel="alternate" type="application/json+oembed" href="http://localhost:' + port + '/services/oembed?' +
+ `url=http%3A%2F%2Flocalhost%3A${port}%2Fvideos%2Fwatch%2Fplaylist%2F${playlistUUID}" ` +
+ `title="${playlistName}" />`
- expect(res.text).to.contain(`<meta property="og:title" content="${account.displayName}" />`)
- expect(res.text).to.contain(`<meta property="og:description" content="${account.description}" />`)
- expect(res.text).to.contain('<meta property="og:type" content="website" />')
- expect(res.text).to.contain(`<meta property="og:url" content="${server.url}/accounts/${server.user.username}" />`)
+ expect(res.text).to.contain(expectedLink)
+ })
})
- it('Should have valid Open Graph tags on the channel page', async function () {
- const res = await request(server.url)
- .get('/video-channels/' + server.videoChannel.name)
- .set('Accept', 'text/html')
- .expect(200)
+ describe('Open Graph', function () {
- expect(res.text).to.contain(`<meta property="og:title" content="${server.videoChannel.displayName}" />`)
- expect(res.text).to.contain(`<meta property="og:description" content="${channelDescription}" />`)
- expect(res.text).to.contain('<meta property="og:type" content="website" />')
- expect(res.text).to.contain(`<meta property="og:url" content="${server.url}/video-channels/${server.videoChannel.name}" />`)
- })
+ it('Should have valid Open Graph tags on the account page', async function () {
+ const res = await request(server.url)
+ .get('/accounts/' + server.user.username)
+ .set('Accept', 'text/html')
+ .expect(200)
- it('Should have valid oEmbed discovery tags', async function () {
- const path = '/videos/watch/' + server.video.uuid
- const res = await request(server.url)
- .get(path)
- .set('Accept', 'text/html')
- .expect(200)
+ expect(res.text).to.contain(`<meta property="og:title" content="${account.displayName}" />`)
+ expect(res.text).to.contain(`<meta property="og:description" content="${account.description}" />`)
+ expect(res.text).to.contain('<meta property="og:type" content="website" />')
+ expect(res.text).to.contain(`<meta property="og:url" content="${server.url}/accounts/${server.user.username}" />`)
+ })
- const port = server.port
+ it('Should have valid Open Graph tags on the channel page', async function () {
+ const res = await request(server.url)
+ .get('/video-channels/' + server.videoChannel.name)
+ .set('Accept', 'text/html')
+ .expect(200)
- const expectedLink = '<link rel="alternate" type="application/json+oembed" href="http://localhost:' + port + '/services/oembed?' +
- `url=http%3A%2F%2Flocalhost%3A${port}%2Fvideos%2Fwatch%2F${server.video.uuid}" ` +
- `title="${server.video.name}" />`
+ expect(res.text).to.contain(`<meta property="og:title" content="${server.videoChannel.displayName}" />`)
+ expect(res.text).to.contain(`<meta property="og:description" content="${channelDescription}" />`)
+ expect(res.text).to.contain('<meta property="og:type" content="website" />')
+ expect(res.text).to.contain(`<meta property="og:url" content="${server.url}/video-channels/${server.videoChannel.name}" />`)
+ })
- expect(res.text).to.contain(expectedLink)
- })
+ it('Should have valid Open Graph tags on the watch page with video id', async function () {
+ const res = await request(server.url)
+ .get('/videos/watch/' + server.video.id)
+ .set('Accept', 'text/html')
+ .expect(200)
- it('Should have valid twitter card on the watch video page', async function () {
- const res = await request(server.url)
- .get('/videos/watch/' + server.video.uuid)
- .set('Accept', 'text/html')
- .expect(200)
+ expect(res.text).to.contain(`<meta property="og:title" content="${videoName}" />`)
+ expect(res.text).to.contain(`<meta property="og:description" content="${videoDescription}" />`)
+ expect(res.text).to.contain('<meta property="og:type" content="video" />')
+ expect(res.text).to.contain(`<meta property="og:url" content="${server.url}/videos/watch/${server.video.uuid}" />`)
+ })
- expect(res.text).to.contain('<meta property="twitter:card" content="summary_large_image" />')
- expect(res.text).to.contain('<meta property="twitter:site" content="@Chocobozzz" />')
- expect(res.text).to.contain(`<meta property="twitter:title" content="${videoName}" />`)
- expect(res.text).to.contain(`<meta property="twitter:description" content="${videoDescription}" />`)
- })
+ it('Should have valid Open Graph tags on the watch page with video uuid', async function () {
+ const res = await request(server.url)
+ .get('/videos/watch/' + server.video.uuid)
+ .set('Accept', 'text/html')
+ .expect(200)
- it('Should have valid twitter card on the watch playlist page', async function () {
- const res = await request(server.url)
- .get('/videos/watch/playlist/' + playlistUUID)
- .set('Accept', 'text/html')
- .expect(200)
+ expect(res.text).to.contain(`<meta property="og:title" content="${videoName}" />`)
+ expect(res.text).to.contain(`<meta property="og:description" content="${videoDescription}" />`)
+ expect(res.text).to.contain('<meta property="og:type" content="video" />')
+ expect(res.text).to.contain(`<meta property="og:url" content="${server.url}/videos/watch/${server.video.uuid}" />`)
+ })
- expect(res.text).to.contain('<meta property="twitter:card" content="summary" />')
- expect(res.text).to.contain('<meta property="twitter:site" content="@Chocobozzz" />')
- expect(res.text).to.contain(`<meta property="twitter:title" content="${playlistName}" />`)
- expect(res.text).to.contain(`<meta property="twitter:description" content="${playlistDescription}" />`)
+ it('Should have valid Open Graph tags on the watch playlist page', async function () {
+ const res = await request(server.url)
+ .get('/videos/watch/playlist/' + playlistUUID)
+ .set('Accept', 'text/html')
+ .expect(200)
+
+ expect(res.text).to.contain(`<meta property="og:title" content="${playlistName}" />`)
+ expect(res.text).to.contain(`<meta property="og:description" content="${playlistDescription}" />`)
+ expect(res.text).to.contain('<meta property="og:type" content="video" />')
+ expect(res.text).to.contain(`<meta property="og:url" content="${server.url}/videos/watch/playlist/${playlistUUID}" />`)
+ })
})
- it('Should have valid twitter card on the account page', async function () {
- const res = await request(server.url)
- .get('/accounts/' + account.name)
- .set('Accept', 'text/html')
- .expect(200)
+ describe('Twitter card', async function () {
- expect(res.text).to.contain('<meta property="twitter:card" content="summary" />')
- expect(res.text).to.contain('<meta property="twitter:site" content="@Chocobozzz" />')
- expect(res.text).to.contain(`<meta property="twitter:title" content="${account.name}" />`)
- expect(res.text).to.contain(`<meta property="twitter:description" content="${account.description}" />`)
- })
+ it('Should have valid twitter card on the watch video page', async function () {
+ const res = await request(server.url)
+ .get('/videos/watch/' + server.video.uuid)
+ .set('Accept', 'text/html')
+ .expect(200)
- it('Should have valid twitter card on the channel page', async function () {
- const res = await request(server.url)
- .get('/video-channels/' + server.videoChannel.name)
- .set('Accept', 'text/html')
- .expect(200)
+ expect(res.text).to.contain('<meta property="twitter:card" content="summary_large_image" />')
+ expect(res.text).to.contain('<meta property="twitter:site" content="@Chocobozzz" />')
+ expect(res.text).to.contain(`<meta property="twitter:title" content="${videoName}" />`)
+ expect(res.text).to.contain(`<meta property="twitter:description" content="${videoDescription}" />`)
+ })
- expect(res.text).to.contain('<meta property="twitter:card" content="summary" />')
- expect(res.text).to.contain('<meta property="twitter:site" content="@Chocobozzz" />')
- expect(res.text).to.contain(`<meta property="twitter:title" content="${server.videoChannel.displayName}" />`)
- expect(res.text).to.contain(`<meta property="twitter:description" content="${channelDescription}" />`)
- })
+ it('Should have valid twitter card on the watch playlist page', async function () {
+ const res = await request(server.url)
+ .get('/videos/watch/playlist/' + playlistUUID)
+ .set('Accept', 'text/html')
+ .expect(200)
- it('Should have valid twitter card if Twitter is whitelisted', async function () {
- const res1 = await getCustomConfig(server.url, server.accessToken)
- const config = res1.body
- config.services.twitter = {
- username: '@Kuja',
- whitelisted: true
- }
- await updateCustomConfig(server.url, server.accessToken, config)
+ expect(res.text).to.contain('<meta property="twitter:card" content="summary" />')
+ expect(res.text).to.contain('<meta property="twitter:site" content="@Chocobozzz" />')
+ expect(res.text).to.contain(`<meta property="twitter:title" content="${playlistName}" />`)
+ expect(res.text).to.contain(`<meta property="twitter:description" content="${playlistDescription}" />`)
+ })
- const resVideoRequest = await request(server.url)
- .get('/videos/watch/' + server.video.uuid)
- .set('Accept', 'text/html')
- .expect(200)
+ it('Should have valid twitter card on the account page', async function () {
+ const res = await request(server.url)
+ .get('/accounts/' + account.name)
+ .set('Accept', 'text/html')
+ .expect(200)
- expect(resVideoRequest.text).to.contain('<meta property="twitter:card" content="player" />')
- expect(resVideoRequest.text).to.contain('<meta property="twitter:site" content="@Kuja" />')
+ expect(res.text).to.contain('<meta property="twitter:card" content="summary" />')
+ expect(res.text).to.contain('<meta property="twitter:site" content="@Chocobozzz" />')
+ expect(res.text).to.contain(`<meta property="twitter:title" content="${account.name}" />`)
+ expect(res.text).to.contain(`<meta property="twitter:description" content="${account.description}" />`)
+ })
- const resVideoPlaylistRequest = await request(server.url)
- .get('/videos/watch/playlist/' + playlistUUID)
- .set('Accept', 'text/html')
- .expect(200)
+ it('Should have valid twitter card on the channel page', async function () {
+ const res = await request(server.url)
+ .get('/video-channels/' + server.videoChannel.name)
+ .set('Accept', 'text/html')
+ .expect(200)
- expect(resVideoPlaylistRequest.text).to.contain('<meta property="twitter:card" content="summary" />')
- expect(resVideoPlaylistRequest.text).to.contain('<meta property="twitter:site" content="@Kuja" />')
+ expect(res.text).to.contain('<meta property="twitter:card" content="summary" />')
+ expect(res.text).to.contain('<meta property="twitter:site" content="@Chocobozzz" />')
+ expect(res.text).to.contain(`<meta property="twitter:title" content="${server.videoChannel.displayName}" />`)
+ expect(res.text).to.contain(`<meta property="twitter:description" content="${channelDescription}" />`)
+ })
- const resAccountRequest = await request(server.url)
- .get('/accounts/' + account.name)
- .set('Accept', 'text/html')
- .expect(200)
+ it('Should have valid twitter card if Twitter is whitelisted', async function () {
+ const res1 = await getCustomConfig(server.url, server.accessToken)
+ const config = res1.body
+ config.services.twitter = {
+ username: '@Kuja',
+ whitelisted: true
+ }
+ await updateCustomConfig(server.url, server.accessToken, config)
- expect(resAccountRequest.text).to.contain('<meta property="twitter:card" content="summary" />')
- expect(resAccountRequest.text).to.contain('<meta property="twitter:site" content="@Kuja" />')
+ const resVideoRequest = await request(server.url)
+ .get('/videos/watch/' + server.video.uuid)
+ .set('Accept', 'text/html')
+ .expect(200)
- const resChannelRequest = await request(server.url)
- .get('/video-channels/' + server.videoChannel.name)
- .set('Accept', 'text/html')
- .expect(200)
+ expect(resVideoRequest.text).to.contain('<meta property="twitter:card" content="player" />')
+ expect(resVideoRequest.text).to.contain('<meta property="twitter:site" content="@Kuja" />')
- expect(resChannelRequest.text).to.contain('<meta property="twitter:card" content="summary" />')
- expect(resChannelRequest.text).to.contain('<meta property="twitter:site" content="@Kuja" />')
- })
+ const resVideoPlaylistRequest = await request(server.url)
+ .get('/videos/watch/playlist/' + playlistUUID)
+ .set('Accept', 'text/html')
+ .expect(200)
- it('Should have valid index html tags (title, description...)', async function () {
- const res = await makeHTMLRequest(server.url, '/videos/trending')
+ expect(resVideoPlaylistRequest.text).to.contain('<meta property="twitter:card" content="player" />')
+ expect(resVideoPlaylistRequest.text).to.contain('<meta property="twitter:site" content="@Kuja" />')
- const description = 'PeerTube, an ActivityPub-federated video streaming platform using P2P directly in your web browser.'
- checkIndexTags(res.text, 'PeerTube', description, '')
+ const resAccountRequest = await request(server.url)
+ .get('/accounts/' + account.name)
+ .set('Accept', 'text/html')
+ .expect(200)
+
+ expect(resAccountRequest.text).to.contain('<meta property="twitter:card" content="summary" />')
+ expect(resAccountRequest.text).to.contain('<meta property="twitter:site" content="@Kuja" />')
+
+ const resChannelRequest = await request(server.url)
+ .get('/video-channels/' + server.videoChannel.name)
+ .set('Accept', 'text/html')
+ .expect(200)
+
+ expect(resChannelRequest.text).to.contain('<meta property="twitter:card" content="summary" />')
+ expect(resChannelRequest.text).to.contain('<meta property="twitter:site" content="@Kuja" />')
+ })
})
- it('Should update the customized configuration and have the correct index html tags', async function () {
- await updateCustomSubConfig(server.url, server.accessToken, {
- instance: {
- name: 'PeerTube updated',
- shortDescription: 'my short description',
- description: 'my super description',
- terms: 'my super terms',
- defaultClientRoute: '/videos/recently-added',
- defaultNSFWPolicy: 'blur',
- customizations: {
- javascript: 'alert("coucou")',
- css: 'body { background-color: red; }'
- }
- }
+ describe('Index HTML', function () {
+
+ it('Should have valid index html tags (title, description...)', async function () {
+ const res = await makeHTMLRequest(server.url, '/videos/trending')
+
+ const description = 'PeerTube, an ActivityPub-federated video streaming platform using P2P directly in your web browser.'
+ checkIndexTags(res.text, 'PeerTube', description, '')
})
- const res = await makeHTMLRequest(server.url, '/videos/trending')
+ it('Should update the customized configuration and have the correct index html tags', async function () {
+ await updateCustomSubConfig(server.url, server.accessToken, {
+ instance: {
+ name: 'PeerTube updated',
+ shortDescription: 'my short description',
+ description: 'my super description',
+ terms: 'my super terms',
+ defaultClientRoute: '/videos/recently-added',
+ defaultNSFWPolicy: 'blur',
+ customizations: {
+ javascript: 'alert("coucou")',
+ css: 'body { background-color: red; }'
+ }
+ }
+ })
- checkIndexTags(res.text, 'PeerTube updated', 'my short description', 'body { background-color: red; }')
- })
+ const res = await makeHTMLRequest(server.url, '/videos/trending')
+
+ checkIndexTags(res.text, 'PeerTube updated', 'my short description', 'body { background-color: red; }')
+ })
- it('Should have valid index html updated tags (title, description...)', async function () {
- const res = await makeHTMLRequest(server.url, '/videos/trending')
+ it('Should have valid index html updated tags (title, description...)', async function () {
+ const res = await makeHTMLRequest(server.url, '/videos/trending')
- checkIndexTags(res.text, 'PeerTube updated', 'my short description', 'body { background-color: red; }')
+ checkIndexTags(res.text, 'PeerTube updated', 'my short description', 'body { background-color: red; }')
+ })
})
after(async function () {