1
0
mirror of https://github.com/invoiceninja/invoiceninja.git synced 2024-11-10 21:22:58 +01:00
invoiceninja/tests/Feature/LoginTest.php
David Bomba 0faf91dd5d
Generated Datatable Action Menus (#2590)
* Style Datatable

* Component Actions

* Harvest user permissions from Pivot table

* Pad out permissions

* Client actions

* Fixes for travis

* Client Datatables

* Menu permissions

* Tests for menu permissions

* Action menu

* Implement query builder filter

* Flatten user permissions

* Implement rendering of client action dropdowns

* Generated Action Menus
2019-01-07 22:30:28 +11:00

124 lines
3.1 KiB
PHP

<?php
namespace Tests\Feature;
use App\Models\Account;
use App\Models\User;
use Illuminate\Foundation\Testing\DatabaseTransactions;
use Illuminate\Foundation\Testing\RefreshDatabase;
use Illuminate\Foundation\Testing\WithFaker;
use Illuminate\Support\Facades\Session;
use Tests\TestCase;
class LoginTest extends TestCase
{
use DatabaseTransactions;
public function setUp()
{
parent::setUp();
Session::start();
}
public function testLoginFormDisplayed()
{
$response = $this->get('/login', [
'_token' => csrf_token()
]);
$response->assertStatus(200);
}
/**
* A valid user can be logged in.
*
* @return void
*/
public function testLoginAValidUser()
{
$account = factory(Account::class)->create();
$user = factory(User::class)->create([
'account_id' => $account->id,
]);
$company = factory(\App\Models\Company::class)->make([
'account_id' => $account->id,
]);
$user->companies()->attach($company->id, [
'account_id' => $account->id,
'is_owner' => 1,
'is_admin' => 1,
]);
$response = $this->post('/login', [
'email' => config('ninja.testvars.username'),
'password' => config('ninja.testvars.password'),
'_token' => csrf_token()
]);
//$response->assertStatus(302);
$this->assertAuthenticatedAs($user);
}
/**
* An invalid user cannot be logged in.
*
* @return void
*/
public function testDoesNotLoginAnInvalidUser()
{
$account = factory(Account::class)->create();
$user = factory(User::class)->create([
'account_id' => $account->id,
]);
$company = factory(\App\Models\Company::class)->make([
'account_id' => $account->id,
]);
$user->companies()->attach($company->id, [
'account_id' => $account->id,
'is_owner' => 1,
'is_admin' => 1,
]);
$response = $this->post('/login', [
'email' => config('ninja.testvars.username'),
'password' => 'invaliddfd',
'_token' => csrf_token()
]);
//$response->assertSessionHasErrors();
$this->assertGuest();
}
/**
* A logged in user can be logged out.
*
* @return void
*/
public function testLogoutAnAuthenticatedUser()
{
$account = factory(Account::class)->create();
$user = factory(User::class)->create([
'account_id' => $account->id,
]);
$company = factory(\App\Models\Company::class)->make([
'account_id' => $account->id,
]);
$user->companies()->attach($company->id, [
'account_id' => $account->id,
'is_owner' => 1,
'is_admin' => 1,
]);
$response = $this->actingAs($user)->post('/logout',[
'_token' => csrf_token()
]);
$response->assertStatus(302);
$this->assertGuest();
}
}