mirror of
https://gitee.com/zoujingli/ThinkAdmin.git
synced 2026-06-07 04:28:11 +08:00
将 v8 重构分支中残留的 ThinkAdminDeveloper 文本统一调整为 ThinkAdmin,避免迁移到主仓库后继续暴露旧开发仓库名称。 主要内容: - 更新 README 标题与项目描述。 - 统一 PHP 文件头注释中的项目标识。 - 同步调整测试、配置、插件与文档中的旧仓库名称文本。 - 保持旧包删除说明与架构边界测试语义不变,只清理品牌名称残留。
114 lines
4.7 KiB
PHP
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);
|
|
}
|
|
}
|
|
}
|