mirror of
https://github.com/10h30/Test-Laravel-Validation.git
synced 2026-06-05 15:07:56 +09:00
Task 6 - form request validation
This commit is contained in:
@@ -72,3 +72,11 @@ Test method `test_old_value_stays_in_form_after_validation_error()`.
|
|||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
|
## Task 6. Form Request Validation.
|
||||||
|
|
||||||
|
In `app/Http/Controllers/ItemController.php` file, validation is performed via class StoreItemRequest, but that class doesn't exist, intentionally. Your task is to create it, with parameters of authorized true, and validation rules of name/title as required fields.
|
||||||
|
|
||||||
|
Test method `test_form_request_validation()`.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
|||||||
@@ -0,0 +1,20 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Http\Controllers;
|
||||||
|
|
||||||
|
use App\Http\Requests\StoreItemRequest;
|
||||||
|
use App\Models\Item;
|
||||||
|
|
||||||
|
class ItemController extends Controller
|
||||||
|
{
|
||||||
|
// TASK: generate that StoreItemRequest class
|
||||||
|
// with authorization returning TRUE
|
||||||
|
// and validation rules: name is required, and description is required
|
||||||
|
public function store(StoreItemRequest $request)
|
||||||
|
{
|
||||||
|
Item::create($request->validated());
|
||||||
|
|
||||||
|
return 'Success';
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
@@ -0,0 +1,13 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Models;
|
||||||
|
|
||||||
|
use Illuminate\Database\Eloquent\Factories\HasFactory;
|
||||||
|
use Illuminate\Database\Eloquent\Model;
|
||||||
|
|
||||||
|
class Item extends Model
|
||||||
|
{
|
||||||
|
use HasFactory;
|
||||||
|
|
||||||
|
protected $fillable = ['name', 'description'];
|
||||||
|
}
|
||||||
@@ -0,0 +1,33 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
use Illuminate\Database\Migrations\Migration;
|
||||||
|
use Illuminate\Database\Schema\Blueprint;
|
||||||
|
use Illuminate\Support\Facades\Schema;
|
||||||
|
|
||||||
|
class CreateItemsTable extends Migration
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Run the migrations.
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function up()
|
||||||
|
{
|
||||||
|
Schema::create('items', function (Blueprint $table) {
|
||||||
|
$table->id();
|
||||||
|
$table->string('name');
|
||||||
|
$table->string('description');
|
||||||
|
$table->timestamps();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Reverse the migrations.
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function down()
|
||||||
|
{
|
||||||
|
Schema::dropIfExists('items');
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -18,6 +18,7 @@ Route::post('profile', [\App\Http\Controllers\ProfileController::class, 'update'
|
|||||||
Route::resource('projects', \App\Http\Controllers\ProjectController::class);
|
Route::resource('projects', \App\Http\Controllers\ProjectController::class);
|
||||||
Route::resource('products', \App\Http\Controllers\ProductController::class);
|
Route::resource('products', \App\Http\Controllers\ProductController::class);
|
||||||
Route::resource('teams', \App\Http\Controllers\TeamController::class);
|
Route::resource('teams', \App\Http\Controllers\TeamController::class);
|
||||||
|
Route::resource('items', \App\Http\Controllers\ItemController::class);
|
||||||
|
|
||||||
Route::get('/', function () {
|
Route::get('/', function () {
|
||||||
return view('welcome');
|
return view('welcome');
|
||||||
|
|||||||
@@ -67,4 +67,18 @@ class ValidationTest extends TestCase
|
|||||||
$response->assertStatus(200);
|
$response->assertStatus(200);
|
||||||
$response->assertSee('Abc');
|
$response->assertSee('Abc');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function test_form_request_validation()
|
||||||
|
{
|
||||||
|
// Post with no name/description should fail
|
||||||
|
$response = $this->post('items');
|
||||||
|
$response->assertStatus(302);
|
||||||
|
|
||||||
|
// Post with all the fields should succeed
|
||||||
|
$response = $this->post('items', [
|
||||||
|
'name' => 'Abc',
|
||||||
|
'description' => 'Xyz',
|
||||||
|
]);
|
||||||
|
$response->assertStatus(200);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user