siip-stripe-payment_intents/vendor/ubnt/ucrm-plugin-sdk/tests/UcrmPluginSdk/Service/PluginConfigManagerTest.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

49 lines
1.3 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\Service;
use Ubnt\UcrmPluginSdk\Exception\InvalidPluginRootPathException;
class PluginConfigManagerTest extends \PHPUnit\Framework\TestCase
{
public function testLoadConfig(): void
{
$expectedOptions = [
'token' => 'dummyTokenForTests',
'startDate' => '1.1.2018',
'paymentMatchAttribute' => 'invoiceNumber',
'importUnattached' => '1',
'lastProcessedPayment' => null,
'lastProcessedTimestamp' => null,
];
$pluginOptionsManager = PluginConfigManager::create(__DIR__ . '/../../files_enabled');
$config = $pluginOptionsManager->loadConfig();
self::assertSame($expectedOptions, $config);
}
public function testFileNotFound(): void
{
$exception = null;
try {
$pluginOptionsManager = PluginConfigManager::create(__DIR__);
$pluginOptionsManager->loadConfig();
} catch (InvalidPluginRootPathException $exception) {
}
self::assertInstanceOf(InvalidPluginRootPathException::class, $exception);
}
}