X-Git-Url: http://source.bookstackapp.com/bookstack/blobdiff_plain/0627efe5e9f3ec5ef7182637e8d6a47934b3d1ab..refs/pull/2902/head:/tests/Entity/PageContentTest.php diff --git a/tests/Entity/PageContentTest.php b/tests/Entity/PageContentTest.php index 1b3af97c7..5aee97887 100644 --- a/tests/Entity/PageContentTest.php +++ b/tests/Entity/PageContentTest.php @@ -1,7 +1,9 @@ -id)->first(); + $page = Page::query()->first(); + $secondPage = Page::query()->where('id', '!=', $page->id)->first(); $secondPage->html = "

Hello, This is a test

This is a second block of content

"; $secondPage->save(); @@ -42,8 +44,8 @@ class PageContentTest extends TestCase public function test_saving_page_with_includes() { - $page = Page::first(); - $secondPage = Page::where('id', '!=', $page->id)->first(); + $page = Page::query()->first(); + $secondPage = Page::query()->where('id', '!=', $page->id)->first(); $this->asEditor(); $includeTag = '{{@' . $secondPage->id . '}}'; @@ -60,8 +62,8 @@ class PageContentTest extends TestCase public function test_page_includes_do_not_break_tables() { - $page = Page::first(); - $secondPage = Page::where('id', '!=', $page->id)->first(); + $page = Page::query()->first(); + $secondPage = Page::query()->where('id', '!=', $page->id)->first(); $content = '
test
'; $secondPage->html = $content; @@ -97,7 +99,7 @@ class PageContentTest extends TestCase public function test_page_content_scripts_removed_by_default() { $this->asEditor(); - $page = Page::first(); + $page = Page::query()->first(); $script = 'abc123abc123'; $page->html = "escape {$script}"; $page->save(); @@ -120,7 +122,7 @@ class PageContentTest extends TestCase ]; $this->asEditor(); - $page = Page::first(); + $page = Page::query()->first(); foreach ($checks as $check) { $page->html = $check; @@ -131,7 +133,6 @@ class PageContentTest extends TestCase $pageView->assertElementNotContains('.page-content', ''); } - } public function test_iframe_js_and_base64_urls_are_removed() @@ -141,11 +142,11 @@ class PageContentTest extends TestCase '', '', '', - '' + '', ]; $this->asEditor(); - $page = Page::first(); + $page = Page::query()->first(); foreach ($checks as $check) { $page->html = $check; @@ -160,18 +161,17 @@ class PageContentTest extends TestCase $pageView->assertElementNotContains('.page-content', 'data:'); $pageView->assertElementNotContains('.page-content', 'base64'); } - } public function test_javascript_uri_links_are_removed() { $checks = [ '', '
', - '
' + '
', ]; $this->asEditor(); - $page = Page::first(); + $page = Page::query()->first(); foreach ($checks as $check) { $page->html = $check; @@ -207,7 +208,7 @@ class PageContentTest extends TestCase $pageView->assertElementNotContains('.page-content', 'formaction=javascript:'); } } - + public function test_metadata_redirects_are_removed() { $checks = [ @@ -215,7 +216,7 @@ class PageContentTest extends TestCase ]; $this->asEditor(); - $page = Page::first(); + $page = Page::query()->first(); foreach ($checks as $check) { $page->html = $check; @@ -229,10 +230,11 @@ class PageContentTest extends TestCase $pageView->assertElementNotContains('.page-content', 'external_url'); } } + public function test_page_inline_on_attributes_removed_by_default() { $this->asEditor(); - $page = Page::first(); + $page = Page::query()->first(); $script = '

Hello

'; $page->html = "escape {$script}"; $page->save(); @@ -255,7 +257,7 @@ class PageContentTest extends TestCase ]; $this->asEditor(); - $page = Page::first(); + $page = Page::query()->first(); foreach ($checks as $check) { $page->html = $check; @@ -265,13 +267,12 @@ class PageContentTest extends TestCase $pageView->assertStatus(200); $pageView->assertElementNotContains('.page-content', 'onclick'); } - } public function test_page_content_scripts_show_when_configured() { $this->asEditor(); - $page = Page::first(); + $page = Page::query()->first(); config()->push('app.allow_content_scripts', 'true'); $script = 'abc123abc123'; @@ -286,7 +287,7 @@ class PageContentTest extends TestCase public function test_page_inline_on_attributes_show_if_configured() { $this->asEditor(); - $page = Page::first(); + $page = Page::query()->first(); config()->push('app.allow_content_scripts', 'true'); $script = '

Hello

'; @@ -301,14 +302,14 @@ class PageContentTest extends TestCase public function test_duplicate_ids_does_not_break_page_render() { $this->asEditor(); - $pageA = Page::first(); + $pageA = Page::query()->first(); $pageB = Page::query()->where('id', '!=', $pageA->id)->first(); $content = ' '; $pageA->html = $content; $pageA->save(); - $pageB->html = '

