You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 

295 lines
9.0 KiB

<?php
namespace Tests\Feature;
use App\User;
use Illuminate\Foundation\Testing\RefreshDatabase;
use Storage;
use Tests\TestCase;
class UsersProfileTest extends TestCase
{
use RefreshDatabase;
/** @test */
public function guest_can_search_users_profile()
{
$jono = factory(User::class)->create(['name' => 'Jono']);
$jeni = factory(User::class)->create(['name' => 'Jeni']);
$johan = factory(user::class)->create(['name' => 'Johan']);
$this->visitRoute('users.search', ['q' => 'jo']);
$this->seeRouteIs('users.search', ['q' => 'jo']);
$this->seeText('Jono');
$this->seeText('Johan');
$this->dontSeeText('Jeni');
}
/** @test */
public function user_can_view_other_users_profile()
{
$user = factory(User::class)->create();
$this->visit(route('users.show', $user->id));
$this->see($user->name);
}
/** @test */
public function user_will_see_edit_profile_if_an_invalid_tab_selected()
{
$user = $this->loginAsUser();
$this->visit(route('users.edit', [$user->id, 'tab' => 'invalid_tab']));
$this->seePageIs(route('users.edit', [$user->id, 'tab' => 'invalid_tab']));
$this->seeElement('input', ['name' => 'nickname']);
$this->seeElement('input', ['name' => 'name']);
}
/** @test */
public function user_can_edit_profile()
{
$user = $this->loginAsUser();
$this->visit(route('users.edit', $user->id));
$this->seePageIs(route('users.edit', $user->id));
$this->submitForm(trans('app.update'), [
'nickname' => 'Nama Panggilan',
'name' => 'Nama User',
'gender_id' => 1,
'dob' => '1959-06-09',
'yob' => '',
'birth_order' => 3,
]);
$this->seeInDatabase('users', [
'nickname' => 'Nama Panggilan',
'name' => 'Nama User',
'gender_id' => 1,
'dob' => '1959-06-09',
'yob' => '1959',
'birth_order' => 3,
]);
}
/** @test */
public function user_can_update_yob_only()
{
$user = $this->loginAsUser();
$this->visit(route('users.edit', $user->id));
$this->seePageIs(route('users.edit', $user->id));
$this->submitForm(trans('app.update'), [
'dob' => '',
'yob' => '2003',
]);
$this->seeInDatabase('users', [
'id' => $user->id,
'dob' => null,
'yob' => '2003',
]);
}
/** @test */
public function user_can_edit_contact_address()
{
$user = $this->loginAsUser();
$this->visit(route('users.edit', [$user->id, 'tab' => 'contact_address']));
$this->seePageIs(route('users.edit', [$user->id, 'tab' => 'contact_address']));
$this->submitForm(trans('app.update'), [
'address' => 'Jln. Angkasa, No. 70',
'city' => 'Nama Kota',
'phone' => '081234567890',
]);
$this->seeInDatabase('users', [
'id' => $user->id,
'address' => 'Jln. Angkasa, No. 70',
'city' => 'Nama Kota',
'phone' => '081234567890',
]);
}
/** @test */
public function user_can_edit_login_account()
{
$user = $this->loginAsUser();
$this->visit(route('users.edit', [$user->id, 'tab' => 'login_account']));
$this->seePageIs(route('users.edit', [$user->id, 'tab' => 'login_account']));
$this->submitForm(trans('app.update'), [
'email' => '',
'password' => '',
]);
$this->seeInDatabase('users', [
'id' => $user->id,
'email' => null,
'password' => null,
]);
}
/** @test */
public function user_can_edit_death()
{
$user = $this->loginAsUser();
$this->visit(route('users.edit', [$user->id, 'tab' => 'death']));
$this->seePageIs(route('users.edit', [$user->id, 'tab' => 'death']));
$this->submitForm(trans('app.update'), [
'dod' => '2003-10-17',
'yod' => '',
]);
$this->seeInDatabase('users', [
'id' => $user->id,
'dod' => '2003-10-17',
'yod' => '2003',
]);
}
/** @test */
public function user_can_update_yod_only()
{
$user = $this->loginAsUser();
$this->visit(route('users.edit', [$user->id, 'tab' => 'death']));
$this->seePageIs(route('users.edit', [$user->id, 'tab' => 'death']));
$this->submitForm(trans('app.update'), [
'dod' => '',
'yod' => '2003',
]);
$this->seeInDatabase('users', [
'id' => $user->id,
'dod' => null,
'yod' => '2003',
]);
}
/** @test */
public function user_can_update_died_person_cemetary_location()
{
$user = $this->loginAsUser();
$this->visit(route('users.edit', [$user->id, 'tab' => 'death']));
$this->seePageIs(route('users.edit', [$user->id, 'tab' => 'death']));
$this->submitForm(trans('app.update'), [
'dod' => '',
'yod' => '2003',
'cemetery_location_name' => 'Some name',
'cemetery_location_address' => 'Some address',
'cemetery_location_latitude' => '-3.333333',
'cemetery_location_longitude' => '114.583333',
]);
$this->seeInDatabase('users', [
'id' => $user->id,
'dod' => null,
'yod' => '2003',
]);
$this->seeInDatabase('user_metadata', [
'user_id' => $user->id,
'name' => 'cemetery_location_name',
'value' => 'Some name',
]);
$this->seeInDatabase('user_metadata', [
'user_id' => $user->id,
'name' => 'cemetery_location_address',
'value' => 'Some address',
]);
$this->seeInDatabase('user_metadata', [
'user_id' => $user->id,
'name' => 'cemetery_location_latitude',
'value' => '-3.333333',
]);
$this->seeInDatabase('user_metadata', [
'user_id' => $user->id,
'name' => 'cemetery_location_longitude',
'value' => '114.583333',
]);
}
/** @test */
public function manager_can_add_login_account_on_a_user()
{
$manager = $this->loginAsUser();
$user = factory(User::class)->create(['manager_id' => $manager->id]);
$this->visit(route('users.edit', [$user->id, 'tab' => 'login_account']));
$this->seePageIs(route('users.edit', [$user->id, 'tab' => 'login_account']));
$this->submitForm(trans('app.update'), [
'email' => 'user@mail.com',
'password' => 'Secr3t',
]);
$user = $user->fresh();
$this->assertEquals('user@mail.com', $user->email);
$this->assertTrue(app('hash')->check('Secr3t', $user->password));
}
/** @test */
public function manager_can_add_user_email_without_a_password()
{
$manager = $this->loginAsUser();
$user = factory(User::class)->create(['manager_id' => $manager->id]);
$this->visit(route('users.edit', [$user->id, 'tab' => 'login_account']));
$this->seePageIs(route('users.edit', [$user->id, 'tab' => 'login_account']));
$this->submitForm(trans('app.update'), [
'email' => 'user@mail.com',
'password' => '',
]);
$user = $user->fresh();
$this->assertEquals('user@mail.com', $user->email);
$this->assertNull($user->password);
}
/** @test */
public function empty_password_does_not_replace_existing()
{
$manager = $this->loginAsUser();
$user = factory(User::class)->create([
'manager_id' => $manager->id,
'password' => 'some random string password',
]);
$this->visit(route('users.edit', [$user->id, 'tab' => 'login_account']));
$this->seePageIs(route('users.edit', [$user->id, 'tab' => 'login_account']));
$this->submitForm(trans('app.update'), [
'email' => 'user@mail.com',
'password' => '',
]);
$this->seeInDatabase('users', [
'id' => $user->id,
'manager_id' => $manager->id,
'password' => 'some random string password',
]);
}
/** @test */
public function user_can_upload_their_own_photo()
{
Storage::fake(config('filesystems.default'));
$user = $this->loginAsUser();
$this->visit(route('users.edit', $user->id));
$this->assertNull($user->photo_path);
$this->attach(public_path('images/icon_user_1.png'), 'photo');
$this->press(trans('user.update_photo'));
$this->seePageIs(route('users.edit', $user));
$user = $user->fresh();
$this->assertNotNull($user->photo_path);
Storage::assertExists($user->photo_path);
}
}