84 lines
2.2 KiB
TypeScript
84 lines
2.2 KiB
TypeScript
/* eslint-disable @typescript-eslint/no-unused-expressions,@typescript-eslint/require-await */
|
|
|
|
import 'mocha'
|
|
import * as chai from 'chai'
|
|
import {
|
|
cleanupTests,
|
|
flushAndRunServer,
|
|
getPluginsCSS,
|
|
installPlugin,
|
|
makeHTMLRequest,
|
|
ServerInfo,
|
|
setAccessTokensToServers,
|
|
uninstallPlugin
|
|
} from '../../../shared/extra-utils'
|
|
|
|
const expect = chai.expect
|
|
|
|
describe('Test plugins HTML inection', function () {
|
|
let server: ServerInfo = null
|
|
|
|
before(async function () {
|
|
this.timeout(30000)
|
|
|
|
server = await flushAndRunServer(1)
|
|
await setAccessTokensToServers([ server ])
|
|
})
|
|
|
|
it('Should not inject global css file in HTML', async function () {
|
|
{
|
|
const res = await getPluginsCSS(server.url)
|
|
expect(res.text).to.be.empty
|
|
}
|
|
|
|
for (const path of [ '/', '/videos/embed/1', '/video-playlists/embed/1' ]) {
|
|
const res = await makeHTMLRequest(server.url, path)
|
|
expect(res.text).to.not.include('link rel="stylesheet" href="/plugins/global.css')
|
|
}
|
|
})
|
|
|
|
it('Should install a plugin and a theme', async function () {
|
|
this.timeout(30000)
|
|
|
|
await installPlugin({
|
|
url: server.url,
|
|
accessToken: server.accessToken,
|
|
npmName: 'peertube-plugin-hello-world'
|
|
})
|
|
})
|
|
|
|
it('Should have the correct global css', async function () {
|
|
{
|
|
const res = await getPluginsCSS(server.url)
|
|
expect(res.text).to.contain('background-color: red')
|
|
}
|
|
|
|
for (const path of [ '/', '/videos/embed/1', '/video-playlists/embed/1' ]) {
|
|
const res = await makeHTMLRequest(server.url, path)
|
|
expect(res.text).to.include('link rel="stylesheet" href="/plugins/global.css')
|
|
}
|
|
})
|
|
|
|
it('Should have an empty global css on uninstall', async function () {
|
|
await uninstallPlugin({
|
|
url: server.url,
|
|
accessToken: server.accessToken,
|
|
npmName: 'peertube-plugin-hello-world'
|
|
})
|
|
|
|
{
|
|
const res = await getPluginsCSS(server.url)
|
|
expect(res.text).to.be.empty
|
|
}
|
|
|
|
for (const path of [ '/', '/videos/embed/1', '/video-playlists/embed/1' ]) {
|
|
const res = await makeHTMLRequest(server.url, path)
|
|
expect(res.text).to.not.include('link rel="stylesheet" href="/plugins/global.css')
|
|
}
|
|
})
|
|
|
|
after(async function () {
|
|
await cleanupTests([ server ])
|
|
})
|
|
})
|