707 lines
25 KiB
PHP
707 lines
25 KiB
PHP
<?php
|
|
|
|
namespace Tests;
|
|
|
|
use Cache;
|
|
use Redis;
|
|
use App\Models\User;
|
|
use App\Models\Player;
|
|
use App\Models\Texture;
|
|
use Illuminate\Support\Str;
|
|
use Illuminate\Foundation\Testing\WithoutMiddleware;
|
|
use Illuminate\Foundation\Testing\DatabaseTransactions;
|
|
|
|
class AdminControllerTest extends BrowserKitTestCase
|
|
{
|
|
use DatabaseTransactions;
|
|
|
|
protected function setUp(): void
|
|
{
|
|
// Do not use `WithoutMiddleware` trait
|
|
parent::setUp();
|
|
$this->actAs('admin');
|
|
}
|
|
|
|
public function testChartData()
|
|
{
|
|
factory(User::class)->create();
|
|
factory(Texture::class)->create();
|
|
$this->getJson('/admin/chart')
|
|
->seeJson(['labels' => [
|
|
trans('admin.index.user-registration'),
|
|
trans('admin.index.texture-uploads'),
|
|
]])
|
|
->seeJsonStructure(['labels', 'xAxis', 'data']);
|
|
}
|
|
|
|
public function testCustomize()
|
|
{
|
|
// Check if `color_scheme` is existed or not
|
|
$this->getJson('/admin/customize?action=color')
|
|
->seeJsonStructure(['errors' => ['color_scheme']]);
|
|
|
|
// Change color
|
|
$this->get('/admin/customize?action=color&color_scheme=purple')
|
|
->seeJson([
|
|
'code' => 0,
|
|
'message' => trans('admin.customize.change-color.success'),
|
|
]);
|
|
$this->assertEquals('purple', option('color_scheme'));
|
|
|
|
$this->visit('/admin/customize')
|
|
->type('url', 'home_pic_url')
|
|
->type('url', 'favicon_url')
|
|
->check('transparent_navbar')
|
|
->select('1', 'copyright_prefer')
|
|
->type('copyright', 'copyright_text')
|
|
->press('submit_homepage');
|
|
$this->assertEquals('url', option('home_pic_url'));
|
|
$this->assertEquals('url', option('favicon_url'));
|
|
$this->assertTrue(option('transparent_navbar'));
|
|
$this->assertEquals('1', option('copyright_prefer'));
|
|
$this->assertEquals('copyright', option('copyright_text'));
|
|
|
|
$this->visit('/admin/customize')
|
|
->type('css', 'custom_css')
|
|
->type('js', 'custom_js')
|
|
->press('submit_customJsCss');
|
|
$this->assertEquals('css', option('custom_css'));
|
|
$this->assertEquals('js', option('custom_js'));
|
|
}
|
|
|
|
public function testScore()
|
|
{
|
|
$this->visit('/admin/score')
|
|
->type('4', 'score_per_storage')
|
|
->type('6', 'private_score_per_storage')
|
|
->type('8', 'score_per_closet_item')
|
|
->uncheck('return_score')
|
|
->type('12', 'score_per_player')
|
|
->type('500', 'user_initial_score')
|
|
->press('submit_rate');
|
|
$this->assertEquals('4', option('score_per_storage'));
|
|
$this->assertEquals('6', option('private_score_per_storage'));
|
|
$this->assertEquals('8', option('score_per_closet_item'));
|
|
$this->assertFalse(option('return_score'));
|
|
$this->assertEquals('12', option('score_per_player'));
|
|
$this->assertEquals('500', option('user_initial_score'));
|
|
|
|
$this->visit('/admin/score')
|
|
->type('1', 'reporter_score_modification')
|
|
->type('2', 'reporter_reward_score')
|
|
->press('submit_report');
|
|
$this->assertEquals('1', option('reporter_score_modification'));
|
|
$this->assertEquals('2', option('reporter_reward_score'));
|
|
|
|
$this->visit('/admin/score')
|
|
->type('233', 'sign_score_from')
|
|
->type('666', 'sign_score_to')
|
|
->type('7', 'sign_gap_time')
|
|
->check('sign_after_zero')
|
|
->press('submit_sign');
|
|
$this->assertEquals('233,666', option('sign_score'));
|
|
$this->assertEquals('7', option('sign_gap_time'));
|
|
$this->assertTrue(option('sign_after_zero'));
|
|
|
|
$this->visit('/admin/score')
|
|
->type('1', 'score_award_per_texture')
|
|
->uncheck('take_back_scores_after_deletion')
|
|
->type('1', 'score_award_per_like')
|
|
->press('submit_sharing');
|
|
$this->assertEquals('1', option('score_award_per_texture'));
|
|
$this->assertFalse(option('take_back_scores_after_deletion'));
|
|
$this->assertEquals('1', option('score_award_per_like'));
|
|
}
|
|
|
|
public function testOptions()
|
|
{
|
|
$this->visit('/admin/options')
|
|
->type('My Site', 'site_name')
|
|
->type('hi', 'site_description')
|
|
->type('http://blessing.skin/', 'site_url')
|
|
->uncheck('user_can_register')
|
|
->type('8', 'regs_per_ip')
|
|
->select('1', 'ip_get_method')
|
|
->type('2048', 'max_upload_file_size')
|
|
->see(trans(
|
|
'options.general.max_upload_file_size.hint',
|
|
['size' => ini_get('upload_max_filesize')]
|
|
))
|
|
->select('cjk', 'player_name_rule')
|
|
->type('/^([0-9]+)$/', 'custom_player_name_regexp')
|
|
->select('1', 'api_type')
|
|
->check('auto_del_invalid_texture')
|
|
->uncheck('allow_downloading_texture')
|
|
->type('abc', 'texture_name_regexp')
|
|
->type('policy', 'content_policy')
|
|
->type('code', 'comment_script')
|
|
->press('submit_general');
|
|
$this->assertEquals('My Site', option_localized('site_name'));
|
|
$this->assertEquals('hi', option_localized('site_description'));
|
|
$this->assertEquals('http://blessing.skin', option('site_url'));
|
|
$this->assertFalse(option('user_can_register'));
|
|
$this->assertEquals('8', option('regs_per_ip'));
|
|
$this->assertEquals('1', option('ip_get_method'));
|
|
$this->assertEquals('2048', option('max_upload_file_size'));
|
|
$this->assertEquals('cjk', option('player_name_rule'));
|
|
$this->assertEquals('/^([0-9]+)$/', option('custom_player_name_regexp'));
|
|
$this->assertEquals('1', option('api_type'));
|
|
$this->assertTrue(option('auto_del_invalid_texture'));
|
|
$this->assertFalse(option('allow_downloading_texture'));
|
|
$this->assertEquals('abc', option('texture_name_regexp'));
|
|
$this->assertEquals('policy', option_localized('content_policy'));
|
|
$this->assertEquals('code', option('comment_script'));
|
|
|
|
$this->visit('/admin/options')
|
|
->type('http://blessing.skin/index.php', 'site_url')
|
|
->press('submit_general');
|
|
$this->assertEquals('http://blessing.skin', option('site_url'));
|
|
|
|
$this->visit('/admin/options')
|
|
->type('announcement', 'announcement')
|
|
->press('submit_announ');
|
|
$this->assertEquals('announcement', option_localized('announcement'));
|
|
|
|
$this->visit('/admin/options')
|
|
->type('kw', 'meta_keywords')
|
|
->type('desc', 'meta_description')
|
|
->type('<!-- nothing -->', 'meta_extras')
|
|
->press('submit_meta');
|
|
$this->visit('/')
|
|
->see('<meta name="keywords" content="kw">')
|
|
->see('<meta name="description" content="desc">')
|
|
->see('<!-- nothing -->');
|
|
|
|
$this->visit('/admin/options')
|
|
->type('key', 'recaptcha_sitekey')
|
|
->type('secret', 'recaptcha_secretkey')
|
|
->check('recaptcha_invisible')
|
|
->press('submit_recaptcha');
|
|
$this->assertEquals('key', option('recaptcha_sitekey'));
|
|
$this->assertEquals('secret', option('recaptcha_secretkey'));
|
|
$this->assertTrue(option('recaptcha_invisible'));
|
|
}
|
|
|
|
public function testResource()
|
|
{
|
|
$this->visit('/admin/resource')
|
|
->check('force_ssl')
|
|
->uncheck('auto_detect_asset_url')
|
|
->check('return_204_when_notfound')
|
|
->type('0', 'cache_expire_time')
|
|
->type('url/', 'cdn_address')
|
|
->press('submit_resources');
|
|
$this->assertTrue(option('force_ssl'));
|
|
$this->assertFalse(option('auto_detect_asset_url'));
|
|
$this->assertTrue(option('return_204_when_notfound'));
|
|
$this->assertEquals('0', option('cache_expire_time'));
|
|
$this->visit('/')->see('url/app/');
|
|
|
|
$this->visit('/admin/resource')
|
|
->type('', 'cdn_address')
|
|
->press('submit_resources');
|
|
$this->visit('/')->dontSee('url/app/index.js');
|
|
|
|
$this->visit('/admin/resource')
|
|
->check('enable_redis')
|
|
->press('submit_redis');
|
|
$this->assertTrue(option('enable_redis'));
|
|
|
|
Redis::shouldReceive('ping')->once()->andReturn(true);
|
|
$this->visit('/admin/resource')->see(trans('options.redis.connect.success'));
|
|
|
|
Redis::shouldReceive('ping')->once()->andThrow(new \Exception('fake'));
|
|
$this->visit('/admin/resource')
|
|
->see(trans('options.redis.connect.failed', ['msg' => 'fake']));
|
|
|
|
option(['enable_redis' => false]);
|
|
|
|
$this->visit('/admin/resource')
|
|
->see(trans('options.cache.driver', ['driver' => config('cache.default')]))
|
|
->check('enable_avatar_cache')
|
|
->check('enable_preview_cache')
|
|
->check('enable_json_cache')
|
|
->check('enable_notfound_cache')
|
|
->press('submit_cache');
|
|
$this->assertTrue(option('enable_avatar_cache'));
|
|
$this->assertTrue(option('enable_preview_cache'));
|
|
$this->assertTrue(option('enable_json_cache'));
|
|
$this->assertTrue(option('enable_notfound_cache'));
|
|
|
|
Cache::shouldReceive('flush');
|
|
$this->visit('/admin/resource')
|
|
->click(trans('options.cache.clear'))
|
|
->see(trans('options.cache.cleared'));
|
|
}
|
|
|
|
public function testUsers()
|
|
{
|
|
$this->visit('/admin/users')->see(trans('general.user-manage'));
|
|
}
|
|
|
|
public function testGetUserData()
|
|
{
|
|
$this->getJson('/admin/user-data')
|
|
->seeJsonStructure([
|
|
'data' => [[
|
|
'uid',
|
|
'email',
|
|
'nickname',
|
|
'score',
|
|
'permission',
|
|
'register_at',
|
|
'operations',
|
|
'players_count',
|
|
]],
|
|
]);
|
|
|
|
$user = factory(User::class)->create();
|
|
$this->getJson('/admin/user-data?uid='.$user->uid)
|
|
->seeJsonSubset([
|
|
'data' => [[
|
|
'uid' => $user->uid,
|
|
'email' => $user->email,
|
|
'nickname' => $user->nickname,
|
|
'score' => $user->score,
|
|
'permission' => $user->permission,
|
|
'players_count' => 0,
|
|
]],
|
|
]);
|
|
}
|
|
|
|
public function testPlayers()
|
|
{
|
|
$this->visit('/admin/players')->see(trans('general.player-manage'));
|
|
}
|
|
|
|
public function testGetPlayerData()
|
|
{
|
|
$player = factory(Player::class)->create();
|
|
$user = $player->user;
|
|
|
|
$this->getJson('/admin/player-data')
|
|
->seeJsonStructure([
|
|
'data' => [[
|
|
'pid',
|
|
'uid',
|
|
'name',
|
|
'tid_skin',
|
|
'tid_cape',
|
|
'last_modified',
|
|
]],
|
|
]);
|
|
|
|
$this->getJson('/admin/player-data?uid='.$user->uid)
|
|
->seeJsonSubset([
|
|
'data' => [[
|
|
'pid' => $player->pid,
|
|
'uid' => $user->uid,
|
|
'name' => $player->name,
|
|
'tid_skin' => $player->tid_skin,
|
|
'tid_cape' => $player->tid_cape,
|
|
]],
|
|
]);
|
|
}
|
|
|
|
public function testUserAjaxHandler()
|
|
{
|
|
// Operate on an not-existed user
|
|
$this->postJson('/admin/users')
|
|
->seeJson([
|
|
'code' => 1,
|
|
'message' => trans('admin.users.operations.non-existent'),
|
|
]);
|
|
|
|
$user = factory(User::class)->create();
|
|
|
|
// Operate without `action` field
|
|
$this->postJson('/admin/users', ['uid' => $user->uid])
|
|
->seeJson([
|
|
'code' => 1,
|
|
'message' => trans('admin.users.operations.invalid'),
|
|
]);
|
|
|
|
// An admin operating on a super admin should be forbidden
|
|
$superAdmin = factory(User::class, 'superAdmin')->create();
|
|
$this->postJson('/admin/users', ['uid' => $superAdmin->uid])
|
|
->seeJson([
|
|
'code' => 1,
|
|
'message' => trans('admin.users.operations.no-permission'),
|
|
]);
|
|
|
|
// Action is `email` but without `email` field
|
|
$this->postJson(
|
|
'/admin/users',
|
|
['uid' => $user->uid, 'action' => 'email'],
|
|
['Accept' => 'application/json']
|
|
)->seeJsonStructure(['errors' => ['email']]);
|
|
|
|
// Action is `email` but with an invalid email address
|
|
$this->postJson(
|
|
'/admin/users',
|
|
['uid' => $user->uid, 'action' => 'email', 'email' => 'invalid'],
|
|
['Accept' => 'application/json']
|
|
)->seeJsonStructure(['errors' => ['email']]);
|
|
|
|
// Using an existed email address
|
|
$this->postJson(
|
|
'/admin/users',
|
|
['uid' => $user->uid, 'action' => 'email', 'email' => $superAdmin->email]
|
|
)->seeJson([
|
|
'code' => 1,
|
|
'message' => trans('admin.users.operations.email.existed', ['email' => $superAdmin->email]),
|
|
]);
|
|
|
|
// Set email successfully
|
|
$this->postJson(
|
|
'/admin/users',
|
|
['uid' => $user->uid, 'action' => 'email', 'email' => 'a@b.c']
|
|
)->seeJson([
|
|
'code' => 0,
|
|
'message' => trans('admin.users.operations.email.success'),
|
|
]);
|
|
$this->seeInDatabase('users', [
|
|
'uid' => $user->uid,
|
|
'email' => 'a@b.c',
|
|
]);
|
|
|
|
// Toggle verification
|
|
$this->postJson(
|
|
'/admin/users',
|
|
['uid' => $user->uid, 'action' => 'verification']
|
|
)->seeJson([
|
|
'code' => 0,
|
|
'message' => trans('admin.users.operations.verification.success'),
|
|
]);
|
|
$this->seeInDatabase('users', [
|
|
'uid' => $user->uid,
|
|
'verified' => 0,
|
|
]);
|
|
|
|
// Action is `nickname` but without `nickname` field
|
|
$this->postJson(
|
|
'/admin/users',
|
|
['uid' => $user->uid, 'action' => 'nickname'],
|
|
['Accept' => 'application/json']
|
|
)->seeJsonStructure(['errors' => ['nickname']]);
|
|
|
|
// Action is `nickname` but with an invalid nickname
|
|
$this->postJson(
|
|
'/admin/users',
|
|
['uid' => $user->uid, 'action' => 'nickname', 'nickname' => '\\'],
|
|
['Accept' => 'application/json']
|
|
)->seeJsonStructure(['errors' => ['nickname']]);
|
|
|
|
// Set nickname successfully
|
|
$this->postJson(
|
|
'/admin/users',
|
|
['uid' => $user->uid, 'action' => 'nickname', 'nickname' => 'nickname']
|
|
)->seeJson([
|
|
'code' => 0,
|
|
'message' => trans('admin.users.operations.nickname.success', ['new' => 'nickname']),
|
|
]);
|
|
$this->seeInDatabase('users', [
|
|
'uid' => $user->uid,
|
|
'nickname' => 'nickname',
|
|
]);
|
|
|
|
// Action is `password` but without `password` field
|
|
$this->postJson(
|
|
'/admin/users',
|
|
['uid' => $user->uid, 'action' => 'password'],
|
|
['Accept' => 'application/json']
|
|
)->seeJsonStructure(['errors' => ['password']]);
|
|
|
|
// Set a too short password
|
|
$this->postJson(
|
|
'/admin/users',
|
|
['uid' => $user->uid, 'action' => 'password', 'password' => '1'],
|
|
['Accept' => 'application/json']
|
|
)->seeJsonStructure(['errors' => ['password']]);
|
|
|
|
// Set a too long password
|
|
$this->postJson(
|
|
'/admin/users',
|
|
['uid' => $user->uid, 'action' => 'password', 'password' => Str::random(17)],
|
|
['Accept' => 'application/json']
|
|
)->seeJsonStructure(['errors' => ['password']]);
|
|
|
|
// Set password successfully
|
|
$this->postJson(
|
|
'/admin/users',
|
|
['uid' => $user->uid, 'action' => 'password', 'password' => '12345678']
|
|
)->seeJson([
|
|
'code' => 0,
|
|
'message' => trans('admin.users.operations.password.success'),
|
|
]);
|
|
$user = User::find($user->uid);
|
|
$this->assertTrue($user->verifyPassword('12345678'));
|
|
|
|
// Action is `score` but without `score` field
|
|
$this->postJson(
|
|
'/admin/users',
|
|
['uid' => $user->uid, 'action' => 'score'],
|
|
['Accept' => 'application/json']
|
|
)->seeJsonStructure(['errors' => ['score']]);
|
|
|
|
// Action is `score` but with an not-an-integer value
|
|
$this->postJson(
|
|
'/admin/users',
|
|
['uid' => $user->uid, 'action' => 'score', 'score' => 'string'],
|
|
['Accept' => 'application/json']
|
|
)->seeJsonStructure(['errors' => ['score']]);
|
|
|
|
// Set score successfully
|
|
$this->postJson(
|
|
'/admin/users',
|
|
['uid' => $user->uid, 'action' => 'score', 'score' => 123]
|
|
)->seeJson([
|
|
'code' => 0,
|
|
'message' => trans('admin.users.operations.score.success'),
|
|
]);
|
|
$this->seeInDatabase('users', [
|
|
'uid' => $user->uid,
|
|
'score' => 123,
|
|
]);
|
|
|
|
// Invalid permission value
|
|
$this->postJson('/admin/users', [
|
|
'uid' => $user->uid,
|
|
'action' => 'permission',
|
|
'permission' => -2,
|
|
])->seeJsonStructure(['errors' => ['permission']]);
|
|
$user = User::find($user->uid);
|
|
$this->assertEquals(User::NORMAL, $user->permission);
|
|
|
|
// Update permission successfully
|
|
$this->postJson('/admin/users', [
|
|
'uid' => $user->uid,
|
|
'action' => 'permission',
|
|
'permission' => -1,
|
|
])->seeJson([
|
|
'code' => 0,
|
|
'message' => trans('admin.users.operations.permission'),
|
|
]);
|
|
$user = User::find($user->uid);
|
|
$this->assertEquals(User::BANNED, $user->permission);
|
|
|
|
// Delete a user
|
|
$this->postJson('/admin/users', ['uid' => $user->uid, 'action' => 'delete'])
|
|
->seeJson([
|
|
'code' => 0,
|
|
'message' => trans('admin.users.operations.delete.success'),
|
|
]);
|
|
$this->assertNull(User::find($user->uid));
|
|
}
|
|
|
|
public function testPlayerAjaxHandler()
|
|
{
|
|
$player = factory(Player::class)->create();
|
|
|
|
// Operate on a not-existed player
|
|
$this->postJson('/admin/players', ['pid' => -1])
|
|
->seeJson([
|
|
'code' => 1,
|
|
'message' => trans('general.unexistent-player'),
|
|
]);
|
|
|
|
// An admin cannot operate another admin's player
|
|
$admin = factory(User::class, 'admin')->create();
|
|
$this->postJson(
|
|
'/admin/players',
|
|
['pid' => factory(Player::class)->create(['uid' => $admin->uid])->pid]
|
|
)->seeJson([
|
|
'code' => 1,
|
|
'message' => trans('admin.players.no-permission'),
|
|
]);
|
|
$superAdmin = factory(User::class, 'superAdmin')->create();
|
|
$this->postJson(
|
|
'/admin/players',
|
|
['pid' => factory(Player::class)->create(['uid' => $superAdmin->uid])->pid]
|
|
)->seeJson([
|
|
'code' => 1,
|
|
'message' => trans('admin.players.no-permission'),
|
|
]);
|
|
// For self is OK
|
|
$this->actingAs($admin)->postJson(
|
|
'/admin/players',
|
|
['pid' => factory(Player::class)->create(['uid' => $admin->uid])->pid]
|
|
)->seeJson([
|
|
'code' => 1,
|
|
'message' => trans('admin.users.operations.invalid'),
|
|
]);
|
|
|
|
// Change texture without `type` field
|
|
$this->postJson('/admin/players', [
|
|
'pid' => $player->pid,
|
|
'action' => 'texture',
|
|
], [
|
|
'Accept' => 'application/json',
|
|
])->seeJsonStructure(['errors' => ['type']]);
|
|
|
|
// Change texture without `tid` field
|
|
$this->postJson('/admin/players', [
|
|
'pid' => $player->pid,
|
|
'action' => 'texture',
|
|
'type' => 'skin',
|
|
], [
|
|
'Accept' => 'application/json',
|
|
])->seeJsonStructure(['errors' => ['tid']]);
|
|
|
|
// Change texture with a not-integer value
|
|
$this->postJson('/admin/players', [
|
|
'pid' => $player->pid,
|
|
'action' => 'texture',
|
|
'type' => 'skin',
|
|
'tid' => 'string',
|
|
], [
|
|
'Accept' => 'application/json',
|
|
])->seeJsonStructure(['errors' => ['tid']]);
|
|
|
|
// Invalid texture
|
|
$this->postJson('/admin/players', [
|
|
'pid' => $player->pid,
|
|
'action' => 'texture',
|
|
'type' => 'skin',
|
|
'tid' => -1,
|
|
])->seeJson([
|
|
'code' => 1,
|
|
'message' => trans('admin.players.textures.non-existent', ['tid' => -1]),
|
|
]);
|
|
|
|
$skin = factory(Texture::class)->create();
|
|
$cape = factory(Texture::class, 'cape')->create();
|
|
|
|
// Skin
|
|
$this->postJson('/admin/players', [
|
|
'pid' => $player->pid,
|
|
'action' => 'texture',
|
|
'type' => 'skin',
|
|
'tid' => $skin->tid,
|
|
])->seeJson([
|
|
'code' => 0,
|
|
'message' => trans('admin.players.textures.success', ['player' => $player->name]),
|
|
]);
|
|
$player = Player::find($player->pid);
|
|
$this->assertEquals($skin->tid, $player->tid_skin);
|
|
|
|
// Cape
|
|
$this->postJson('/admin/players', [
|
|
'pid' => $player->pid,
|
|
'action' => 'texture',
|
|
'type' => 'cape',
|
|
'tid' => $cape->tid,
|
|
])->seeJson([
|
|
'code' => 0,
|
|
'message' => trans('admin.players.textures.success', ['player' => $player->name]),
|
|
]);
|
|
$player = Player::find($player->pid);
|
|
$this->assertEquals($cape->tid, $player->tid_cape);
|
|
|
|
// Reset texture
|
|
$this->postJson('/admin/players', [
|
|
'pid' => $player->pid,
|
|
'action' => 'texture',
|
|
'type' => 'skin',
|
|
'tid' => 0,
|
|
])->seeJson([
|
|
'code' => 0,
|
|
'message' => trans('admin.players.textures.success', ['player' => $player->name]),
|
|
]);
|
|
$player = Player::find($player->pid);
|
|
$this->assertEquals(0, $player->tid_skin);
|
|
$this->assertNotEquals(0, $player->tid_cape);
|
|
|
|
$this->postJson('/admin/players', [
|
|
'pid' => $player->pid,
|
|
'action' => 'texture',
|
|
'type' => 'cape',
|
|
'tid' => 0,
|
|
])->seeJson([
|
|
'code' => 0,
|
|
'message' => trans('admin.players.textures.success', ['player' => $player->name]),
|
|
]);
|
|
$player = Player::find($player->pid);
|
|
$this->assertEquals(0, $player->tid_cape);
|
|
|
|
// Change owner without `uid` field
|
|
$this->postJson('/admin/players', [
|
|
'pid' => $player->pid,
|
|
'action' => 'owner',
|
|
], [
|
|
'Accept' => 'application/json',
|
|
])->seeJsonStructure(['errors' => ['uid']]);
|
|
|
|
// Change owner with a not-integer `uid` value
|
|
$this->postJson('/admin/players', [
|
|
'pid' => $player->pid,
|
|
'action' => 'owner',
|
|
'uid' => 'string',
|
|
], [
|
|
'Accept' => 'application/json',
|
|
])->seeJsonStructure(['errors' => ['uid']]);
|
|
|
|
// Change owner to a not-existed user
|
|
$this->postJson('/admin/players', [
|
|
'pid' => $player->pid,
|
|
'action' => 'owner',
|
|
'uid' => -1,
|
|
])->seeJson([
|
|
'code' => 1,
|
|
'message' => trans('admin.users.operations.non-existent'),
|
|
]);
|
|
|
|
// Change owner successfully
|
|
$user = factory(User::class)->create();
|
|
$this->postJson('/admin/players', [
|
|
'pid' => $player->pid,
|
|
'action' => 'owner',
|
|
'uid' => $user->uid,
|
|
])->seeJson([
|
|
'code' => 0,
|
|
'message' => trans(
|
|
'admin.players.owner.success',
|
|
['player' => $player->name, 'user' => $user->nickname]
|
|
),
|
|
]);
|
|
|
|
// Rename a player without `name` field
|
|
$this->postJson('/admin/players', [
|
|
'pid' => $player->pid,
|
|
'action' => 'name',
|
|
], [
|
|
'Accept' => 'application/json',
|
|
])->seeJsonStructure(['errors' => ['name']]);
|
|
|
|
// Rename a player successfully
|
|
$this->postJson('/admin/players', [
|
|
'pid' => $player->pid,
|
|
'action' => 'name',
|
|
'name' => 'new_name',
|
|
])->seeJson([
|
|
'code' => 0,
|
|
'message' => trans('admin.players.name.success', ['player' => 'new_name']),
|
|
]);
|
|
|
|
// Single player
|
|
option(['single_player' => true]);
|
|
$this->postJson('/admin/players', [
|
|
'pid' => $player->pid,
|
|
'action' => 'name',
|
|
'name' => 'abc',
|
|
])->seeJson(['code' => 0]);
|
|
$player->refresh();
|
|
$this->assertEquals('abc', $player->user->nickname);
|
|
|
|
// Delete a player
|
|
$this->postJson('/admin/players', [
|
|
'pid' => $player->pid,
|
|
'action' => 'delete',
|
|
])->seeJson([
|
|
'code' => 0,
|
|
'message' => trans('admin.players.delete.success'),
|
|
]);
|
|
$this->assertNull(Player::find($player->pid));
|
|
}
|
|
}
|