mirror of
https://github.com/BookStackApp/BookStack.git
synced 2025-01-19 08:42:48 +08:00
31f5786e01
* Started mass-refactoring of the current entity repos * Rewrote book tree logic - Now does two simple queries instead of one really complex one. - Extracted logic into its own class. - Remove model-level akward union field listing. - Logic now more readable than being large separate query and compilation functions. * Extracted and split book sort logic * Finished up Book controller/repo organisation * Refactored bookshelves controllers and repo parts * Fixed issues found via phpunit * Refactored Chapter controller * Updated Chapter export controller * Started Page controller/repo refactor * Refactored another chunk of PageController * Completed initial pagecontroller refactor pass * Fixed tests and continued reduction of old repos * Removed old page remove and further reduced entity repo * Removed old entity repo, split out page controller * Ran phpcbf and split out some page content methods * Tidied up some EntityProvider elements * Fixed issued caused by viewservice change
122 lines
4.0 KiB
PHP
122 lines
4.0 KiB
PHP
<?php namespace Tests;
|
|
|
|
use BookStack\Auth\Permissions\JointPermission;
|
|
use BookStack\Entities\Page;
|
|
use BookStack\Auth\User;
|
|
use BookStack\Entities\Repos\PageRepo;
|
|
|
|
class CommandsTest extends TestCase
|
|
{
|
|
|
|
public function test_clear_views_command()
|
|
{
|
|
$this->asEditor();
|
|
$page = Page::first();
|
|
|
|
$this->get($page->getUrl());
|
|
|
|
$this->assertDatabaseHas('views', [
|
|
'user_id' => $this->getEditor()->id,
|
|
'viewable_id' => $page->id,
|
|
'views' => 1
|
|
]);
|
|
|
|
$exitCode = \Artisan::call('bookstack:clear-views');
|
|
$this->assertTrue($exitCode === 0, 'Command executed successfully');
|
|
|
|
$this->assertDatabaseMissing('views', [
|
|
'user_id' => $this->getEditor()->id
|
|
]);
|
|
}
|
|
|
|
public function test_clear_activity_command()
|
|
{
|
|
$this->asEditor();
|
|
$page = Page::first();
|
|
\Activity::add($page, 'page_update', $page->book->id);
|
|
|
|
$this->assertDatabaseHas('activities', [
|
|
'key' => 'page_update',
|
|
'entity_id' => $page->id,
|
|
'user_id' => $this->getEditor()->id
|
|
]);
|
|
|
|
$exitCode = \Artisan::call('bookstack:clear-activity');
|
|
$this->assertTrue($exitCode === 0, 'Command executed successfully');
|
|
|
|
|
|
$this->assertDatabaseMissing('activities', [
|
|
'key' => 'page_update'
|
|
]);
|
|
}
|
|
|
|
public function test_clear_revisions_command()
|
|
{
|
|
$this->asEditor();
|
|
$pageRepo = app(PageRepo::class);
|
|
$page = Page::first();
|
|
$pageRepo->update($page, ['name' => 'updated page', 'html' => '<p>new content</p>', 'summary' => 'page revision testing']);
|
|
$pageRepo->updatePageDraft($page, ['name' => 'updated page', 'html' => '<p>new content in draft</p>', 'summary' => 'page revision testing']);
|
|
|
|
$this->assertDatabaseHas('page_revisions', [
|
|
'page_id' => $page->id,
|
|
'type' => 'version'
|
|
]);
|
|
$this->assertDatabaseHas('page_revisions', [
|
|
'page_id' => $page->id,
|
|
'type' => 'update_draft'
|
|
]);
|
|
|
|
$exitCode = \Artisan::call('bookstack:clear-revisions');
|
|
$this->assertTrue($exitCode === 0, 'Command executed successfully');
|
|
|
|
$this->assertDatabaseMissing('page_revisions', [
|
|
'page_id' => $page->id,
|
|
'type' => 'version'
|
|
]);
|
|
$this->assertDatabaseHas('page_revisions', [
|
|
'page_id' => $page->id,
|
|
'type' => 'update_draft'
|
|
]);
|
|
|
|
$exitCode = \Artisan::call('bookstack:clear-revisions', ['--all' => true]);
|
|
$this->assertTrue($exitCode === 0, 'Command executed successfully');
|
|
|
|
$this->assertDatabaseMissing('page_revisions', [
|
|
'page_id' => $page->id,
|
|
'type' => 'update_draft'
|
|
]);
|
|
}
|
|
|
|
public function test_regen_permissions_command()
|
|
{
|
|
JointPermission::query()->truncate();
|
|
$page = Page::first();
|
|
|
|
$this->assertDatabaseMissing('joint_permissions', ['entity_id' => $page->id]);
|
|
|
|
$exitCode = \Artisan::call('bookstack:regenerate-permissions');
|
|
$this->assertTrue($exitCode === 0, 'Command executed successfully');
|
|
|
|
$this->assertDatabaseHas('joint_permissions', ['entity_id' => $page->id]);
|
|
}
|
|
|
|
public function test_add_admin_command()
|
|
{
|
|
$exitCode = \Artisan::call('bookstack:create-admin', [
|
|
'--email' => 'admintest@example.com',
|
|
'--name' => 'Admin Test',
|
|
'--password' => 'testing-4',
|
|
]);
|
|
$this->assertTrue($exitCode === 0, 'Command executed successfully');
|
|
|
|
$this->assertDatabaseHas('users', [
|
|
'email' => 'admintest@example.com',
|
|
'name' => 'Admin Test'
|
|
]);
|
|
|
|
$this->assertTrue(User::where('email', '=', 'admintest@example.com')->first()->hasSystemRole('admin'), 'User has admin role as expected');
|
|
$this->assertTrue(\Auth::attempt(['email' => 'admintest@example.com', 'password' => 'testing-4']), 'Password stored as expected');
|
|
}
|
|
}
|