]> BookStack Code Mirror - bookstack/commitdiff
Merge branch 'v0.31.x'
authorDan Brown <redacted>
Sat, 13 Mar 2021 15:37:44 +0000 (15:37 +0000)
committerDan Brown <redacted>
Sat, 13 Mar 2021 15:37:44 +0000 (15:37 +0000)
1  2 
tests/Entity/SortTest.php

index f3f6a8a1a462e832347565e3ce65f9c5d8cedb21,d3838c53c11e58e4d72b867dba1aa7e3fd884c04..c27c41f29120e83bb7e635568a4c5b98e6b9e261
@@@ -91,19 -91,19 +91,19 @@@ class SortTest extends TestCas
  
      public function test_page_move_requires_create_permissions_on_parent()
      {
 -        $page = Page::first();
 +        $page = Page::query()->first();
          $currentBook = $page->book;
 -        $newBook = Book::where('id', '!=', $currentBook->id)->first();
 +        $newBook = Book::query()->where('id', '!=', $currentBook->id)->first();
          $editor = $this->getEditor();
  
 -        $this->setEntityRestrictions($newBook, ['view', 'update', 'delete'], $editor->roles);
 +        $this->setEntityRestrictions($newBook, ['view', 'update', 'delete'], $editor->roles->all());
  
          $movePageResp = $this->actingAs($editor)->put($page->getUrl('/move'), [
              'entity_selection' => 'book:' . $newBook->id
          ]);
          $this->assertPermissionError($movePageResp);
  
 -        $this->setEntityRestrictions($newBook, ['view', 'update', 'delete', 'create'], $editor->roles);
 +        $this->setEntityRestrictions($newBook, ['view', 'update', 'delete', 'create'], $editor->roles->all());
          $movePageResp = $this->put($page->getUrl('/move'), [
              'entity_selection' => 'book:' . $newBook->id
          ]);
          $newBook = Book::where('id', '!=', $currentBook->id)->first();
          $editor = $this->getEditor();
  
 -        $this->setEntityRestrictions($newBook, ['view', 'update', 'create', 'delete'], $editor->roles);
 -        $this->setEntityRestrictions($page, ['view', 'update', 'create'], $editor->roles);
 +        $this->setEntityRestrictions($newBook, ['view', 'update', 'create', 'delete'], $editor->roles->all());
 +        $this->setEntityRestrictions($page, ['view', 'update', 'create'], $editor->roles->all());
  
          $movePageResp = $this->actingAs($editor)->put($page->getUrl('/move'), [
              'entity_selection' => 'book:' . $newBook->id
          $pageView = $this->get($page->getUrl());
          $pageView->assertDontSee($page->getUrl('/move'));
  
 -        $this->setEntityRestrictions($page, ['view', 'update', 'create', 'delete'], $editor->roles);
 +        $this->setEntityRestrictions($page, ['view', 'update', 'create', 'delete'], $editor->roles->all());
          $movePageResp = $this->put($page->getUrl('/move'), [
              'entity_selection' => 'book:' . $newBook->id
          ]);
          $newBook = Book::where('id', '!=', $currentBook->id)->first();
          $editor = $this->getEditor();
  
 -        $this->setEntityRestrictions($newBook, ['view', 'update', 'create', 'delete'], $editor->roles);
 -        $this->setEntityRestrictions($chapter, ['view', 'update', 'create'], $editor->roles);
 +        $this->setEntityRestrictions($newBook, ['view', 'update', 'create', 'delete'], $editor->roles->all());
 +        $this->setEntityRestrictions($chapter, ['view', 'update', 'create'], $editor->roles->all());
  
          $moveChapterResp = $this->actingAs($editor)->put($chapter->getUrl('/move'), [
              'entity_selection' => 'book:' . $newBook->id
          $pageView = $this->get($chapter->getUrl());
          $pageView->assertDontSee($chapter->getUrl('/move'));
  
 -        $this->setEntityRestrictions($chapter, ['view', 'update', 'create', 'delete'], $editor->roles);
 +        $this->setEntityRestrictions($chapter, ['view', 'update', 'create', 'delete'], $editor->roles->all());
          $moveChapterResp = $this->put($chapter->getUrl('/move'), [
              'entity_selection' => 'book:' . $newBook->id
          ]);
          $this->assertTrue($chapter->book->id == $newBook->id, 'Page book is now the new book');
      }
  
+     public function test_chapter_move_changes_book_for_deleted_pages_within()
+     {
+         /** @var Chapter $chapter */
+         $chapter = Chapter::query()->whereHas('pages')->first();
+         $currentBook = $chapter->book;
+         $pageToCheck = $chapter->pages->first();
+         $newBook = Book::query()->where('id', '!=', $currentBook->id)->first();
+         $pageToCheck->delete();
+         $this->asEditor()->put($chapter->getUrl('/move'), [
+             'entity_selection' => 'book:' . $newBook->id
+         ]);
+         $pageToCheck->refresh();
+         $this->assertEquals($newBook->id, $pageToCheck->book_id);
+     }
      public function test_book_sort()
      {
          $oldBook = Book::query()->first();