invoiceninja/tests/Integration/UniqueEmailTest.php
David Bomba 62e2444a2c
Sign Up Scaffolding (#2453)
* Fix js dependencies

* Breadcrumb implementation

* Test for UniqueEmailRule Validation

* reduce length of account_key to prevent key too long error

* Fixes for travis - reduce user email length

* Reduce all unique field lengths to 100 to prevent key overflow

* Fix for Bank Model

* Prevent a user from registering multiple account with one email address when using multiple databases
2018-10-17 23:26:27 +11:00

65 lines
1.5 KiB
PHP

<?php
namespace Tests\Unit;
use App\Http\ValidationRules\UniqueUserRule;
use App\Models\User;
use Illuminate\Foundation\Testing\Concerns\InteractsWithDatabase;
use Illuminate\Support\Facades\DB;
use Illuminate\Support\Facades\Hash;
use Tests\TestCase;
/**
* @test
* @covers App\Utils\NumberHelper
*/
class UniqueEmailTest extends TestCase
{
use InteractsWithDatabase;
protected $rule;
public function setUp()
{
parent::setUp();
if (config('auth.providers.users.driver') == 'eloquent')
$this->markTestSkipped('Multi DB not enabled - skipping');
DB::connection('db-ninja-1')->table('users')->delete();
DB::connection('db-ninja-2')->table('users')->delete();
$this->rule = new UniqueUserRule();
$user = [
'first_name' => 'user_db_1',
'email' => 'user@example.com',
'password' => Hash::make('password'),
];
User::on('db-ninja-1')->create($user);
User::on('db-ninja-2')->create($user);
}
public function test_unique_emails_detected_on_database()
{
$this->assertFalse($this->rule->passes('email', 'user@example.com'));
}
public function test_no_unique_emails_detected()
{
$this->assertTrue($this->rule->passes('email', 'nohit@example.com'));
}
public function tearDown()
{
// DB::connection('db-ninja-1')->table('users')->delete();
// DB::connection('db-ninja-2')->table('users')->delete();
}
}