create([ 'username' => 'player_manage_admin', 'name' => 'Player Manage Admin', 'email' => null, 'password' => Hash::make('secret-strong'), 'status' => 0, ]); grantSuperAdminRole($admin); return $admin->createToken('test', ['*'], now()->addDay())->plainTextToken; } test('admin can freeze and unfreeze player with audit log', function (): void { $player = Player::query()->create([ 'site_code' => 'main', 'site_player_id' => 'freeze-1', 'username' => 'freeze_user', 'nickname' => 'Freeze', 'default_currency' => 'NPR', 'status' => 0, ]); PlayerWallet::query()->create([ 'player_id' => $player->id, 'wallet_type' => 'lottery', 'currency_code' => 'NPR', 'balance' => 1_000, 'frozen_balance' => 0, 'status' => 0, 'version' => 0, ]); $token = playerManageAdminToken(); $this->withHeader('Authorization', 'Bearer '.$token) ->postJson('/api/v1/admin/players/'.$player->id.'/freeze') ->assertOk() ->assertJsonPath('data.status', 1); $this->assertDatabaseHas('audit_logs', [ 'module_code' => 'player_manage', 'action_code' => 'freeze', 'target_type' => 'player', 'target_id' => (string) $player->id, ]); $this->withHeader('Authorization', 'Bearer '.$token) ->postJson('/api/v1/admin/players/'.$player->id.'/unfreeze') ->assertOk() ->assertJsonPath('data.status', 0); expect(AuditLog::query()->where('module_code', 'player_manage')->count())->toBe(2); });