X-Git-Url: http://source.bookstackapp.com/bookstack/blobdiff_plain/1b46aa87565547ff7af21dfec1c2d7d89ff4873d..refs/pull/3387/head:/tests/Entity/PageEditorTest.php diff --git a/tests/Entity/PageEditorTest.php b/tests/Entity/PageEditorTest.php index f489e6b03..3fe7b33cd 100644 --- a/tests/Entity/PageEditorTest.php +++ b/tests/Entity/PageEditorTest.php @@ -18,36 +18,39 @@ class PageEditorTest extends TestCase $this->page = Page::query()->first(); } - public function test_default_editor_is_wysiwyg() + public function test_default_editor_is_wysiwyg_for_new_pages() { $this->assertEquals('wysiwyg', setting('app-editor')); - $this->asAdmin()->get($this->page->getUrl() . '/edit') - ->assertElementExists('#html-editor'); + $resp = $this->asAdmin()->get($this->page->book->getUrl('/create-page')); + $this->followRedirects($resp)->assertElementExists('#html-editor'); } - public function test_markdown_setting_shows_markdown_editor() + public function test_markdown_setting_shows_markdown_editor_for_new_pages() { $this->setSettings(['app-editor' => 'markdown']); - $this->asAdmin()->get($this->page->getUrl() . '/edit') + + $resp = $this->asAdmin()->get($this->page->book->getUrl('/create-page')); + $this->followRedirects($resp) ->assertElementNotExists('#html-editor') ->assertElementExists('#markdown-editor'); } public function test_markdown_content_given_to_editor() { - $this->setSettings(['app-editor' => 'markdown']); - $mdContent = '# hello. This is a test'; $this->page->markdown = $mdContent; + $this->page->editor = 'markdown'; $this->page->save(); - $this->asAdmin()->get($this->page->getUrl() . '/edit') + $this->asAdmin()->get($this->page->getUrl('/edit')) ->assertElementContains('[name="markdown"]', $mdContent); } public function test_html_content_given_to_editor_if_no_markdown() { - $this->setSettings(['app-editor' => 'markdown']); + $this->page->editor = 'markdown'; + $this->page->save(); + $this->asAdmin()->get($this->page->getUrl() . '/edit') ->assertElementContains('[name="markdown"]', $this->page->html); } @@ -143,45 +146,61 @@ class PageEditorTest extends TestCase $resp->assertSee("

A Header

\n

Some content with bold text!

", true); } - public function test_page_editor_depends_on_content_type() + public function test_page_editor_changes_with_editor_property() { - /** @var Page $page */ - $page = Page::query()->first(); - - $resp = $this->asAdmin()->get($page->getUrl('/edit')); + $resp = $this->asAdmin()->get($this->page->getUrl('/edit')); $resp->assertElementExists('[component="wysiwyg-editor"]'); - $page->html = ''; - $page->markdown = "## A Header\n\nSome content with **bold** text!"; - $page->save(); + $this->page->markdown = "## A Header\n\nSome content with **bold** text!"; + $this->page->editor = 'markdown'; + $this->page->save(); - $resp = $this->asAdmin()->get($page->getUrl('/edit')); + $resp = $this->asAdmin()->get($this->page->getUrl('/edit')); $resp->assertElementExists('[component="markdown-editor"]'); } public function test_editor_type_switch_options_show() { - /** @var Page $page */ - $page = Page::query()->first(); - - $resp = $this->asAdmin()->get($page->getUrl('/edit')); - $editLink = $page->getUrl('/edit') . '?editor='; + $resp = $this->asAdmin()->get($this->page->getUrl('/edit')); + $editLink = $this->page->getUrl('/edit') . '?editor='; $resp->assertElementContains("a[href=\"${editLink}markdown-clean\"]", '(Clean Content)'); $resp->assertElementContains("a[href=\"${editLink}markdown-stable\"]", '(Stable Content)'); - $resp = $this->asAdmin()->get($page->getUrl('/edit?editor=markdown-stable')); - $editLink = $page->getUrl('/edit') . '?editor='; + $resp = $this->asAdmin()->get($this->page->getUrl('/edit?editor=markdown-stable')); + $editLink = $this->page->getUrl('/edit') . '?editor='; $resp->assertElementContains("a[href=\"${editLink}wysiwyg\"]", 'Switch to WYSIWYG Editor'); } public function test_editor_type_switch_options_dont_show_if_without_change_editor_permissions() + { + $resp = $this->asEditor()->get($this->page->getUrl('/edit')); + $editLink = $this->page->getUrl('/edit') . '?editor='; + $resp->assertElementNotExists("a[href*=\"${editLink}\"]"); + } + + public function test_page_editor_type_switch_does_not_work_without_change_editor_permissions() { /** @var Page $page */ $page = Page::query()->first(); + $page->html = '

A Header

Some bold content.

'; + $page->save(); - $resp = $this->asEditor()->get($page->getUrl('/edit')); - $editLink = $page->getUrl('/edit') . '?editor='; - $resp->assertElementNotExists("a[href*=\"${editLink}\"]"); + $resp = $this->asEditor()->get($page->getUrl('/edit?editor=markdown-stable')); + $resp->assertStatus(200); + $resp->assertElementExists('[component="wysiwyg-editor"]'); + $resp->assertElementNotExists('[component="markdown-editor"]'); + } + + public function test_page_save_does_not_change_active_editor_without_change_editor_permissions() + { + /** @var Page $page */ + $page = Page::query()->first(); + $page->html = '

A Header

Some bold content.

'; + $page->editor = 'wysiwyg'; + $page->save(); + + $this->asEditor()->put($page->getUrl(), ['name' => $page->name, 'markdown' => '## Updated content abc']); + $this->assertEquals('wysiwyg', $page->refresh()->editor); } }