mirror of
https://github.com/BookStackApp/BookStack.git
synced 2025-08-07 23:03:00 +03:00
Touched entity timestamps on entity tag update
Decided it's relevant to entity updated_at since tags are now indexed alongside content. - Also fixed tags not applied on shelf. - Also enforced proper page API update validation. - Adds tests to cover. For #3319 Fixes #3370
This commit is contained in:
@@ -3,13 +3,15 @@
|
||||
namespace Tests\Api;
|
||||
|
||||
use BookStack\Entities\Models\Book;
|
||||
use Carbon\Carbon;
|
||||
use Illuminate\Support\Facades\DB;
|
||||
use Tests\TestCase;
|
||||
|
||||
class BooksApiTest extends TestCase
|
||||
{
|
||||
use TestsApi;
|
||||
|
||||
protected $baseEndpoint = '/api/books';
|
||||
protected string $baseEndpoint = '/api/books';
|
||||
|
||||
public function test_index_endpoint_returns_expected_book()
|
||||
{
|
||||
@@ -101,6 +103,21 @@ class BooksApiTest extends TestCase
|
||||
$this->assertActivityExists('book_update', $book);
|
||||
}
|
||||
|
||||
public function test_update_increments_updated_date_if_only_tags_are_sent()
|
||||
{
|
||||
$this->actingAsApiEditor();
|
||||
$book = Book::visible()->first();
|
||||
DB::table('books')->where('id', '=', $book->id)->update(['updated_at' => Carbon::now()->subWeek()]);
|
||||
|
||||
$details = [
|
||||
'tags' => [['name' => 'Category', 'value' => 'Testing']]
|
||||
];
|
||||
|
||||
$this->putJson($this->baseEndpoint . "/{$book->id}", $details);
|
||||
$book->refresh();
|
||||
$this->assertGreaterThan(Carbon::now()->subDay()->unix(), $book->updated_at->unix());
|
||||
}
|
||||
|
||||
public function test_delete_endpoint()
|
||||
{
|
||||
$this->actingAsApiEditor();
|
||||
|
@@ -4,13 +4,15 @@ namespace Tests\Api;
|
||||
|
||||
use BookStack\Entities\Models\Book;
|
||||
use BookStack\Entities\Models\Chapter;
|
||||
use Carbon\Carbon;
|
||||
use Illuminate\Support\Facades\DB;
|
||||
use Tests\TestCase;
|
||||
|
||||
class ChaptersApiTest extends TestCase
|
||||
{
|
||||
use TestsApi;
|
||||
|
||||
protected $baseEndpoint = '/api/chapters';
|
||||
protected string $baseEndpoint = '/api/chapters';
|
||||
|
||||
public function test_index_endpoint_returns_expected_chapter()
|
||||
{
|
||||
@@ -147,6 +149,21 @@ class ChaptersApiTest extends TestCase
|
||||
$this->assertActivityExists('chapter_update', $chapter);
|
||||
}
|
||||
|
||||
public function test_update_increments_updated_date_if_only_tags_are_sent()
|
||||
{
|
||||
$this->actingAsApiEditor();
|
||||
$chapter = Chapter::visible()->first();
|
||||
DB::table('chapters')->where('id', '=', $chapter->id)->update(['updated_at' => Carbon::now()->subWeek()]);
|
||||
|
||||
$details = [
|
||||
'tags' => [['name' => 'Category', 'value' => 'Testing']]
|
||||
];
|
||||
|
||||
$this->putJson($this->baseEndpoint . "/{$chapter->id}", $details);
|
||||
$chapter->refresh();
|
||||
$this->assertGreaterThan(Carbon::now()->subDay()->unix(), $chapter->updated_at->unix());
|
||||
}
|
||||
|
||||
public function test_delete_endpoint()
|
||||
{
|
||||
$this->actingAsApiEditor();
|
||||
|
@@ -5,13 +5,15 @@ namespace Tests\Api;
|
||||
use BookStack\Entities\Models\Book;
|
||||
use BookStack\Entities\Models\Chapter;
|
||||
use BookStack\Entities\Models\Page;
|
||||
use Carbon\Carbon;
|
||||
use Illuminate\Support\Facades\DB;
|
||||
use Tests\TestCase;
|
||||
|
||||
class PagesApiTest extends TestCase
|
||||
{
|
||||
use TestsApi;
|
||||
|
||||
protected $baseEndpoint = '/api/pages';
|
||||
protected string $baseEndpoint = '/api/pages';
|
||||
|
||||
public function test_index_endpoint_returns_expected_page()
|
||||
{
|
||||
@@ -240,6 +242,21 @@ class PagesApiTest extends TestCase
|
||||
$this->assertEquals($originalContent, $page->html);
|
||||
}
|
||||
|
||||
public function test_update_increments_updated_date_if_only_tags_are_sent()
|
||||
{
|
||||
$this->actingAsApiEditor();
|
||||
$page = Page::visible()->first();
|
||||
DB::table('pages')->where('id', '=', $page->id)->update(['updated_at' => Carbon::now()->subWeek()]);
|
||||
|
||||
$details = [
|
||||
'tags' => [['name' => 'Category', 'value' => 'Testing']]
|
||||
];
|
||||
|
||||
$this->putJson($this->baseEndpoint . "/{$page->id}", $details);
|
||||
$page->refresh();
|
||||
$this->assertGreaterThan(Carbon::now()->subDay()->unix(), $page->updated_at->unix());
|
||||
}
|
||||
|
||||
public function test_delete_endpoint()
|
||||
{
|
||||
$this->actingAsApiEditor();
|
||||
|
@@ -4,13 +4,15 @@ namespace Tests\Api;
|
||||
|
||||
use BookStack\Entities\Models\Book;
|
||||
use BookStack\Entities\Models\Bookshelf;
|
||||
use Carbon\Carbon;
|
||||
use Illuminate\Support\Facades\DB;
|
||||
use Tests\TestCase;
|
||||
|
||||
class ShelvesApiTest extends TestCase
|
||||
{
|
||||
use TestsApi;
|
||||
|
||||
protected $baseEndpoint = '/api/shelves';
|
||||
protected string $baseEndpoint = '/api/shelves';
|
||||
|
||||
public function test_index_endpoint_returns_expected_shelf()
|
||||
{
|
||||
@@ -111,6 +113,21 @@ class ShelvesApiTest extends TestCase
|
||||
$this->assertActivityExists('bookshelf_update', $shelf);
|
||||
}
|
||||
|
||||
public function test_update_increments_updated_date_if_only_tags_are_sent()
|
||||
{
|
||||
$this->actingAsApiEditor();
|
||||
$shelf = Bookshelf::visible()->first();
|
||||
DB::table('bookshelves')->where('id', '=', $shelf->id)->update(['updated_at' => Carbon::now()->subWeek()]);
|
||||
|
||||
$details = [
|
||||
'tags' => [['name' => 'Category', 'value' => 'Testing']]
|
||||
];
|
||||
|
||||
$this->putJson($this->baseEndpoint . "/{$shelf->id}", $details);
|
||||
$shelf->refresh();
|
||||
$this->assertGreaterThan(Carbon::now()->subDay()->unix(), $shelf->updated_at->unix());
|
||||
}
|
||||
|
||||
public function test_update_only_assigns_books_if_param_provided()
|
||||
{
|
||||
$this->actingAsApiEditor();
|
||||
|
Reference in New Issue
Block a user