2024-09-29 16:03:29 +02:00
|
|
|
import { describe, expect, test } from 'vitest';
|
|
|
|
|
2023-02-12 20:26:18 +01:00
|
|
|
import template from '../src/middlewares/web/utils/template';
|
2021-10-29 17:33:05 +02:00
|
|
|
|
2021-03-06 18:56:45 +01:00
|
|
|
const manifest = require('./partials/manifest/manifest.json');
|
|
|
|
|
2024-07-30 17:20:18 -04:00
|
|
|
// manifest expected to have leading slash
|
|
|
|
// see packages\middleware\test\partials\manifest\manifest.json
|
2021-03-06 18:56:45 +01:00
|
|
|
const exampleManifest = {
|
|
|
|
css: ['main.css'],
|
|
|
|
js: ['runtime.js', 'main.js'],
|
2024-07-30 17:20:18 -04:00
|
|
|
ico: 'favicon.ico',
|
2021-03-06 18:56:45 +01:00
|
|
|
};
|
|
|
|
|
2024-07-30 17:20:18 -04:00
|
|
|
// "base" is expected to be result of getPublicUrl
|
|
|
|
// i.e. it must be valid URL with trailing slash
|
2021-03-06 18:56:45 +01:00
|
|
|
describe('template', () => {
|
|
|
|
test('custom render', () => {
|
2021-04-02 15:59:47 +02:00
|
|
|
expect(
|
2024-07-30 17:20:18 -04:00
|
|
|
template({ options: { base: 'http://domain.com/' }, manifest: exampleManifest }, manifest)
|
2021-04-02 15:59:47 +02:00
|
|
|
).toMatchSnapshot();
|
2021-03-06 18:56:45 +01:00
|
|
|
});
|
|
|
|
|
|
|
|
test('custom title', () => {
|
|
|
|
expect(
|
2021-04-02 15:59:47 +02:00
|
|
|
template(
|
2024-07-30 17:20:18 -04:00
|
|
|
{ options: { base: 'http://domain.com/', title: 'foo title' }, manifest: exampleManifest },
|
2021-04-02 15:59:47 +02:00
|
|
|
manifest
|
|
|
|
)
|
|
|
|
).toMatchSnapshot();
|
|
|
|
});
|
|
|
|
|
|
|
|
test('meta scripts', () => {
|
|
|
|
expect(
|
|
|
|
template(
|
|
|
|
{
|
2024-07-30 17:20:18 -04:00
|
|
|
options: { base: 'http://domain.com/' },
|
2021-04-02 15:59:47 +02:00
|
|
|
metaScripts: [`<style>.someclass{font-size:10px;}</style>`],
|
|
|
|
manifest: exampleManifest,
|
|
|
|
},
|
|
|
|
manifest
|
|
|
|
)
|
2021-03-06 18:56:45 +01:00
|
|
|
).toMatchSnapshot();
|
|
|
|
});
|
|
|
|
|
|
|
|
test('custom body after', () => {
|
|
|
|
expect(
|
2021-04-02 15:59:47 +02:00
|
|
|
template(
|
|
|
|
{
|
2024-07-30 17:20:18 -04:00
|
|
|
options: { base: 'http://domain.com/' },
|
2021-04-02 15:59:47 +02:00
|
|
|
scriptsBodyAfter: [`<script src="foo"/>`],
|
|
|
|
manifest: exampleManifest,
|
|
|
|
},
|
|
|
|
manifest
|
|
|
|
)
|
2021-03-06 18:56:45 +01:00
|
|
|
).toMatchSnapshot();
|
|
|
|
});
|
|
|
|
|
|
|
|
test('custom body before', () => {
|
|
|
|
expect(
|
|
|
|
template(
|
|
|
|
{
|
2024-07-30 17:20:18 -04:00
|
|
|
options: { base: 'http://domain.com/' },
|
2021-04-02 15:59:47 +02:00
|
|
|
scriptsbodyBefore: [`<script src="fooBefore"/>`, `<script src="barBefore"/>`],
|
2021-03-06 18:56:45 +01:00
|
|
|
manifest: exampleManifest,
|
|
|
|
},
|
|
|
|
manifest
|
|
|
|
)
|
|
|
|
).toMatchSnapshot();
|
|
|
|
});
|
|
|
|
});
|