Fix client tests
This commit is contained in:
parent
2f712d2bff
commit
39433fa56c
|
@ -3,24 +3,25 @@
|
||||||
import 'mocha'
|
import 'mocha'
|
||||||
import * as chai from 'chai'
|
import * as chai from 'chai'
|
||||||
import * as request from 'supertest'
|
import * as request from 'supertest'
|
||||||
|
import { Account, VideoPlaylistPrivacy } from '@shared/models'
|
||||||
import {
|
import {
|
||||||
|
addVideoInPlaylist,
|
||||||
cleanupTests,
|
cleanupTests,
|
||||||
|
createVideoPlaylist,
|
||||||
flushAndRunServer,
|
flushAndRunServer,
|
||||||
|
getAccount,
|
||||||
getCustomConfig,
|
getCustomConfig,
|
||||||
getVideosList,
|
getVideosList,
|
||||||
makeHTMLRequest,
|
makeHTMLRequest,
|
||||||
ServerInfo,
|
ServerInfo,
|
||||||
serverLogin,
|
serverLogin,
|
||||||
|
setDefaultVideoChannel,
|
||||||
updateCustomConfig,
|
updateCustomConfig,
|
||||||
updateCustomSubConfig,
|
updateCustomSubConfig,
|
||||||
uploadVideo,
|
uploadVideo,
|
||||||
createVideoPlaylist,
|
updateMyUser,
|
||||||
addVideoInPlaylist,
|
updateVideoChannel
|
||||||
getAccount,
|
|
||||||
addVideoChannel
|
|
||||||
} from '../../shared/extra-utils'
|
} from '../../shared/extra-utils'
|
||||||
import { VideoPlaylistPrivacy } from '@shared/models'
|
|
||||||
import { MVideoPlaylist, MAccount, MChannel } from '@server/types/models'
|
|
||||||
|
|
||||||
const expect = chai.expect
|
const expect = chai.expect
|
||||||
|
|
||||||
|
@ -32,28 +33,33 @@ function checkIndexTags (html: string, title: string, description: string, css:
|
||||||
|
|
||||||
describe('Test a client controllers', function () {
|
describe('Test a client controllers', function () {
|
||||||
let server: ServerInfo
|
let server: ServerInfo
|
||||||
let videoPlaylist: MVideoPlaylist
|
let account: Account
|
||||||
let account: MAccount
|
|
||||||
let videoChannel: MChannel
|
const videoName = 'my super name for server 1'
|
||||||
const name = 'my super name for server 1'
|
const videoDescription = 'my super description for server 1'
|
||||||
const description = 'my super description for server 1'
|
|
||||||
|
const playlistName = 'super playlist name'
|
||||||
|
const playlistDescription = 'super playlist description'
|
||||||
|
let playlistUUID: string
|
||||||
|
|
||||||
|
const channelDescription = 'my super channel description'
|
||||||
|
|
||||||
before(async function () {
|
before(async function () {
|
||||||
this.timeout(120000)
|
this.timeout(120000)
|
||||||
|
|
||||||
server = await flushAndRunServer(1)
|
server = await flushAndRunServer(1)
|
||||||
server.accessToken = await serverLogin(server)
|
server.accessToken = await serverLogin(server)
|
||||||
|
await setDefaultVideoChannel([ server ])
|
||||||
|
|
||||||
|
await updateVideoChannel(server.url, server.accessToken, server.videoChannel.name, { description: channelDescription })
|
||||||
|
|
||||||
// Video
|
// Video
|
||||||
|
|
||||||
const videoAttributes = { name, description }
|
const videoAttributes = { name: videoName, description: videoDescription }
|
||||||
|
|
||||||
await uploadVideo(server.url, server.accessToken, videoAttributes)
|
await uploadVideo(server.url, server.accessToken, videoAttributes)
|
||||||
|
|
||||||
const resVideosRequest = await getVideosList(server.url)
|
const resVideosRequest = await getVideosList(server.url)
|
||||||
|
|
||||||
const videos = resVideosRequest.body.data
|
const videos = resVideosRequest.body.data
|
||||||
|
|
||||||
expect(videos.length).to.equal(1)
|
expect(videos.length).to.equal(1)
|
||||||
|
|
||||||
server.video = videos[0]
|
server.video = videos[0]
|
||||||
|
@ -61,39 +67,31 @@ describe('Test a client controllers', function () {
|
||||||
// Playlist
|
// Playlist
|
||||||
|
|
||||||
const playlistAttrs = {
|
const playlistAttrs = {
|
||||||
displayName: name,
|
displayName: playlistName,
|
||||||
description,
|
description: playlistDescription,
|
||||||
privacy: VideoPlaylistPrivacy.PUBLIC
|
privacy: VideoPlaylistPrivacy.PUBLIC,
|
||||||
|
videoChannelId: server.videoChannel.id
|
||||||
}
|
}
|
||||||
|
|
||||||
const resVideoPlaylistRequest = await createVideoPlaylist({ url: server.url, token: server.accessToken, playlistAttrs })
|
const resVideoPlaylistRequest = await createVideoPlaylist({ url: server.url, token: server.accessToken, playlistAttrs })
|
||||||
|
|
||||||
videoPlaylist = resVideoPlaylistRequest.body.videoPlaylist
|
const playlist = resVideoPlaylistRequest.body.videoPlaylist
|
||||||
|
const playlistId = playlist.id
|
||||||
|
playlistUUID = playlist.uuid
|
||||||
|
|
||||||
await addVideoInPlaylist({
|
await addVideoInPlaylist({
|
||||||
url: server.url,
|
url: server.url,
|
||||||
token: server.accessToken,
|
token: server.accessToken,
|
||||||
playlistId: videoPlaylist.id,
|
playlistId,
|
||||||
elementAttrs: { videoId: server.video.id }
|
elementAttrs: { videoId: server.video.id }
|
||||||
})
|
})
|
||||||
|
|
||||||
// Account
|
// Account
|
||||||
|
|
||||||
const resAccountRequest = await getAccount(server.url, `${server.user.username}@${server.host}:${server.port}`)
|
await updateMyUser({ url: server.url, accessToken: server.accessToken, description: 'my account description' })
|
||||||
|
|
||||||
account = resAccountRequest.body.account
|
const resAccountRequest = await getAccount(server.url, `${server.user.username}@${server.host}`)
|
||||||
|
account = resAccountRequest.body
|
||||||
// Channel
|
|
||||||
|
|
||||||
const videoChannelAttributesArg = {
|
|
||||||
name: `${server.user.username}_channel`,
|
|
||||||
displayName: name,
|
|
||||||
description
|
|
||||||
}
|
|
||||||
|
|
||||||
const resChannelRequest = await addVideoChannel(server.url, server.accessToken, videoChannelAttributesArg)
|
|
||||||
|
|
||||||
videoChannel = resChannelRequest.body.videoChannel
|
|
||||||
})
|
})
|
||||||
|
|
||||||
it('Should have valid Open Graph tags on the watch page with video id', async function () {
|
it('Should have valid Open Graph tags on the watch page with video id', async function () {
|
||||||
|
@ -102,8 +100,8 @@ describe('Test a client controllers', function () {
|
||||||
.set('Accept', 'text/html')
|
.set('Accept', 'text/html')
|
||||||
.expect(200)
|
.expect(200)
|
||||||
|
|
||||||
expect(res.text).to.contain(`<meta property="og:title" content="${name}" />`)
|
expect(res.text).to.contain(`<meta property="og:title" content="${videoName}" />`)
|
||||||
expect(res.text).to.contain(`<meta property="og:description" content="${description}" />`)
|
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: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="og:url" content="${server.url}/videos/watch/${server.video.uuid}" />`)
|
||||||
})
|
})
|
||||||
|
@ -114,22 +112,22 @@ describe('Test a client controllers', function () {
|
||||||
.set('Accept', 'text/html')
|
.set('Accept', 'text/html')
|
||||||
.expect(200)
|
.expect(200)
|
||||||
|
|
||||||
expect(res.text).to.contain(`<meta property="og:title" content="${name}" />`)
|
expect(res.text).to.contain(`<meta property="og:title" content="${videoName}" />`)
|
||||||
expect(res.text).to.contain(`<meta property="og:description" content="${description}" />`)
|
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: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="og:url" content="${server.url}/videos/watch/${server.video.uuid}" />`)
|
||||||
})
|
})
|
||||||
|
|
||||||
it('Should have valid Open Graph tags on the watch playlist page', async function () {
|
it('Should have valid Open Graph tags on the watch playlist page', async function () {
|
||||||
const res = await request(server.url)
|
const res = await request(server.url)
|
||||||
.get('/videos/watch/playlist/' + videoPlaylist.uuid)
|
.get('/videos/watch/playlist/' + playlistUUID)
|
||||||
.set('Accept', 'text/html')
|
.set('Accept', 'text/html')
|
||||||
.expect(200)
|
.expect(200)
|
||||||
|
|
||||||
expect(res.text).to.contain(`<meta property="og:title" content="${videoPlaylist.name}" />`)
|
expect(res.text).to.contain(`<meta property="og:title" content="${playlistName}" />`)
|
||||||
expect(res.text).to.contain(`<meta property="og:description" content="${videoPlaylist.description}" />`)
|
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:type" content="video" />')
|
||||||
expect(res.text).to.contain(`<meta property="og:url" content="${server.url}/videos/watch/playlist/${videoPlaylist.uuid}" />`)
|
expect(res.text).to.contain(`<meta property="og:url" content="${server.url}/videos/watch/playlist/${playlistUUID}" />`)
|
||||||
})
|
})
|
||||||
|
|
||||||
it('Should have valid Open Graph tags on the account page', async function () {
|
it('Should have valid Open Graph tags on the account page', async function () {
|
||||||
|
@ -138,7 +136,7 @@ describe('Test a client controllers', function () {
|
||||||
.set('Accept', 'text/html')
|
.set('Accept', 'text/html')
|
||||||
.expect(200)
|
.expect(200)
|
||||||
|
|
||||||
expect(res.text).to.contain(`<meta property="og:title" content="${account.getDisplayName()}" />`)
|
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:description" content="${account.description}" />`)
|
||||||
expect(res.text).to.contain('<meta property="og:type" content="website" />')
|
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(`<meta property="og:url" content="${server.url}/accounts/${server.user.username}" />`)
|
||||||
|
@ -146,14 +144,14 @@ describe('Test a client controllers', function () {
|
||||||
|
|
||||||
it('Should have valid Open Graph tags on the channel page', async function () {
|
it('Should have valid Open Graph tags on the channel page', async function () {
|
||||||
const res = await request(server.url)
|
const res = await request(server.url)
|
||||||
.get('/video-channels/' + videoChannel.name)
|
.get('/video-channels/' + server.videoChannel.name)
|
||||||
.set('Accept', 'text/html')
|
.set('Accept', 'text/html')
|
||||||
.expect(200)
|
.expect(200)
|
||||||
|
|
||||||
expect(res.text).to.contain(`<meta property="og:title" content="${videoChannel.getDisplayName()}" />`)
|
expect(res.text).to.contain(`<meta property="og:title" content="${server.videoChannel.displayName}" />`)
|
||||||
expect(res.text).to.contain(`<meta property="og:description" content="${videoChannel.description}" />`)
|
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:type" content="website" />')
|
||||||
expect(res.text).to.contain(`<meta property="og:url" content="${server.url}/video-channels/${videoChannel.name}" />`)
|
expect(res.text).to.contain(`<meta property="og:url" content="${server.url}/video-channels/${server.videoChannel.name}" />`)
|
||||||
})
|
})
|
||||||
|
|
||||||
it('Should have valid oEmbed discovery tags', async function () {
|
it('Should have valid oEmbed discovery tags', async function () {
|
||||||
|
@ -172,7 +170,7 @@ describe('Test a client controllers', function () {
|
||||||
expect(res.text).to.contain(expectedLink)
|
expect(res.text).to.contain(expectedLink)
|
||||||
})
|
})
|
||||||
|
|
||||||
it('Should have valid twitter card on the whatch video page', async function () {
|
it('Should have valid twitter card on the watch video page', async function () {
|
||||||
const res = await request(server.url)
|
const res = await request(server.url)
|
||||||
.get('/videos/watch/' + server.video.uuid)
|
.get('/videos/watch/' + server.video.uuid)
|
||||||
.set('Accept', 'text/html')
|
.set('Accept', 'text/html')
|
||||||
|
@ -180,20 +178,20 @@ describe('Test a client controllers', function () {
|
||||||
|
|
||||||
expect(res.text).to.contain('<meta property="twitter:card" content="summary_large_image" />')
|
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:site" content="@Chocobozzz" />')
|
||||||
expect(res.text).to.contain(`<meta property="twitter:title" content="${name}" />`)
|
expect(res.text).to.contain(`<meta property="twitter:title" content="${videoName}" />`)
|
||||||
expect(res.text).to.contain(`<meta property="twitter:description" content="${description}" />`)
|
expect(res.text).to.contain(`<meta property="twitter:description" content="${videoDescription}" />`)
|
||||||
})
|
})
|
||||||
|
|
||||||
it('Should have valid twitter card on the watch playlist page', async function () {
|
it('Should have valid twitter card on the watch playlist page', async function () {
|
||||||
const res = await request(server.url)
|
const res = await request(server.url)
|
||||||
.get('/videos/watch/playlist/' + videoPlaylist.uuid)
|
.get('/videos/watch/playlist/' + playlistUUID)
|
||||||
.set('Accept', 'text/html')
|
.set('Accept', 'text/html')
|
||||||
.expect(200)
|
.expect(200)
|
||||||
|
|
||||||
expect(res.text).to.contain('<meta property="twitter:card" content="summary" />')
|
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:site" content="@Chocobozzz" />')
|
||||||
expect(res.text).to.contain(`<meta property="twitter:title" content="${videoPlaylist.name}" />`)
|
expect(res.text).to.contain(`<meta property="twitter:title" content="${playlistName}" />`)
|
||||||
expect(res.text).to.contain(`<meta property="twitter:description" content="${videoPlaylist.description}" />`)
|
expect(res.text).to.contain(`<meta property="twitter:description" content="${playlistDescription}" />`)
|
||||||
})
|
})
|
||||||
|
|
||||||
it('Should have valid twitter card on the account page', async function () {
|
it('Should have valid twitter card on the account page', async function () {
|
||||||
|
@ -210,14 +208,14 @@ describe('Test a client controllers', function () {
|
||||||
|
|
||||||
it('Should have valid twitter card on the channel page', async function () {
|
it('Should have valid twitter card on the channel page', async function () {
|
||||||
const res = await request(server.url)
|
const res = await request(server.url)
|
||||||
.get('/video-channels/' + videoChannel.name)
|
.get('/video-channels/' + server.videoChannel.name)
|
||||||
.set('Accept', 'text/html')
|
.set('Accept', 'text/html')
|
||||||
.expect(200)
|
.expect(200)
|
||||||
|
|
||||||
expect(res.text).to.contain('<meta property="twitter:card" content="summary" />')
|
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:site" content="@Chocobozzz" />')
|
||||||
expect(res.text).to.contain(`<meta property="twitter:title" content="${videoChannel.name}" />`)
|
expect(res.text).to.contain(`<meta property="twitter:title" content="${server.videoChannel.displayName}" />`)
|
||||||
expect(res.text).to.contain(`<meta property="twitter:description" content="${videoChannel.description}" />`)
|
expect(res.text).to.contain(`<meta property="twitter:description" content="${channelDescription}" />`)
|
||||||
})
|
})
|
||||||
|
|
||||||
it('Should have valid twitter card if Twitter is whitelisted', async function () {
|
it('Should have valid twitter card if Twitter is whitelisted', async function () {
|
||||||
|
@ -238,11 +236,11 @@ describe('Test a client controllers', function () {
|
||||||
expect(resVideoRequest.text).to.contain('<meta property="twitter:site" content="@Kuja" />')
|
expect(resVideoRequest.text).to.contain('<meta property="twitter:site" content="@Kuja" />')
|
||||||
|
|
||||||
const resVideoPlaylistRequest = await request(server.url)
|
const resVideoPlaylistRequest = await request(server.url)
|
||||||
.get('/videos/watch/playlist/' + videoPlaylist.uuid)
|
.get('/videos/watch/playlist/' + playlistUUID)
|
||||||
.set('Accept', 'text/html')
|
.set('Accept', 'text/html')
|
||||||
.expect(200)
|
.expect(200)
|
||||||
|
|
||||||
expect(resVideoPlaylistRequest.text).to.contain('<meta property="twitter:card" content="player" />')
|
expect(resVideoPlaylistRequest.text).to.contain('<meta property="twitter:card" content="summary" />')
|
||||||
expect(resVideoPlaylistRequest.text).to.contain('<meta property="twitter:site" content="@Kuja" />')
|
expect(resVideoPlaylistRequest.text).to.contain('<meta property="twitter:site" content="@Kuja" />')
|
||||||
|
|
||||||
const resAccountRequest = await request(server.url)
|
const resAccountRequest = await request(server.url)
|
||||||
|
@ -250,15 +248,15 @@ describe('Test a client controllers', function () {
|
||||||
.set('Accept', 'text/html')
|
.set('Accept', 'text/html')
|
||||||
.expect(200)
|
.expect(200)
|
||||||
|
|
||||||
expect(resAccountRequest.text).to.contain('<meta property="twitter:card" content="player" />')
|
expect(resAccountRequest.text).to.contain('<meta property="twitter:card" content="summary" />')
|
||||||
expect(resAccountRequest.text).to.contain('<meta property="twitter:site" content="@Kuja" />')
|
expect(resAccountRequest.text).to.contain('<meta property="twitter:site" content="@Kuja" />')
|
||||||
|
|
||||||
const resChannelRequest = await request(server.url)
|
const resChannelRequest = await request(server.url)
|
||||||
.get('/video-channels/' + videoChannel.name)
|
.get('/video-channels/' + server.videoChannel.name)
|
||||||
.set('Accept', 'text/html')
|
.set('Accept', 'text/html')
|
||||||
.expect(200)
|
.expect(200)
|
||||||
|
|
||||||
expect(resChannelRequest.text).to.contain('<meta property="twitter:card" content="player" />')
|
expect(resChannelRequest.text).to.contain('<meta property="twitter:card" content="summary" />')
|
||||||
expect(resChannelRequest.text).to.contain('<meta property="twitter:site" content="@Kuja" />')
|
expect(resChannelRequest.text).to.contain('<meta property="twitter:site" content="@Kuja" />')
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue