b546098b36
Updated the back button to be a proper link instead of a reference to the last viewed URL since it could break if the last page was the current one (On validation for example). Includes test to cover. Also applied some styleCI changes. Fixes #2834
106 lines
3.5 KiB
PHP
106 lines
3.5 KiB
PHP
<?php
|
|
|
|
namespace Tests\Entity;
|
|
|
|
use BookStack\Entities\Models\Book;
|
|
use BookStack\Entities\Models\Chapter;
|
|
use BookStack\Entities\Models\Page;
|
|
use Tests\TestCase;
|
|
|
|
class PageEditorTest extends TestCase
|
|
{
|
|
/** @var Page */
|
|
protected $page;
|
|
|
|
protected function setUp(): void
|
|
{
|
|
parent::setUp();
|
|
$this->page = Page::query()->first();
|
|
}
|
|
|
|
public function test_default_editor_is_wysiwyg()
|
|
{
|
|
$this->assertEquals('wysiwyg', setting('app-editor'));
|
|
$this->asAdmin()->get($this->page->getUrl() . '/edit')
|
|
->assertElementExists('#html-editor');
|
|
}
|
|
|
|
public function test_markdown_setting_shows_markdown_editor()
|
|
{
|
|
$this->setSettings(['app-editor' => 'markdown']);
|
|
$this->asAdmin()->get($this->page->getUrl() . '/edit')
|
|
->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->save();
|
|
|
|
$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->asAdmin()->get($this->page->getUrl() . '/edit')
|
|
->assertElementContains('[name="markdown"]', $this->page->html);
|
|
}
|
|
|
|
public function test_empty_markdown_still_saves_without_error()
|
|
{
|
|
$this->setSettings(['app-editor' => 'markdown']);
|
|
/** @var Book $book */
|
|
$book = Book::query()->first();
|
|
|
|
$this->asEditor()->get($book->getUrl('/create-page'));
|
|
$draft = Page::query()->where('book_id', '=', $book->id)
|
|
->where('draft', '=', true)->first();
|
|
|
|
$details = [
|
|
'name' => 'my page',
|
|
'markdown' => '',
|
|
];
|
|
$resp = $this->post($book->getUrl("/draft/{$draft->id}"), $details);
|
|
$resp->assertRedirect();
|
|
|
|
$this->assertDatabaseHas('pages', [
|
|
'markdown' => $details['markdown'],
|
|
'id' => $draft->id,
|
|
'draft' => false,
|
|
]);
|
|
}
|
|
|
|
public function test_back_link_in_editor_has_correct_url()
|
|
{
|
|
/** @var Book $book */
|
|
$book = Book::query()->whereHas('pages')->whereHas('chapters')->firstOrFail();
|
|
$this->asEditor()->get($book->getUrl('/create-page'));
|
|
/** @var Chapter $chapter */
|
|
$chapter = $book->chapters()->firstOrFail();
|
|
/** @var Page $draft */
|
|
$draft = $book->pages()->where('draft', '=', true)->firstOrFail();
|
|
|
|
// Book draft goes back to book
|
|
$resp = $this->get($book->getUrl("/draft/{$draft->id}"));
|
|
$resp->assertElementContains('a[href="' . $book->getUrl() . '"]', 'Back');
|
|
|
|
// Chapter draft goes back to chapter
|
|
$draft->chapter_id = $chapter->id;
|
|
$draft->save();
|
|
$resp = $this->get($book->getUrl("/draft/{$draft->id}"));
|
|
$resp->assertElementContains('a[href="' . $chapter->getUrl() . '"]', 'Back');
|
|
|
|
// Saved page goes back to page
|
|
$this->post($book->getUrl("/draft/{$draft->id}"), ['name' => 'Updated', 'html' => 'Updated']);
|
|
$draft->refresh();
|
|
$resp = $this->get($draft->getUrl('/edit'));
|
|
$resp->assertElementContains('a[href="' . $draft->getUrl() . '"]', 'Back');
|
|
}
|
|
}
|