mirror of
				https://github.com/BookStackApp/BookStack.git
				synced 2025-11-03 02:13:16 +03:00 
			
		
		
		
	
		
			
				
	
	
		
			123 lines
		
	
	
		
			4.0 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			123 lines
		
	
	
		
			4.0 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php namespace Tests;
 | 
						|
 | 
						|
use BookStack\Auth\Permissions\JointPermission;
 | 
						|
use BookStack\Entities\Page;
 | 
						|
use BookStack\Entities\Repos\EntityRepo;
 | 
						|
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->updatePage($page, $page->book_id, ['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');
 | 
						|
    }
 | 
						|
}
 |