siip-stripe-payment_intents/vendor/ubnt/ucrm-plugin-sdk/tests/UcrmPluginSdk/Data/UcrmUserTest.php
DANYDHSV 7e4a535038 feat(stripe-sync): implementar resolución dinámica de métodos de pago y corregir validación API
- Se agregó 'getPaymentMethodIdByName' para buscar automáticamente el ID de "Transferencia bancaria" por nombre, asegurando portabilidad entre servidores UISP.
- Se implementó el manejo del webhook 'customer_cash_balance_transaction.created' para el registro automático de pagos fondeados.
- Fix: Se corrigió error 422 en la API de UCRM forzando el cast de 'clientId' a integer y 'methodId' a string (GUID).
- Se actualizó la documentación (README/CHANGELOG) con instrucciones de configuración de webhooks.
2025-12-23 14:50:01 -06:00

178 lines
5.4 KiB
PHP
Executable File

<?php
/*
* This file is part of UCRM Plugin SDK.
*
* Copyright (c) 2019 Ubiquiti Inc.
*
* For the full copyright and license information, please view the LICENSE.md
* file that was distributed with this source code.
*/
declare(strict_types=1);
namespace Ubnt\UcrmPluginSdk\Data;
use Ubnt\UcrmPluginSdk\Security\Permission;
use Ubnt\UcrmPluginSdk\Security\PermissionNames;
use Ubnt\UcrmPluginSdk\Security\SpecialPermission;
use Ubnt\UcrmPluginSdk\Security\SpecialPermissionNames;
class UcrmUserTest extends \PHPUnit\Framework\TestCase
{
/**
* @dataProvider hasViewPermissionProvider
*/
public function testHasViewPermission(UcrmUser $ucrmUser, string $resource, bool $expected): void
{
self::assertSame($expected, $ucrmUser->hasViewPermission($resource));
}
/**
* @return mixed[]
*/
public function hasViewPermissionProvider(): array
{
return [
'denied user' => [
'ucrmUser' => $this->createDeniedUcrmUser(),
'resource' => PermissionNames::CLIENTS_CLIENTS,
'expected' => false,
],
'view user' => [
'ucrmUser' => $this->createViewUcrmUser(),
'resource' => PermissionNames::CLIENTS_CLIENTS,
'expected' => true,
],
'edit user' => [
'ucrmUser' => $this->createEditUcrmUser(),
'resource' => PermissionNames::CLIENTS_CLIENTS,
'expected' => true,
],
];
}
/**
* @dataProvider hasEditPermissionProvider
*/
public function testHasEditPermission(UcrmUser $ucrmUser, string $resource, bool $expected): void
{
self::assertSame($expected, $ucrmUser->hasEditPermission($resource));
}
/**
* @return mixed[]
*/
public function hasEditPermissionProvider(): array
{
return [
'denied user' => [
'ucrmUser' => $this->createDeniedUcrmUser(),
'resource' => PermissionNames::CLIENTS_CLIENTS,
'expected' => false,
],
'view user' => [
'ucrmUser' => $this->createViewUcrmUser(),
'resource' => PermissionNames::CLIENTS_CLIENTS,
'expected' => false,
],
'edit user' => [
'ucrmUser' => $this->createEditUcrmUser(),
'resource' => PermissionNames::CLIENTS_CLIENTS,
'expected' => true,
],
];
}
/**
* @dataProvider hasSpecialPermissionProvider
*/
public function testHasSpecialPermission(UcrmUser $ucrmUser, string $name, bool $expected): void
{
self::assertSame($expected, $ucrmUser->hasSpecialPermission($name));
}
/**
* @return mixed[]
*/
public function hasSpecialPermissionProvider(): array
{
return [
'denied user' => [
'ucrmUser' => $this->createDeniedUcrmUser(),
'name' => SpecialPermissionNames::CLIENT_EXPORT,
'expected' => false,
],
'view user' => [
'ucrmUser' => $this->createViewUcrmUser(),
'name' => SpecialPermissionNames::CLIENT_EXPORT,
'expected' => true,
],
'edit user' => [
'ucrmUser' => $this->createEditUcrmUser(),
'name' => SpecialPermissionNames::CLIENT_EXPORT,
'expected' => true,
],
];
}
private function createDeniedUcrmUser(): UcrmUser
{
return new UcrmUser(
[
'userId' => 1,
'username' => 'admin',
'isClient' => false,
'clientId' => null,
'userGroup' => 'Admin Group',
'permissions' => [
PermissionNames::CLIENTS_CLIENTS => Permission::DENIED,
],
'specialPermissions' => [
SpecialPermissionNames::CLIENT_EXPORT => SpecialPermission::DENY,
],
'locale' => 'en_US',
]
);
}
private function createViewUcrmUser(): UcrmUser
{
return new UcrmUser(
[
'userId' => 1,
'username' => 'admin',
'isClient' => false,
'clientId' => null,
'userGroup' => 'Admin Group',
'permissions' => [
PermissionNames::CLIENTS_CLIENTS => Permission::VIEW,
],
'specialPermissions' => [
SpecialPermissionNames::CLIENT_EXPORT => SpecialPermission::ALLOW,
],
'locale' => 'en_US',
]
);
}
private function createEditUcrmUser(): UcrmUser
{
return new UcrmUser(
[
'userId' => 1,
'username' => 'admin',
'isClient' => false,
'clientId' => null,
'userGroup' => 'Admin Group',
'permissions' => [
PermissionNames::CLIENTS_CLIENTS => Permission::EDIT,
],
'specialPermissions' => [
SpecialPermissionNames::CLIENT_EXPORT => SpecialPermission::ALLOW,
],
'locale' => 'en_US',
]
);
}
}