3 namespace Tests\Settings;
5 use BookStack\Util\CspService;
8 class CustomHeadContentTest extends TestCase
10 public function test_configured_content_shows_on_pages()
12 $this->setSettings(['app-custom-head' => '<script>console.log("cat");</script>']);
13 $resp = $this->get('/login');
14 $resp->assertSee('console.log("cat")');
17 public function test_configured_content_does_not_show_on_settings_page()
19 $this->setSettings(['app-custom-head' => '<script>console.log("cat");</script>']);
20 $resp = $this->asAdmin()->get('/settings');
21 $resp->assertDontSee('console.log("cat")');
24 public function test_divs_in_js_preserved_in_configured_content()
26 $this->setSettings(['app-custom-head' => '<script><div id="hello">cat</div></script>']);
27 $resp = $this->get('/login');
28 $resp->assertSee('<div id="hello">cat</div>');
31 public function test_nonce_application_handles_edge_cases()
33 $mockCSP = $this->mock(CspService::class);
34 $mockCSP->shouldReceive('getNonce')->andReturn('abc123');
37 <script>console.log("cat");</script>
38 <script type="text/html"><\script>const a = `<div></div>`<\/\script></script>
39 <script >const a = `<div></div>`;</script>
40 <script type="<script text>test">const c = `<div></div>`;</script>
44 const a = `<\script><\/script>`;
47 <SCRIPT>const b = `↗️£`;</SCRIPT>
50 $expectedOutput = trim('
51 <script nonce="abc123">console.log("cat");</script>
52 <script type="text/html" nonce="abc123"><\script>const a = `<div></div>`<\/\script></script>
53 <script nonce="abc123">const a = `<div></div>`;</script>
54 <script type="<script text>test" nonce="abc123">const c = `<div></div>`;</script>
55 <script type="text/html" nonce="abc123">
56 const a = `<\script><\/script>`;
59 <script nonce="abc123">const b = `↗️£`;</script>
62 $this->setSettings(['app-custom-head' => $content]);
63 $resp = $this->get('/login');
64 $resp->assertSee($expectedOutput);