mirror of
https://github.com/BookStackApp/BookStack.git
synced 2025-06-02 06:43:10 +08:00
Applied another round of static analysis updates
This commit is contained in:
32
tests/Unit/FrameworkAssumptionTest.php
Normal file
32
tests/Unit/FrameworkAssumptionTest.php
Normal file
@ -0,0 +1,32 @@
|
||||
<?php
|
||||
|
||||
namespace Tests\Unit;
|
||||
|
||||
use BadMethodCallException;
|
||||
use BookStack\Entities\Models\Page;
|
||||
use Tests\TestCase;
|
||||
|
||||
/**
|
||||
* This class tests assumptions we're relying upon in the framework.
|
||||
* This is primarily to keep track of certain bits of functionality that
|
||||
* may be used in important areas such as to enforce permissions.
|
||||
*/
|
||||
class FrameworkAssumptionTest extends TestCase
|
||||
{
|
||||
|
||||
public function test_scopes_error_if_not_existing()
|
||||
{
|
||||
$this->expectException(BadMethodCallException::class);
|
||||
$this->expectExceptionMessage('Call to undefined method BookStack\Entities\Models\Page::scopeNotfoundscope()');
|
||||
Page::query()->scopes('notfoundscope');
|
||||
}
|
||||
|
||||
public function test_scopes_applies_upon_existing()
|
||||
{
|
||||
// Page has SoftDeletes trait by default, so we apply our custom scope and ensure
|
||||
// it stacks on the global scope to filter out deleted items.
|
||||
$query = Page::query()->scopes('visible')->toSql();
|
||||
$this->assertStringContainsString('joint_permissions', $query);
|
||||
$this->assertStringContainsString('`deleted_at` is null', $query);
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user