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

主要内容:

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

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

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

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

90 lines
2.8 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\wuma\controller\sales\User as SalesUserController;
use think\admin\runtime\RequestContext;
use think\admin\tests\Support\SqliteIntegrationTestCase;
/**
* @internal
* @coversNothing
*/
class SalesUserControllerTest extends SqliteIntegrationTestCase
{
public function testEditFilterTreatsStarMaskAsKeepPassword(): void
{
$this->executeStatements([
<<<'SQL'
CREATE TABLE plugin_wuma_sales_user (
id INTEGER PRIMARY KEY AUTOINCREMENT,
phone TEXT DEFAULT '',
password TEXT DEFAULT '',
date_start TEXT DEFAULT NULL,
date_after TEXT DEFAULT NULL,
delete_time TEXT DEFAULT NULL
)
SQL,
]);
$this->executeStatements([
<<<'SQL'
INSERT INTO plugin_wuma_sales_user (id, phone, password) VALUES (1, '13800138000', 'legacy-pass')
SQL,
]);
$request = $this->app->request
->withGet([])
->withPost([
'id' => 1,
'phone' => '13800138000',
'password' => password_mask(),
'date' => '2026-03-28 - 2027-03-28',
])
->setMethod('POST')
->setController('sales.user')
->setAction('edit');
RequestContext::clear();
$this->app->instance('request', $request);
$controller = new SalesUserController($this->app);
$method = new \ReflectionMethod($controller, '_form_filter');
$method->setAccessible(true);
$data = [
'id' => 1,
'phone' => '13800138000',
'password' => password_mask(),
'date' => '2026-03-28 - 2027-03-28',
];
$method->invokeArgs($controller, [&$data]);
$this->assertArrayNotHasKey('password', $data);
$this->assertSame('2026-03-28', $data['date_start'] ?? '');
$this->assertSame('2027-03-28', $data['date_after'] ?? '');
}
protected function defineSchema(): void
{
}
}