ThinkAdmin/plugin/think-plugs-payment/tests/IntegralIntegrationTest.php
Anyon e7a8c05556 chore(repo): 统一 v8 仓库品牌名称
将 v8 重构分支中残留的 ThinkAdminDeveloper 文本统一调整为 ThinkAdmin,避免迁移到主仓库后继续暴露旧开发仓库名称。

主要内容:

- 更新 README 标题与项目描述。

- 统一 PHP 文件头注释中的项目标识。

- 同步调整测试、配置、插件与文档中的旧仓库名称文本。

- 保持旧包删除说明与架构边界测试语义不变,只清理品牌名称残留。
2026-05-08 16:15:24 +08:00

114 lines
4.7 KiB
PHP

<?php
declare(strict_types=1);
/**
* +----------------------------------------------------------------------
* | ThinkAdmin Plugin
* +----------------------------------------------------------------------
* | Copyright (c) 2014~2026 ThinkAdmin [ thinkadmin.top ]
* +----------------------------------------------------------------------
* | Official Website: https://thinkadmin.top
* +----------------------------------------------------------------------
* | Licensed: https://mit-license.org
* | Disclaimer: https://thinkadmin.top/disclaimer
* | Vip Rights: https://thinkadmin.top/vip-introduce
* +----------------------------------------------------------------------
* | Gitee Repository: https://gitee.com/zoujingli/ThinkAdmin
* | Github Repository: https://github.com/zoujingli/ThinkAdmin
* +----------------------------------------------------------------------
*/
namespace think\admin\tests;
use plugin\payment\service\Integral;
use think\admin\Exception;
use think\admin\tests\Support\SqliteIntegrationTestCase;
/**
* @internal
* @coversNothing
*/
class IntegralIntegrationTest extends SqliteIntegrationTestCase
{
protected function setUp(): void
{
parent::setUp();
$this->context->setData('plugin.payment.config', ['integral' => 100]);
}
public function testRatioAndCreateRefreshIntegralSummary(): void
{
$user = $this->createAccountUser([
'phone' => $this->randomPhone('1330013'),
'username' => 'integral-' . random_int(100, 999),
'nickname' => '积分用户',
]);
$this->assertSame('2.500000', Integral::ratio('250'));
$model = Integral::create(intval($user->getAttr('id')), 'integral-create', '积分发放', '30.00', '签到积分');
$user = $user->refresh();
$this->assertTrue($model->isExists());
$this->assertSame('0.00', $this->decimal($model->getAttr('amount_prev')));
$this->assertSame('30.00', $this->decimal($model->getAttr('amount_next')));
$this->assertSame('30.00', $this->decimal($user->getAttr('extra')['integral_lock'] ?? 0));
$this->assertSame('30.00', $this->decimal($user->getAttr('extra')['integral_total'] ?? 0));
$this->assertSame('30.00', $this->decimal($user->getAttr('extra')['integral_usable'] ?? 0));
}
public function testUnlockCancelAndInsufficientDeduction(): void
{
$user = $this->createAccountUser([
'phone' => $this->randomPhone('1330013'),
'username' => 'integral-' . random_int(100, 999),
'nickname' => '积分用户',
]);
Integral::create(intval($user->getAttr('id')), 'integral-state', '积分发放', '12.00', '用于状态变更');
$unlocked = Integral::unlock('integral-state');
$this->assertSame(1, intval($unlocked->getAttr('unlock')));
$this->assertNotEmpty($unlocked->getAttr('unlock_time'));
$cancelled = Integral::cancel('integral-state');
$user = $user->refresh();
$this->assertSame(1, intval($cancelled->getAttr('cancel')));
$this->assertSame('0.00', $this->decimal($user->getAttr('extra')['integral_lock'] ?? 0));
$this->assertSame('0.00', $this->decimal($user->getAttr('extra')['integral_total'] ?? 0));
$this->assertSame('0.00', $this->decimal($user->getAttr('extra')['integral_usable'] ?? 0));
$this->expectException(Exception::class);
$this->expectExceptionMessage('扣减积分不足');
Integral::create(intval($user->getAttr('id')), 'integral-minus', '积分扣减', '-20.00', '超额扣减');
}
public function testInsufficientDeductionReturnsEnglishMessageWhenLangSetIsEnUs(): void
{
$user = $this->createAccountUser([
'phone' => $this->randomPhone('1330014'),
'username' => 'integral-en-' . random_int(100, 999),
'nickname' => '积分英文用户',
]);
Integral::create(intval($user->getAttr('id')), 'integral-enough', '积分发放', '12.00', '英文提示测试');
$this->switchPaymentLang('en-us');
$this->expectException(Exception::class);
$this->expectExceptionMessage('Insufficient integral for deduction');
Integral::create(intval($user->getAttr('id')), 'integral-minus-en', '积分扣减', '-20.00', '超额扣减');
}
protected function defineSchema(): void
{
$this->createAccountTables();
$this->createPaymentIntegralTable();
}
private function switchPaymentLang(string $langSet): void
{
$this->app->lang->switchLangSet($langSet);
$file = TEST_PROJECT_ROOT . "/plugin/think-plugs-payment/src/lang/{$langSet}.php";
if (is_file($file)) {
$this->app->lang->load($file, $langSet);
}
}
}