2FAuth/tests/Feature/Http/Requests/UserPatchPwdRequestTest.php

107 lines
3.0 KiB
PHP
Raw Normal View History

2021-11-14 01:52:46 +01:00
<?php
2022-03-31 08:38:35 +02:00
namespace Tests\Feature\Http\Requests;
2021-11-14 01:52:46 +01:00
2022-03-31 08:38:35 +02:00
use App\Http\Requests\UserPatchPwdRequest;
2021-11-14 01:52:46 +01:00
use Illuminate\Foundation\Testing\WithoutMiddleware;
use Illuminate\Support\Facades\Auth;
2022-11-22 15:15:52 +01:00
use Illuminate\Support\Facades\Validator;
2023-08-01 11:28:27 +02:00
use PHPUnit\Framework\Attributes\CoversClass;
use PHPUnit\Framework\Attributes\DataProvider;
use PHPUnit\Framework\Attributes\Test;
2021-11-14 01:52:46 +01:00
use Tests\TestCase;
2022-03-31 08:38:35 +02:00
/**
2023-08-01 11:28:27 +02:00
* UserPatchPwdRequestTest test class
2022-03-31 08:38:35 +02:00
*/
2023-08-01 11:28:27 +02:00
#[CoversClass(UserPatchPwdRequest::class)]
2021-11-14 01:52:46 +01:00
class UserPatchPwdRequestTest extends TestCase
{
use WithoutMiddleware;
#[Test]
2021-11-14 01:52:46 +01:00
public function test_user_is_authorized()
2022-11-22 15:15:52 +01:00
{
2021-11-14 01:52:46 +01:00
Auth::shouldReceive('check')
2023-12-20 16:55:58 +01:00
->once()
->andReturn(true);
2021-11-14 01:52:46 +01:00
2024-09-26 23:50:01 +02:00
$request = new UserPatchPwdRequest;
2022-11-22 15:15:52 +01:00
2021-11-14 01:52:46 +01:00
$this->assertTrue($request->authorize());
}
#[Test]
2023-08-01 11:28:27 +02:00
#[DataProvider('provideValidData')]
2021-11-14 01:52:46 +01:00
public function test_valid_data(array $data) : void
{
2024-09-26 23:50:01 +02:00
$request = new UserPatchPwdRequest;
2021-11-14 01:52:46 +01:00
$validator = Validator::make($data, $request->rules());
$this->assertFalse($validator->fails());
}
/**
* Provide Valid data for validation test
*/
2023-08-01 11:28:27 +02:00
public static function provideValidData() : array
2021-11-14 01:52:46 +01:00
{
return [
[[
2022-11-22 15:15:52 +01:00
'currentPassword' => 'newPassword',
'password' => 'newPassword',
'password_confirmation' => 'newPassword',
2021-11-14 01:52:46 +01:00
]],
];
}
#[Test]
2023-08-01 11:28:27 +02:00
#[DataProvider('provideInvalidData')]
2021-11-14 01:52:46 +01:00
public function test_invalid_data(array $data) : void
{
2024-09-26 23:50:01 +02:00
$request = new UserPatchPwdRequest;
2021-11-14 01:52:46 +01:00
$validator = Validator::make($data, $request->rules());
$this->assertTrue($validator->fails());
}
/**
* Provide invalid data for validation test
*/
2023-08-01 11:28:27 +02:00
public static function provideInvalidData() : array
2021-11-14 01:52:46 +01:00
{
return [
[[
2022-11-22 15:15:52 +01:00
'currentPassword' => '', // required
'password' => 'newPassword',
'password_confirmation' => 'newPassword',
2021-11-14 01:52:46 +01:00
]],
[[
2022-11-22 15:15:52 +01:00
'currentPassword' => 'currentPassword',
'password' => '', // required
'password_confirmation' => 'newPassword',
2021-11-14 01:52:46 +01:00
]],
[[
2022-11-22 15:15:52 +01:00
'currentPassword' => 'newPassword',
'password' => 'anotherPassword', // confirmed
'password_confirmation' => 'newPassword',
2021-11-14 01:52:46 +01:00
]],
[[
2022-11-22 15:15:52 +01:00
'currentPassword' => 'pwd',
'password' => 'pwd', // min:8
'password_confirmation' => 'newPassword',
2021-11-14 01:52:46 +01:00
]],
[[
2022-11-22 15:15:52 +01:00
'currentPassword' => 'pwd',
'password' => true, // string
'password_confirmation' => 'newPassword',
2021-11-14 01:52:46 +01:00
]],
[[
2022-11-22 15:15:52 +01:00
'currentPassword' => 'pwd',
'password' => 10, // string
'password_confirmation' => 'newPassword',
2021-11-14 01:52:46 +01:00
]],
];
}
2022-11-22 15:15:52 +01:00
}