/* eslint-disable @typescript-eslint/no-unused-expressions,@typescript-eslint/require-await */ import { expect } from 'chai' import { cleanupTests, createSingleServer, makeHTMLRequest, PeerTubeServer, PluginsCommand, setAccessTokensToServers } from '@shared/server-commands' describe('Test plugins HTML injection', function () { let server: PeerTubeServer = null let command: PluginsCommand before(async function () { this.timeout(30000) server = await createSingleServer(1) await setAccessTokensToServers([ server ]) command = server.plugins }) it('Should not inject global css file in HTML', async function () { { const text = await command.getCSS() expect(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 command.install({ npmName: 'peertube-plugin-hello-world' }) }) it('Should have the correct global css', async function () { { const text = await command.getCSS() expect(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 command.uninstall({ npmName: 'peertube-plugin-hello-world' }) { const text = await command.getCSS() expect(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 ]) }) })