Фон: В моем проекте Laravel я реализую функцию создания пользователей, в которой администратор может создавать пользователей. Во время создания пользователя я устанавливаю случайный пароль (не ввод) и отправляю пользователю электронное письмо для сброса пароля. В моей схеме поле пароля не допускает значения NULL (мне не нужны пользователи без паролей в базе данных).
Я использую Form Request для реализации проверки контроллера и prepareForValidation для установки случайного пароля на POST , но устанавливаю пароль на ноль на PATCH , как я не Я хочу, чтобы пароль обновлялся при обновлении пользователя. (Администраторы могут обновлять профили пользователей, но не пароли.) И правила проверки «иногда» обрабатывают два сценария ios.
Ниже приведен мой класс запроса ( правила и prepareForValidation методы).
class AdminUserRequest extends FormRequest
{
public function rules()
{
return [
...
'password' => [
'sometimes',
'required',
'min:8',
],
...
];
}
/**
* Prepare the data for validation.
*
* @return void
*/
protected function prepareForValidation()
{
if ($this->getMethod() == 'POST') {
$this->merge([
'password' => Hash::make(Str::random(10)),
]);
} else {
$this->offsetUnset('password');
}
}
}
Вопрос: Мой вопрос: как лучше всего проверить функциональность prepareForValidation в форме запроса.
Он должен проверить, что набор данных запроса имеет пароль при POST и не установлен для других методов.
Конечно, я могу провести функциональное тестирование, чтобы охватить случаи
- POST для маршрута создает пользователя в базе данных и не имеет ошибок в сеансе
- PATCH для маршрута не меняет пароль, даже если он передан в наборе данных.
Но Я хотел бы знать, есть ли способ провести модульное тестирование. И как это сделать.
Заранее спасибо