X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=server%2Ftests%2Fclient.ts;h=bcbac86e9b9709a45cc94860d81faa66e485cf00;hb=2769e297ca6703f761f9b57792585eb1fc5aac49;hp=2be1cf5dda44919c4dbc51829ec1ca274b84713d;hpb=eec63bbc0f4fdb39e56f37127b35c449f90a135f;p=github%2FChocobozzz%2FPeerTube.git
diff --git a/server/tests/client.ts b/server/tests/client.ts
index 2be1cf5dd..bcbac86e9 100644
--- a/server/tests/client.ts
+++ b/server/tests/client.ts
@@ -11,8 +11,15 @@ import {
runServer,
serverLogin,
uploadVideo,
- getVideosList
+ getVideosList, updateCustomConfig, getCustomConfig, killallServers, makeHTMLRequest
} from './utils'
+import { CustomConfig } from '../../shared/models/server/custom-config.model'
+
+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
@@ -73,12 +80,106 @@ describe('Test a client controllers', function () {
expect(res.text).to.contain(expectedLink)
})
- after(async function () {
- process.kill(-server.app.pid)
+ 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('')
+ })
+
+ 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')
- // Keep the logs if the test failed
- if (this['ok']) {
- await flushTests()
+ 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 () {
+ const newCustomConfig: CustomConfig = {
+ instance: {
+ name: 'PeerTube updated',
+ shortDescription: 'my short description',
+ description: 'my super description',
+ terms: 'my super terms',
+ defaultClientRoute: '/videos/recently-added',
+ defaultNSFWPolicy: 'blur' as 'blur',
+ customizations: {
+ javascript: 'alert("coucou")',
+ css: 'body { background-color: red; }'
+ }
+ },
+ services: {
+ twitter: {
+ username: '@Kuja',
+ whitelisted: true
+ }
+ },
+ cache: {
+ previews: {
+ size: 2
+ },
+ captions: {
+ size: 3
+ }
+ },
+ signup: {
+ enabled: false,
+ limit: 5
+ },
+ admin: {
+ email: 'superadmin1@example.com'
+ },
+ user: {
+ videoQuota: 5242881
+ },
+ transcoding: {
+ enabled: true,
+ threads: 1,
+ resolutions: {
+ '240p': false,
+ '360p': true,
+ '480p': true,
+ '720p': false,
+ '1080p': false
+ }
+ }
}
+ await updateCustomConfig(server.url, server.accessToken, newCustomConfig)
+
+ 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 ])
})
})