{{@'. $pageA->id .'#test}}

'; + $pageB->html = '

{{@' . $pageA->id . '#test}}

'; $pageB->save(); $pageView = $this->get($pageB->getUrl()); @@ -318,33 +319,33 @@ class PageContentTest extends TestCase public function test_duplicate_ids_fixed_on_page_save() { $this->asEditor(); - $page = Page::first(); + $page = Page::query()->first(); $content = ''; $pageSave = $this->put($page->getUrl(), [ - 'name' => $page->name, - 'html' => $content, - 'summary' => '' + 'name' => $page->name, + 'html' => $content, + 'summary' => '', ]); $pageSave->assertRedirect(); - $updatedPage = Page::where('id', '=', $page->id)->first(); - $this->assertEquals(substr_count($updatedPage->html, "bkmrk-test\""), 1); + $updatedPage = Page::query()->where('id', '=', $page->id)->first(); + $this->assertEquals(substr_count($updatedPage->html, 'bkmrk-test"'), 1); } public function test_anchors_referencing_non_bkmrk_ids_rewritten_after_save() { $this->asEditor(); - $page = Page::first(); + $page = Page::query()->first(); $content = '

test

link

'; $this->put($page->getUrl(), [ - 'name' => $page->name, - 'html' => $content, - 'summary' => '' + 'name' => $page->name, + 'html' => $content, + 'summary' => '', ]); - $updatedPage = Page::where('id', '=', $page->id)->first(); + $updatedPage = Page::query()->where('id', '=', $page->id)->first(); $this->assertStringContainsString('id="bkmrk-test"', $updatedPage->html); $this->assertStringContainsString('href="#bkmrk-test"', $updatedPage->html); } @@ -358,21 +359,21 @@ class PageContentTest extends TestCase $this->assertCount(3, $navMap); $this->assertArrayMapIncludes([ 'nodeName' => 'h1', - 'link' => '#testa', - 'text' => 'Hello', - 'level' => 1, + 'link' => '#testa', + 'text' => 'Hello', + 'level' => 1, ], $navMap[0]); $this->assertArrayMapIncludes([ 'nodeName' => 'h2', - 'link' => '#testb', - 'text' => 'There', - 'level' => 2, + 'link' => '#testb', + 'text' => 'There', + 'level' => 2, ], $navMap[1]); $this->assertArrayMapIncludes([ 'nodeName' => 'h3', - 'link' => '#testc', - 'text' => 'Donkey', - 'level' => 3, + 'link' => '#testc', + 'text' => 'Donkey', + 'level' => 3, ], $navMap[2]); } @@ -385,8 +386,8 @@ class PageContentTest extends TestCase $this->assertCount(1, $navMap); $this->assertArrayMapIncludes([ 'nodeName' => 'h1', - 'link' => '#testa', - 'text' => 'Hello' + 'link' => '#testa', + 'text' => 'Hello', ], $navMap[0]); } @@ -399,15 +400,15 @@ class PageContentTest extends TestCase $this->assertCount(3, $navMap); $this->assertArrayMapIncludes([ 'nodeName' => 'h4', - 'level' => 1, + 'level' => 1, ], $navMap[0]); $this->assertArrayMapIncludes([ 'nodeName' => 'h5', - 'level' => 2, + 'level' => 2, ], $navMap[1]); $this->assertArrayMapIncludes([ 'nodeName' => 'h6', - 'level' => 3, + 'level' => 3, ], $navMap[2]); } @@ -436,7 +437,7 @@ class PageContentTest extends TestCase | Paragraph | Text |'; $this->put($page->getUrl(), [ 'name' => $page->name, 'markdown' => $content, - 'html' => '', 'summary' => '' + 'html' => '', 'summary' => '', ]); $page->refresh(); @@ -455,7 +456,7 @@ class PageContentTest extends TestCase - [x] Item b'; $this->put($page->getUrl(), [ 'name' => $page->name, 'markdown' => $content, - 'html' => '', 'summary' => '' + 'html' => '', 'summary' => '', ]); $page->refresh(); @@ -463,7 +464,8 @@ class PageContentTest extends TestCase $this->assertStringContainsString('type="checkbox"', $page->html); $pageView = $this->get($page->getUrl()); - $pageView->assertElementExists('.page-content input[type=checkbox]'); + $pageView->assertElementExists('.page-content li.task-list-item input[type=checkbox]'); + $pageView->assertElementExists('.page-content li.task-list-item input[type=checkbox][checked=checked]'); } public function test_page_markdown_strikethrough_rendering() @@ -474,7 +476,7 @@ class PageContentTest extends TestCase $content = '~~some crossed out text~~'; $this->put($page->getUrl(), [ 'name' => $page->name, 'markdown' => $content, - 'html' => '', 'summary' => '' + 'html' => '', 'summary' => '', ]); $page->refresh(); @@ -484,6 +486,25 @@ class PageContentTest extends TestCase $pageView->assertElementExists('.page-content p > s'); } + public function test_page_markdown_single_html_comment_saving() + { + $this->asEditor(); + $page = Page::query()->first(); + + $content = ''; + $this->put($page->getUrl(), [ + 'name' => $page->name, 'markdown' => $content, + 'html' => '', 'summary' => '', + ]); + + $page->refresh(); + $this->assertStringMatchesFormat($content, $page->html); + + $pageView = $this->get($page->getUrl()); + $pageView->assertStatus(200); + $pageView->assertSee($content); + } + public function test_base64_images_get_extracted_from_page_content() { $this->asEditor(); @@ -491,7 +512,7 @@ class PageContentTest extends TestCase $this->put($page->getUrl(), [ 'name' => $page->name, 'summary' => '', - 'html' => '

test

', + 'html' => '

test

', ]); $page->refresh(); @@ -515,7 +536,7 @@ class PageContentTest extends TestCase $base64PngWithoutWhitespace = 'iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAACklEQVR4nGMAAQAABQAB'; $this->put($page->getUrl(), [ 'name' => $page->name, 'summary' => '', - 'html' => '

test

', + 'html' => '

test

', ]); $page->refresh(); @@ -537,7 +558,7 @@ class PageContentTest extends TestCase $this->put($page->getUrl(), [ 'name' => $page->name, 'summary' => '', - 'html' => '

test

', + 'html' => '

test

', ]); $page->refresh();