Better tests for User Controller

This commit is contained in:
Phan An 2018-08-22 21:40:04 +02:00
parent 3efcc9a049
commit 61bc21c303
2 changed files with 68 additions and 23 deletions

View file

@ -6,13 +6,20 @@ use App\Http\Requests\API\UserStoreRequest;
use App\Http\Requests\API\UserUpdateRequest; use App\Http\Requests\API\UserUpdateRequest;
use App\Models\User; use App\Models\User;
use Exception; use Exception;
use Hash;
use Illuminate\Auth\Access\AuthorizationException; use Illuminate\Auth\Access\AuthorizationException;
use Illuminate\Contracts\Hashing\Hasher as Hash;
use Illuminate\Http\JsonResponse; use Illuminate\Http\JsonResponse;
use RuntimeException; use RuntimeException;
class UserController extends Controller class UserController extends Controller
{ {
private $hash;
public function __construct(Hash $hash)
{
$this->hash = $hash;
}
/** /**
* Create a new user. * Create a new user.
* *
@ -27,7 +34,7 @@ class UserController extends Controller
return response()->json(User::create([ return response()->json(User::create([
'name' => $request->name, 'name' => $request->name,
'email' => $request->email, 'email' => $request->email,
'password' => Hash::make($request->password), 'password' => $this->hash->make($request->password),
])); ]));
} }
@ -46,7 +53,7 @@ class UserController extends Controller
$data = $request->only('name', 'email'); $data = $request->only('name', 'email');
if ($request->password) { if ($request->password) {
$data['password'] = Hash::make($request->password); $data['password'] = $this->hash->make($request->password);
} }
return response()->json($user->update($data)); return response()->json($user->update($data));

View file

@ -3,34 +3,64 @@
namespace Tests\Feature; namespace Tests\Feature;
use App\Models\User; use App\Models\User;
use Illuminate\Contracts\Hashing\Hasher;
use Mockery\MockInterface;
class UserTest extends TestCase class UserTest extends TestCase
{ {
/** @test */ /** @var MockInterface */
public function admin_can_create_a_user() private $hash;
{
// Non-admins can't do shit public function setUp()
$this->postAsUser('api/user', [ {
'name' => 'Foo', parent::setUp();
'email' => 'bar@baz.com', $this->hash = $this->mockIocDependency(Hasher::class);
'password' => 'qux', }
])
->seeStatusCode(403); public function testNonAdminCannotCreateUser()
{
$this->postAsUser('api/user', [
'name' => 'Foo',
'email' => 'bar@baz.com',
'password' => 'qux',
])->seeStatusCode(403);
}
public function testAdminCreatesUser()
{
$this->hash
->shouldReceive('make')
->once()
->with('qux')
->andReturn('hashed');
// But admins can
$this->postAsUser('api/user', [ $this->postAsUser('api/user', [
'name' => 'Foo', 'name' => 'Foo',
'email' => 'bar@baz.com', 'email' => 'bar@baz.com',
'password' => 'qux', 'password' => 'qux',
], factory(User::class, 'admin')->create()); ], factory(User::class, 'admin')->create());
$this->seeInDatabase('users', ['name' => 'Foo']); self::seeInDatabase('users', [
'name' => 'Foo',
'email' => 'bar@baz.com',
'password' => 'hashed',
]);
} }
/** @test */ public function testAdminUpdatesUser()
public function admin_can_update_a_user()
{ {
$user = factory(User::class)->create(); /** @var User $user */
$user = factory(User::class)->create([
'name' => 'John',
'email' => 'john@doe.com',
'password' => 'nope',
]);
$this->hash
->shouldReceive('make')
->once()
->with('qux')
->andReturn('hashed');
$this->putAsUser("api/user/{$user->id}", [ $this->putAsUser("api/user/{$user->id}", [
'name' => 'Foo', 'name' => 'Foo',
@ -38,17 +68,26 @@ class UserTest extends TestCase
'password' => 'qux', 'password' => 'qux',
], factory(User::class, 'admin')->create()); ], factory(User::class, 'admin')->create());
$this->seeInDatabase('users', ['name' => 'Foo', 'email' => 'bar@baz.com']); self::seeInDatabase('users', [
'id' => $user->id,
'name' => 'Foo',
'email' => 'bar@baz.com',
'password' => 'hashed',
]);
} }
/** @test */ public function testAdminDeletesUser()
public function admin_can_delete_a_user()
{ {
$user = factory(User::class)->create(); $user = factory(User::class)->create();
$admin = factory(User::class, 'admin')->create(); $admin = factory(User::class, 'admin')->create();
$this->deleteAsUser("api/user/{$user->id}", [], $admin) $this->deleteAsUser("api/user/{$user->id}", [], $admin)
->notSeeInDatabase('users', ['id' => $user->id]); ->notSeeInDatabase('users', ['id' => $user->id]);
}
public function testSeppukuNotAllowed()
{
$admin = factory(User::class, 'admin')->create();
// A user can't delete himself // A user can't delete himself
$this->deleteAsUser("api/user/{$admin->id}", [], $admin) $this->deleteAsUser("api/user/{$admin->id}", [], $admin)
@ -56,8 +95,7 @@ class UserTest extends TestCase
->seeInDatabase('users', ['id' => $admin->id]); ->seeInDatabase('users', ['id' => $admin->id]);
} }
/** @test */ public function testUpdateUserProfile()
public function user_can_update_their_preferences()
{ {
$user = factory(User::class)->create(); $user = factory(User::class)->create();
$this->assertNull($user->getPreference('foo')); $this->assertNull($user->getPreference('foo'));