18 use TYPO3\TestingFramework\Fluid\Unit\ViewHelpers\ViewHelperBaseTestcase;
30 protected function setUp()
34 $this->injectDependenciesIntoViewHelper($this->viewHelper);
42 $this->setArgumentsUnderTest(
48 $actualResult = $this->viewHelper->initializeArgumentsAndRender();
49 $this->assertEquals(
'Source', $actualResult);
57 $this->setArgumentsUnderTest(
64 $actualResult = $this->viewHelper->initializeArgumentsAndRender();
65 $this->assertEquals(
'Source', $actualResult);
73 $source =
'StringWithoutSpecialCharacters';
75 $this->setArgumentsUnderTest(
81 $actualResult = $this->viewHelper->initializeArgumentsAndRender();
82 $this->assertSame($source, $actualResult);
90 $source =
'Foo @+%/ "';
91 $expectedResult =
'Foo%20%40%2B%25%2F%20%22';
93 $this->setArgumentsUnderTest(
100 $actualResult = $this->viewHelper->initializeArgumentsAndRender();
101 $this->assertEquals($expectedResult, $actualResult);
116 $this->setArgumentsUnderTest(
122 $actualResult = $this->viewHelper->render();
123 $this->assertSame($expectation, $actualResult);
131 $stdClass = new \stdClass();
132 $toStringClass =
new class() {
133 public function __toString(): string
135 return '<script>alert(\'"xss"\')</script>';
140 'plain object' => [$stdClass, $stdClass],
141 'object with __toString()' => [$toStringClass,
'%3Cscript%3Ealert%28%27%22xss%22%27%29%3C%2Fscript%3E'],