优化积分流水筛选与用户管理样式
This commit is contained in:
@@ -0,0 +1,64 @@
|
||||
<?php
|
||||
|
||||
/**
|
||||
* 文件功能:后台金币/积分流水查询测试
|
||||
*
|
||||
* 覆盖后台流水页对来源多选筛选的查询行为。
|
||||
*/
|
||||
|
||||
namespace Tests\Feature\Feature;
|
||||
|
||||
use App\Enums\CurrencySource;
|
||||
use App\Models\Sysparam;
|
||||
use App\Models\User;
|
||||
use App\Models\UserCurrencyLog;
|
||||
use Illuminate\Foundation\Testing\RefreshDatabase;
|
||||
use Tests\TestCase;
|
||||
|
||||
/**
|
||||
* 类功能:验证后台金币/积分流水查询页筛选行为。
|
||||
*/
|
||||
class AdminCurrencyLogControllerTest extends TestCase
|
||||
{
|
||||
use RefreshDatabase;
|
||||
|
||||
/**
|
||||
* 验证后台流水页支持按多个来源同时筛选。
|
||||
*/
|
||||
public function test_admin_can_filter_currency_logs_by_multiple_sources(): void
|
||||
{
|
||||
Sysparam::updateOrCreate(['alias' => 'superlevel'], ['body' => '100']);
|
||||
$admin = User::factory()->create(['user_level' => 100]);
|
||||
|
||||
foreach ([CurrencySource::AUTO_SAVE, CurrencySource::SIGN_IN, CurrencySource::ADMIN_ADJUST] as $index => $source) {
|
||||
UserCurrencyLog::query()->create([
|
||||
'user_id' => $admin->id,
|
||||
'username' => $admin->username,
|
||||
'currency' => 'gold',
|
||||
'amount' => 10 + $index,
|
||||
'balance_after' => 100 + $index,
|
||||
'source' => $source->value,
|
||||
'remark' => $source->label(),
|
||||
'created_at' => now()->subMinutes($index),
|
||||
]);
|
||||
}
|
||||
|
||||
$response = $this->actingAs($admin)->get(route('admin.currency-logs.index', [
|
||||
'sources' => [
|
||||
CurrencySource::AUTO_SAVE->value,
|
||||
CurrencySource::SIGN_IN->value,
|
||||
],
|
||||
]));
|
||||
|
||||
$response->assertOk();
|
||||
$response->assertViewIs('admin.currency-logs.index');
|
||||
$response->assertViewHas('selectedSources', [
|
||||
CurrencySource::AUTO_SAVE->value,
|
||||
CurrencySource::SIGN_IN->value,
|
||||
]);
|
||||
$this->assertSame(
|
||||
[CurrencySource::AUTO_SAVE->value, CurrencySource::SIGN_IN->value],
|
||||
$response->viewData('logs')->getCollection()->pluck('source')->sort()->values()->all()
|
||||
);
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,86 @@
|
||||
<?php
|
||||
|
||||
/**
|
||||
* 文件功能:后台积分流水统计页面测试
|
||||
*
|
||||
* 覆盖后台统计页的来源聚合与净流通量口径。
|
||||
*/
|
||||
|
||||
namespace Tests\Feature\Feature;
|
||||
|
||||
use App\Enums\CurrencySource;
|
||||
use App\Models\Sysparam;
|
||||
use App\Models\User;
|
||||
use App\Models\UserCurrencyLog;
|
||||
use Illuminate\Foundation\Testing\RefreshDatabase;
|
||||
use Illuminate\Support\Facades\Cache;
|
||||
use Tests\TestCase;
|
||||
|
||||
/**
|
||||
* 类功能:验证后台积分流水统计页能正确汇总指定日期数据。
|
||||
*/
|
||||
class AdminCurrencyStatsControllerTest extends TestCase
|
||||
{
|
||||
use RefreshDatabase;
|
||||
|
||||
/**
|
||||
* 验证后台积分流水统计页会返回指定日期的来源统计与净流通数据。
|
||||
*/
|
||||
public function test_admin_can_view_currency_stats_summary_for_selected_date(): void
|
||||
{
|
||||
Cache::flush();
|
||||
Sysparam::updateOrCreate(['alias' => 'superlevel'], ['body' => '100']);
|
||||
|
||||
$admin = User::factory()->create(['user_level' => 100]);
|
||||
$date = '2026-04-26';
|
||||
|
||||
UserCurrencyLog::query()->create([
|
||||
'user_id' => $admin->id,
|
||||
'username' => $admin->username,
|
||||
'currency' => 'gold',
|
||||
'amount' => 120,
|
||||
'balance_after' => 120,
|
||||
'source' => CurrencySource::SIGN_IN->value,
|
||||
'remark' => '签到奖励',
|
||||
'created_at' => "{$date} 10:00:00",
|
||||
]);
|
||||
|
||||
UserCurrencyLog::query()->create([
|
||||
'user_id' => $admin->id,
|
||||
'username' => $admin->username,
|
||||
'currency' => 'gold',
|
||||
'amount' => -20,
|
||||
'balance_after' => 100,
|
||||
'source' => CurrencySource::FISHING_COST->value,
|
||||
'remark' => '钓鱼消耗',
|
||||
'created_at' => "{$date} 11:00:00",
|
||||
]);
|
||||
|
||||
UserCurrencyLog::query()->create([
|
||||
'user_id' => $admin->id,
|
||||
'username' => $admin->username,
|
||||
'currency' => 'exp',
|
||||
'amount' => 80,
|
||||
'balance_after' => 80,
|
||||
'source' => CurrencySource::AUTO_SAVE->value,
|
||||
'remark' => '自动存点',
|
||||
'created_at' => "{$date} 12:00:00",
|
||||
]);
|
||||
|
||||
$response = $this->actingAs($admin)->get(route('admin.currency-stats.index', ['date' => $date]));
|
||||
|
||||
$response->assertOk();
|
||||
$response->assertViewIs('admin.currency-stats.index');
|
||||
$response->assertViewHas('date', $date);
|
||||
$response->assertViewHas('netFlow', [
|
||||
'exp' => ['in' => 80, 'out' => 0, 'net' => 80],
|
||||
'gold' => ['in' => 120, 'out' => 20, 'net' => 100],
|
||||
'charm' => ['in' => 0, 'out' => 0, 'net' => 0],
|
||||
]);
|
||||
|
||||
$statsByType = $response->viewData('statsByType');
|
||||
|
||||
$this->assertSame(120, (int) $statsByType['gold'][CurrencySource::SIGN_IN->value]->total_amount);
|
||||
$this->assertSame(80, (int) $statsByType['exp'][CurrencySource::AUTO_SAVE->value]->total_amount);
|
||||
}
|
||||
}
|
||||
@@ -23,6 +23,24 @@ class AdminUserManagerTest extends TestCase
|
||||
{
|
||||
use RefreshDatabase;
|
||||
|
||||
/**
|
||||
* 方法功能:验证后台用户管理页可以正常打开并展示核心文案。
|
||||
*/
|
||||
public function test_site_owner_can_view_user_manager_page(): void
|
||||
{
|
||||
$siteOwner = $this->createSiteOwner();
|
||||
User::factory()->create([
|
||||
'username' => 'viewer-target',
|
||||
]);
|
||||
|
||||
$response = $this->actingAs($siteOwner)->get(route('admin.users.index'));
|
||||
|
||||
$response->assertOk();
|
||||
$response->assertSee('用户检索与管理');
|
||||
$response->assertSee('注册名');
|
||||
$response->assertSee('管理操作');
|
||||
}
|
||||
|
||||
/**
|
||||
* 方法功能:验证站长可以在用户编辑页直接任命职务。
|
||||
*/
|
||||
|
||||
@@ -2,16 +2,24 @@
|
||||
|
||||
namespace Tests\Feature;
|
||||
|
||||
use App\Enums\CurrencySource;
|
||||
use App\Models\Sysparam;
|
||||
use App\Models\User;
|
||||
use App\Models\UserCurrencyLog;
|
||||
use Illuminate\Foundation\Testing\RefreshDatabase;
|
||||
use Tests\TestCase;
|
||||
|
||||
/**
|
||||
* 功能说明:验证排行榜与个人积分流水页面的访问和筛选行为。
|
||||
*/
|
||||
class LeaderboardControllerTest extends TestCase
|
||||
{
|
||||
use RefreshDatabase;
|
||||
|
||||
public function test_can_view_leaderboard_index()
|
||||
/**
|
||||
* 验证用户可以访问排行榜首页并看到过滤后的榜单数据。
|
||||
*/
|
||||
public function test_can_view_leaderboard_index(): void
|
||||
{
|
||||
$user = User::factory()->create(['exp_num' => 10, 'jjb' => 100, 'meili' => 5]);
|
||||
|
||||
@@ -51,7 +59,10 @@ class LeaderboardControllerTest extends TestCase
|
||||
$this->assertEquals(50, $topCharm->first()->meili);
|
||||
}
|
||||
|
||||
public function test_can_view_today_leaderboard()
|
||||
/**
|
||||
* 验证用户可以访问今日排行榜页面。
|
||||
*/
|
||||
public function test_can_view_today_leaderboard(): void
|
||||
{
|
||||
$user = User::factory()->create();
|
||||
|
||||
@@ -61,7 +72,10 @@ class LeaderboardControllerTest extends TestCase
|
||||
$response->assertViewIs('leaderboard.today');
|
||||
}
|
||||
|
||||
public function test_can_view_my_currency_logs()
|
||||
/**
|
||||
* 验证用户可以访问自己的积分流水页面。
|
||||
*/
|
||||
public function test_can_view_my_currency_logs(): void
|
||||
{
|
||||
$user = User::factory()->create();
|
||||
|
||||
@@ -70,4 +84,84 @@ class LeaderboardControllerTest extends TestCase
|
||||
$response->assertStatus(200);
|
||||
$response->assertViewIs('leaderboard.my-logs');
|
||||
}
|
||||
|
||||
/**
|
||||
* 验证个人积分流水可以按收入和支出 tab 分开筛选。
|
||||
*/
|
||||
public function test_can_filter_my_currency_logs_by_direction(): void
|
||||
{
|
||||
$user = User::factory()->create();
|
||||
|
||||
UserCurrencyLog::query()->create([
|
||||
'user_id' => $user->id,
|
||||
'username' => $user->username,
|
||||
'currency' => 'gold',
|
||||
'amount' => 100,
|
||||
'balance_after' => 100,
|
||||
'source' => 'admin_adjust',
|
||||
'remark' => '测试收入',
|
||||
'created_at' => now(),
|
||||
]);
|
||||
|
||||
UserCurrencyLog::query()->create([
|
||||
'user_id' => $user->id,
|
||||
'username' => $user->username,
|
||||
'currency' => 'gold',
|
||||
'amount' => -30,
|
||||
'balance_after' => 70,
|
||||
'source' => 'admin_adjust',
|
||||
'remark' => '测试支出',
|
||||
'created_at' => now(),
|
||||
]);
|
||||
|
||||
$incomeResponse = $this->actingAs($user)->get(route('currency.my-logs', ['direction' => 'income']));
|
||||
|
||||
$incomeResponse->assertStatus(200);
|
||||
$this->assertSame([100], $incomeResponse->viewData('logs')->pluck('amount')->all());
|
||||
$this->assertSame('income', $incomeResponse->viewData('direction'));
|
||||
|
||||
$expenseResponse = $this->actingAs($user)->get(route('currency.my-logs', ['direction' => 'expense']));
|
||||
|
||||
$expenseResponse->assertStatus(200);
|
||||
$this->assertSame([-30], $expenseResponse->viewData('logs')->pluck('amount')->all());
|
||||
$this->assertSame('expense', $expenseResponse->viewData('direction'));
|
||||
}
|
||||
|
||||
/**
|
||||
* 验证个人积分流水可以按多个来源叠加筛选。
|
||||
*/
|
||||
public function test_can_filter_my_currency_logs_by_multiple_sources(): void
|
||||
{
|
||||
$user = User::factory()->create();
|
||||
|
||||
foreach ([CurrencySource::AUTO_SAVE, CurrencySource::SIGN_IN, CurrencySource::ADMIN_ADJUST] as $index => $source) {
|
||||
UserCurrencyLog::query()->create([
|
||||
'user_id' => $user->id,
|
||||
'username' => $user->username,
|
||||
'currency' => 'gold',
|
||||
'amount' => 10 + $index,
|
||||
'balance_after' => 100 + $index,
|
||||
'source' => $source->value,
|
||||
'remark' => $source->label(),
|
||||
'created_at' => now()->subMinutes($index),
|
||||
]);
|
||||
}
|
||||
|
||||
$response = $this->actingAs($user)->get(route('currency.my-logs', [
|
||||
'sources' => [
|
||||
CurrencySource::AUTO_SAVE->value,
|
||||
CurrencySource::SIGN_IN->value,
|
||||
],
|
||||
]));
|
||||
|
||||
$response->assertStatus(200);
|
||||
$this->assertSame(
|
||||
[CurrencySource::AUTO_SAVE->value, CurrencySource::SIGN_IN->value],
|
||||
$response->viewData('logs')->pluck('source')->sort()->values()->all()
|
||||
);
|
||||
$this->assertSame(
|
||||
[CurrencySource::AUTO_SAVE->value, CurrencySource::SIGN_IN->value],
|
||||
$response->viewData('selectedSources')
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user