X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=server%2Ftests%2Fclient.ts;h=670bc67016927c9541c157822ea85b362c5e0bd7;hb=1fdf8edb77008133e80e5ab8e846b7f8fdfecf12;hp=2be1cf5dda44919c4dbc51829ec1ca274b84713d;hpb=eec63bbc0f4fdb39e56f37127b35c449f90a135f;p=github%2FChocobozzz%2FPeerTube.git
diff --git a/server/tests/client.ts b/server/tests/client.ts
index 2be1cf5dd..670bc6701 100644
--- a/server/tests/client.ts
+++ b/server/tests/client.ts
@@ -1,18 +1,28 @@
-/* tslint:disable:no-unused-expression */
+/* eslint-disable @typescript-eslint/no-unused-expressions,@typescript-eslint/require-await */
import 'mocha'
import * as chai from 'chai'
import * as request from 'supertest'
-const expect = chai.expect
-
import {
+ cleanupTests,
+ flushAndRunServer,
+ getCustomConfig,
+ getVideosList,
+ makeHTMLRequest,
ServerInfo,
- flushTests,
- runServer,
serverLogin,
- uploadVideo,
- getVideosList
-} from './utils'
+ updateCustomConfig,
+ updateCustomSubConfig,
+ uploadVideo
+} from '../../shared/extra-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
@@ -20,9 +30,7 @@ describe('Test a client controllers', function () {
before(async function () {
this.timeout(120000)
- await flushTests()
-
- server = await runServer(1)
+ server = await flushAndRunServer(1)
server.accessToken = await serverLogin(server)
const videoAttributes = {
@@ -73,12 +81,69 @@ 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)
- // Keep the logs if the test failed
- if (this['ok']) {
- await flushTests()
+ 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')
+
+ const description = 'PeerTube, an ActivityPub-federated video streaming platform using P2P directly in your web browser.'
+ 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 () {
+ await cleanupTests([ server ])
})
})