mirror of
https://github.com/verdaccio/verdaccio.git
synced 2024-11-13 03:35:52 +01:00
45c03819e2
* refactor: render middleware * refactor: render middleware
75 lines
1.7 KiB
TypeScript
75 lines
1.7 KiB
TypeScript
import template from '../src/middlewares/web/utils/template';
|
|
|
|
const manifest = require('./partials/manifest/manifest.json');
|
|
|
|
const exampleManifest = {
|
|
css: ['main.css'],
|
|
js: ['runtime.js', 'main.js'],
|
|
ico: '/static/foo.ico',
|
|
};
|
|
|
|
describe('template', () => {
|
|
test('custom render', () => {
|
|
expect(
|
|
template({ options: { base: 'http://domain.com' }, manifest: exampleManifest }, manifest)
|
|
).toMatchSnapshot();
|
|
});
|
|
|
|
test('custom title', () => {
|
|
expect(
|
|
template(
|
|
{ options: { base: 'http://domain.com', title: 'foo title' }, manifest: exampleManifest },
|
|
manifest
|
|
)
|
|
).toMatchSnapshot();
|
|
});
|
|
|
|
test('custom title', () => {
|
|
expect(
|
|
template(
|
|
{ options: { base: 'http://domain.com', title: 'foo title' }, manifest: exampleManifest },
|
|
manifest
|
|
)
|
|
).toMatchSnapshot();
|
|
});
|
|
|
|
test('meta scripts', () => {
|
|
expect(
|
|
template(
|
|
{
|
|
options: { base: 'http://domain.com' },
|
|
metaScripts: [`<style>.someclass{font-size:10px;}</style>`],
|
|
manifest: exampleManifest,
|
|
},
|
|
manifest
|
|
)
|
|
).toMatchSnapshot();
|
|
});
|
|
|
|
test('custom body after', () => {
|
|
expect(
|
|
template(
|
|
{
|
|
options: { base: 'http://domain.com' },
|
|
scriptsBodyAfter: [`<script src="foo"/>`],
|
|
manifest: exampleManifest,
|
|
},
|
|
manifest
|
|
)
|
|
).toMatchSnapshot();
|
|
});
|
|
|
|
test('custom body before', () => {
|
|
expect(
|
|
template(
|
|
{
|
|
options: { base: 'http://domain.com' },
|
|
scriptsbodyBefore: [`<script src="fooBefore"/>`, `<script src="barBefore"/>`],
|
|
manifest: exampleManifest,
|
|
},
|
|
manifest
|
|
)
|
|
).toMatchSnapshot();
|
|
});
|
|
});
|