mirror of
https://github.com/pelican-dev/panel.git
synced 2025-05-19 18:44:46 +02:00

* Install Pest * Don’t use bootstrap file anymore * Fix comment * Think this is needed * Reset this * Switch dataproviders to attributes * Fix these * Support in memory databases * Fix this migration * Switch this back for now * Add missing import * Truncate and reseed database * These are replaced now * Switch ci to use pest
50 lines
1.5 KiB
PHP
50 lines
1.5 KiB
PHP
<?php
|
|
|
|
namespace App\Tests\Unit\Services\Acl\Api;
|
|
|
|
use App\Models\ApiKey;
|
|
use App\Tests\TestCase;
|
|
use App\Services\Acl\Api\AdminAcl;
|
|
use App\Models\Server;
|
|
use PHPUnit\Framework\Attributes\DataProvider;
|
|
|
|
class AdminAclTest extends TestCase
|
|
{
|
|
/**
|
|
* Test that permissions return the expects values.
|
|
*/
|
|
#[DataProvider('permissionsDataProvider')]
|
|
public function testPermissions(int $permission, int $check, bool $outcome): void
|
|
{
|
|
$this->assertSame($outcome, AdminAcl::can($permission, $check));
|
|
}
|
|
|
|
/**
|
|
* Test that checking against a model works as expected.
|
|
*/
|
|
public function testCheck(): void
|
|
{
|
|
$model = ApiKey::factory()->make(['permissions' => [
|
|
Server::RESOURCE_NAME => AdminAcl::READ | AdminAcl::WRITE,
|
|
]]);
|
|
|
|
$this->assertTrue(AdminAcl::check($model, Server::RESOURCE_NAME, AdminAcl::WRITE));
|
|
}
|
|
|
|
/**
|
|
* Provide valid and invalid permissions combos for testing.
|
|
*/
|
|
public static function permissionsDataProvider(): array
|
|
{
|
|
return [
|
|
[AdminAcl::READ, AdminAcl::READ, true],
|
|
[AdminAcl::READ | AdminAcl::WRITE, AdminAcl::READ, true],
|
|
[AdminAcl::READ | AdminAcl::WRITE, AdminAcl::WRITE, true],
|
|
[AdminAcl::WRITE, AdminAcl::WRITE, true],
|
|
[AdminAcl::READ, AdminAcl::WRITE, false],
|
|
[AdminAcl::NONE, AdminAcl::READ, false],
|
|
[AdminAcl::NONE, AdminAcl::WRITE, false],
|
|
];
|
|
}
|
|
}
|