wiki.techinc.nl/tests/phpunit/unit/includes/resourceloader/VueComponentParserTest.php
Timo Tijhof 8d406bbcd6 phpcs: Disable Generic.Files.LineLength for test files
There is a common and reasonable need for longer lines in tests.
The nudge for shorter lines doesn't seem valuable here. The natural
breaks will likely still fall in 80-100 given the enforced practice
for non-test code, e.g. whether through habit, or 80-100 column markers
in text editors, or the finite width of diff and code review
interfaces.

Change-Id: I879479e13551789a67624ce66f0946d2f185e6ee
2022-02-18 18:32:05 +00:00

344 lines
9.2 KiB
PHP

<?php
/**
* @group ResourceLoader
* @covers VueComponentParser
*/
class VueComponentParserTest extends PHPUnit\Framework\TestCase {
/**
* @dataProvider provideTestParse
*/
public function testParse( $html, $minify, $expectedResult, $message, $expectedException = '' ) {
$parser = new VueComponentParser;
if ( $expectedException !== '' ) {
$this->expectExceptionMessage( $expectedException );
}
$actualResult = $parser->parse( $html, [ 'minifyTemplate' => $minify ] );
$this->assertEquals( $expectedResult, $actualResult, $message );
}
public static function provideTestParse() {
return [
[
'<template><p>{{foo}}</p></template><script>bar</script><style>baz</style>',
false,
[
'script' => 'bar',
'template' => '<p>{{foo}}</p>',
'style' => 'baz',
'styleLang' => 'css',
],
'Basic test'
],
[
'<template><p>{{foo}}</p></template><style>baz</style>',
false,
null,
'Missing <script> tag',
'No <script> tag found',
],
[
'<script>bar</script><style>baz</style>',
false,
null,
'Missing <template> tag',
'No <template> tag found',
],
[
'<template><p>{{foo}}</p></template><script>bar</script>',
false,
[
'script' => 'bar',
'template' => '<p>{{foo}}</p>',
'style' => null,
'styleLang' => null,
],
'Missing <style> tag'
],
[
'<template><p>{{foo}}</p></template><template><p>{{quux}}</p></template><script>bar</script>',
false,
null,
'Two template tags',
'More than one <template> tag found'
],
[
'<template><p>{{foo}}</p></template><script>bar</script><script>quux</script>',
false,
null,
'Two script tags',
'More than one <script> tag found'
],
[
'<template><p>{{foo}}</p></template><script>bar</script><style>baz</style><style>quux</style>',
false,
null,
'Two style tags',
'More than one <style> tag found'
],
[
'<template></template><script>bar</script><style>baz</style>',
false,
[
'script' => 'bar',
'template' => '',
'style' => 'baz',
'styleLang' => 'css',
],
'Empty <template> tag',
],
[
'<template><p>{{foo}}</p><p></p></template><script>bar</script>',
false,
[
'script' => 'bar',
'template' => '<p>{{foo}}</p><p></p>',
'style' => null,
'styleLang' => null,
],
'Template with two root nodes',
],
[
'<template><!-- Explanation --><p>{{foo}}</p></template><script>bar</script>',
false,
[
'script' => 'bar',
'template' => '<!-- Explanation --><p>{{foo}}</p>',
'style' => null,
'styleLang' => null,
],
'Template with comment outside: comment preserved when not minifiying',
],
[
'<template><!-- Explanation --><p>{{foo}}</p></template><script>bar</script>',
true,
[
'script' => 'bar',
'template' => '<p>{{foo}}</p>',
'style' => null,
'styleLang' => null,
],
'Template with comment outside: comment removed when minifiying',
],
[
'<template><p><!-- Explanation -->{{foo}}</p></template><script>bar</script>',
false,
[
'script' => 'bar',
'template' => '<p><!-- Explanation -->{{foo}}</p>',
'style' => null,
'styleLang' => null,
],
'Template with comment inside: comment preserved when not minifying',
],
[
'<template><p><!-- Explanation -->{{foo}}</p></template><script>bar</script>',
true,
[
'script' => 'bar',
'template' => '<p>{{foo}}</p>',
'style' => null,
'styleLang' => null,
],
'Template with comment inside: comment removed when minifying',
],
[
'<!-- Explanation --><template><p>{{foo}}</p></template><script>bar</script>',
true,
[
'script' => 'bar',
'template' => '<p>{{foo}}</p>',
'style' => null,
'styleLang' => null,
],
'Comment before template tag',
],
[
"<template>\n\t<div>\t\t<div> {{foo}}\n{{bar}} </div>\n\t</div>\n</template><script>blah</script>",
false,
[
'script' => 'blah',
'template' => "<div>\t\t<div> {{foo}}\n{{bar}} </div>\n\t</div>",
'style' => null,
'styleLang' => null,
],
'Whitespace in <template> tag is preserved when not minifying',
],
[
"<template>\n\t<div>\t\t<div> {{foo}}\n{{bar}} </div>\n\t</div>\n</template><script>blah</script>",
true,
[
'script' => 'blah',
'template' => "<div><div>{{foo}} {{bar}}</div></div>",
'style' => null,
'styleLang' => null,
],
'Whitespace in <template> tag is stripped and collapsed when minifying',
],
[
"<template>\n\t<div>\t\t<pre> {{foo}}\n{{bar}} </pre>\n\t</div>\n</template><script>blah</script>",
true,
[
'script' => 'blah',
'template' => "<div><pre> {{foo}}\n{{bar}} </pre></div>",
'style' => null,
'styleLang' => null,
],
'Whitespace stripping and collapsing skips <pre> tags',
],
[
"<template>\n\t<div>\t\t<pre>\n {{foo}}\n{{bar}} </pre>\n\t</div>\n</template><script>blah</script>",
false,
[
'script' => 'blah',
'template' => "<div>\t\t<pre> {{foo}}\n{{bar}} </pre>\n\t</div>",
'style' => null,
'styleLang' => null,
],
'Single leading newline in <pre> is removed when not minifying',
],
[
"<template>\n\t<div>\t\t<pre>\n {{foo}}\n{{bar}} </pre>\n\t</div>\n</template><script>blah</script>",
true,
[
'script' => 'blah',
'template' => "<div><pre> {{foo}}\n{{bar}} </pre></div>",
'style' => null,
'styleLang' => null,
],
'Single leading newline in <pre> is removed when minifying',
],
[
"<template>\n\t<div>\t\t<pre>\n\n {{foo}}\n{{bar}} </pre>\n\t</div>\n</template><script>blah</script>",
false,
[
'script' => 'blah',
'template' => "<div>\t\t<pre>\n\n {{foo}}\n{{bar}} </pre>\n\t</div>",
'style' => null,
'styleLang' => null,
],
'Double leading newline in <pre> is preserved when not minifying',
],
[
"<template>\n\t<div>\t\t<pre>\n\n {{foo}}\n{{bar}} </pre>\n\t</div>\n</template><script>blah</script>",
true,
[
'script' => 'blah',
'template' => "<div><pre>\n\n {{foo}}\n{{bar}} </pre></div>",
'style' => null,
'styleLang' => null,
],
'Double leading newline in <pre> is preserved when minifying',
],
[
"<template><a>!!!</a></template><script>var x = '<a>!!!</a>';</script>",
false,
[
'script' => "var x = '<a>!!!</a>';",
'template' => "<a>!!!</a>",
'style' => null,
'styleLang' => null,
],
'Script tag with HTML string'
],
[
'<template><p>{{foo}}</p></template><script>bar</script><style lang="less">baz</style>',
false,
[
'script' => 'bar',
'template' => '<p>{{foo}}</p>',
'style' => 'baz',
'styleLang' => 'less',
],
'Style tag with lang="less"',
],
[
'<template><p>{{foo}}</p></template><script>bar</script><style lang="quux">baz</style>',
false,
null,
'Style tag with invalid language',
'<style lang="quux"> is invalid, lang must be "css" or "less"',
],
[
'<template><p>{{foo}}</p></template><script>bar</script><style scoped>baz</style>',
false,
null,
'Scoped style tag',
'<style> may not have the scoped attribute',
],
[
'<template><p>{{foo}}</p></template><script>bar</script><style lang="less" scoped>baz</style>',
false,
null,
'Scoped style tag with lang="less"',
'<style> may not have the scoped attribute',
],
[
'<template><p>{{foo}}</p></template><script>bar</script><style module>baz</style>',
false,
null,
'<style module> tag',
'<style> may not have the module attribute',
],
[
'<template functional><p>{{foo}}</p></template><script>bar</script><style>baz</style>',
false,
null,
'<template functional> tag',
'<template> may not have any attributes'
],
[
'<template><p>{{foo}}</p></template><script foo>bar</script><style>baz</style>',
false,
null,
'<script> tag with attribute',
'<script> may not have any attributes'
],
[
'<template><p :class="classObj">{{foo}}</p></template><script>bar</script>',
false,
[
'script' => 'bar',
'template' => '<p :class="classObj">{{foo}}</p>',
'style' => null,
'styleLang' => null,
],
'Attribute with : in the name'
],
[
'<template><a @click="onClick">{{foo}}</a></template><script>bar</script>',
false,
[
'script' => 'bar',
'template' => '<a @click="onClick">{{foo}}</a>',
'style' => null,
'styleLang' => null,
],
'Attribute with @ in the name'
],
[
'<template><div><template #header></template><template #footer="foo"></template></div></template><script>bar</script>',
false,
[
'script' => 'bar',
'template' => '<div><template #header=""></template><template #footer="foo"></template></div>',
'style' => null,
'styleLang' => null,
],
'Attribute with # in the name'
],
[
'<template><p><mw-button /><mw-blah>foo</mw-blah></p></template><script>bar</script>',
false,
[
'script' => 'bar',
'template' => '<p><mw-button><mw-blah>foo</mw-blah></mw-button></p>',
'style' => null,
'styleLang' => null,
],
'Template with self-closing tag (broken)'
],
];
// phpcs:enable
}
}