X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=server%2Ftests%2Fclient.ts;h=b33a653b13e2079f0bc6ef3980085fcb8fd347a5;hb=993cef4b6e000ee425087e5195dfe40cd0840243;hp=5e5abba5aa1277e3de9528c1b02aa1546099722f;hpb=0e1dc3e7c69995c691e1dd82e3c2bc68748661ca;p=github%2FChocobozzz%2FPeerTube.git
diff --git a/server/tests/client.ts b/server/tests/client.ts
index 5e5abba5a..b33a653b1 100644
--- a/server/tests/client.ts
+++ b/server/tests/client.ts
@@ -3,17 +3,28 @@
import 'mocha'
import * as chai from 'chai'
import * as request from 'supertest'
-const expect = chai.expect
-
import {
- ServerInfo,
flushTests,
+ getCustomConfig,
+ getVideosList,
+ killallServers,
+ makeHTMLRequest,
runServer,
- loginAndGetAccessToken,
- uploadVideo,
- getVideosList
+ ServerInfo,
+ serverLogin,
+ updateCustomConfig,
+ updateCustomSubConfig,
+ uploadVideo
} from './utils'
+const expect = chai.expect
+
+function checkIndexTags (html: string, title: string, description: string, css: string) {
+ expect(html).to.contain('
' + title + '')
+ expect(html).to.contain('')
+ expect(html).to.contain('')
+}
+
describe('Test a client controllers', function () {
let server: ServerInfo
@@ -23,11 +34,11 @@ describe('Test a client controllers', function () {
await flushTests()
server = await runServer(1)
- server.accessToken = await loginAndGetAccessToken(server)
+ server.accessToken = await serverLogin(server)
const videoAttributes = {
- name: 'my super name for pod 1',
- description: 'my super description for pod 1'
+ name: 'my super name for server 1',
+ description: 'my super description for server 1'
}
await uploadVideo(server.url, server.accessToken, videoAttributes)
@@ -39,30 +50,104 @@ describe('Test a client controllers', function () {
server.video = videos[0]
})
- it('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 () {
const res = await request(server.url)
- .get('/videos/watch/' + server.video.id)
- .expect(200)
+ .get('/videos/watch/' + server.video.id)
+ .set('Accept', 'text/html')
+ .expect(200)
- expect(res.text).to.contain('')
- expect(res.text).to.contain('')
+ expect(res.text).to.contain('')
+ expect(res.text).to.contain('')
})
- it('It should have valid Open Graph tags on the watch page with video uuid', async function () {
+ 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)
- .expect(200)
+ .get('/videos/watch/' + server.video.uuid)
+ .set('Accept', 'text/html')
+ .expect(200)
- expect(res.text).to.contain('')
- expect(res.text).to.contain('')
+ expect(res.text).to.contain('')
+ expect(res.text).to.contain('')
})
- after(async function () {
- process.kill(-server.app.pid)
+ 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)
+
+ const expectedLink = '`
+
+ expect(res.text).to.contain(expectedLink)
+ })
+
+ it('Should have valid twitter card', 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('')
+ expect(res.text).to.contain('')
+ })
- // Keep the logs if the test failed
- if (this['ok']) {
- await flushTests()
+ 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)
+
+ const res = await request(server.url)
+ .get('/videos/watch/' + server.video.uuid)
+ .set('Accept', 'text/html')
+ .expect(200)
+
+ expect(res.text).to.contain('')
+ expect(res.text).to.contain('')
+ })
+
+ it('Should have valid index html tags (title, description...)', async function () {
+ const res = await makeHTMLRequest(server.url, '/videos/trending')
+
+ const description = 'PeerTube, a federated (ActivityPub) video streaming platform using P2P (BitTorrent) directly in the web browser ' +
+ 'with WebTorrent and Angular.'
+ checkIndexTags(res.text, 'PeerTube', description, '')
+ })
+
+ 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; }'
+ }
+ }
+ })
+
+ 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')
+
+ checkIndexTags(res.text, 'PeerTube updated', 'my short description', 'body { background-color: red; }')
+ })
+
+ after(async function () {
+ killallServers([ server ])
})
})