X-Git-Url: http://source.bookstackapp.com/bookstack/blobdiff_plain/07b889547d28e68e5fc8f923c166bd607da17ad7..refs/pull/2902/head:/tests/Entity/EntityTest.php diff --git a/tests/Entity/EntityTest.php b/tests/Entity/EntityTest.php index a3fb1cfe1..f8c88b1fe 100644 --- a/tests/Entity/EntityTest.php +++ b/tests/Entity/EntityTest.php @@ -1,42 +1,27 @@ -bookCreation(); $chapter = $this->chapterCreation($book); - $page = $this->pageCreation($chapter); + $this->pageCreation($chapter); // Test Updating - $book = $this->bookUpdate($book); - - // Test Deletion - $this->bookDelete($book); - } - - public function bookDelete(Book $book) - { - $this->asAdmin() - ->visit($book->getUrl()) - // Check link works correctly - ->click('Delete') - ->seePageIs($book->getUrl() . '/delete') - // Ensure the book name is show to user - ->see($book->name) - ->press('Confirm') - ->seePageIs('/books') - ->notSeeInDatabase('books', ['id' => $book->id]); + $this->bookUpdate($book); } public function bookUpdate(Book $book) @@ -58,7 +43,7 @@ class EntityTest extends BrowserKitTest public function test_book_sort_page_shows() { - $books = Book::all(); + $books = Book::all(); $bookToSort = $books[0]; $this->asAdmin() ->visit($bookToSort->getUrl()) @@ -70,7 +55,7 @@ class EntityTest extends BrowserKitTest public function test_book_sort_item_returns_book_content() { - $books = Book::all(); + $books = Book::all(); $bookToSort = $books[0]; $firstPage = $bookToSort->pages[0]; $firstChapter = $bookToSort->chapters[0]; @@ -100,13 +85,12 @@ class EntityTest extends BrowserKitTest ->submitForm('Grid View') ->seePageIs('/books') ->pageHasElement('.featured-image-container'); - } public function pageCreation($chapter) { $page = factory(Page::class)->make([ - 'name' => 'My First Page' + 'name' => 'My First Page', ]); $this->asAdmin() @@ -126,13 +110,14 @@ class EntityTest extends BrowserKitTest ->see($page->name); $page = Page::where('slug', '=', 'my-first-page')->where('chapter_id', '=', $chapter->id)->first(); + return $page; } public function chapterCreation(Book $book) { $chapter = factory(Chapter::class)->make([ - 'name' => 'My First Chapter' + 'name' => 'My First Chapter', ]); $this->asAdmin() @@ -149,13 +134,14 @@ class EntityTest extends BrowserKitTest ->see($chapter->name)->see($chapter->description); $chapter = Chapter::where('slug', '=', 'my-first-chapter')->where('book_id', '=', $book->id)->first(); + return $chapter; } public function bookCreation() { $book = factory(Book::class)->make([ - 'name' => 'My First Book' + 'name' => 'My First Book', ]); $this->asAdmin() ->visit('/books') @@ -178,9 +164,10 @@ class EntityTest extends BrowserKitTest ->press('Save Book'); $expectedPattern = '/\/books\/my-first-book-[0-9a-zA-Z]{3}/'; - $this->assertRegExp($expectedPattern, $this->currentUri, "Did not land on expected page [$expectedPattern].\n"); + $this->assertMatchesRegularExpression($expectedPattern, $this->currentUri, "Did not land on expected page [$expectedPattern].\n"); $book = Book::where('slug', '=', 'my-first-book')->first(); + return $book; } @@ -192,7 +179,7 @@ class EntityTest extends BrowserKitTest $entities = $this->createEntityChainBelongingToUser($creator, $updater); $this->actingAs($creator); app(UserRepo::class)->destroy($creator); - app(PageRepo::class)->savePageRevision($entities['page']); + app(PageRepo::class)->update($entities['page'], ['html' => '
hello!
>']); $this->checkEntitiesViewable($entities); } @@ -205,7 +192,7 @@ class EntityTest extends BrowserKitTest $entities = $this->createEntityChainBelongingToUser($creator, $updater); $this->actingAs($updater); app(UserRepo::class)->destroy($updater); - app(PageRepo::class)->savePageRevision($entities['page']); + app(PageRepo::class)->update($entities['page'], ['html' => 'Hello there!
']); $this->checkEntitiesViewable($entities); } @@ -261,7 +248,7 @@ class EntityTest extends BrowserKitTest { $page = Page::orderBy('updated_at', 'asc')->first(); Page::where('id', '!=', $page->id)->update([ - 'updated_at' => Carbon::now()->subSecond(1) + 'updated_at' => Carbon::now()->subSecond(1), ]); $this->asAdmin()->visit('/') ->dontSeeInElement('#recently-updated-pages', $page->name); @@ -271,25 +258,62 @@ class EntityTest extends BrowserKitTest ->seeInElement('#recently-updated-pages', $page->name); } - public function test_slug_multi_byte_lower_casing() + public function test_slug_multi_byte_url_safe() { - $entityRepo = app(EntityRepo::class); - $book = $entityRepo->createFromInput('book', [ - 'name' => 'ÐÐÐÐÐ' + $book = $this->newBook([ + 'name' => 'инÑоÑмаÑиÑ', ]); - $this->assertEquals('книга', $book->slug); - } + $this->assertEquals('informatsiya', $book->slug); + $book = $this->newBook([ + 'name' => '¿Qué?', + ]); + + $this->assertEquals('que', $book->slug); + } public function test_slug_format() { - $entityRepo = app(EntityRepo::class); - $book = $entityRepo->createFromInput('book', [ - 'name' => 'PartA / PartB / PartC' + $book = $this->newBook([ + 'name' => 'PartA / PartB / PartC', ]); $this->assertEquals('parta-partb-partc', $book->slug); } + public function test_shelf_cancel_creation_returns_to_correct_place() + { + $shelf = Bookshelf::first(); + + // Cancel button from shelf goes back to shelf + $this->asEditor()->visit($shelf->getUrl('/create-book')) + ->see('Cancel') + ->click('Cancel') + ->seePageIs($shelf->getUrl()); + + // Cancel button from books goes back to books + $this->asEditor()->visit('/create-book') + ->see('Cancel') + ->click('Cancel') + ->seePageIs('/books'); + + // Cancel button from book edit goes back to book + $book = Book::first(); + + $this->asEditor()->visit($book->getUrl('/edit')) + ->see('Cancel') + ->click('Cancel') + ->seePageIs($book->getUrl()); + } + + public function test_page_within_chapter_deletion_returns_to_chapter() + { + $chapter = Chapter::query()->first(); + $page = $chapter->pages()->first(); + + $this->asEditor()->visit($page->getUrl('/delete')) + ->submitForm('Confirm') + ->seePageIs($chapter->getUrl()); + } }