我是 laravel 的新手。我正在尝试测试身份验证是否适用于我的网站,并且我想在测试用例中测试身份验证过程。我创建了一个内存中的 sqlite 数据库,我创建了一个新用户并使用->save()
eloquent 的方法将其存储在数据库中。我已经设置了一个身份验证过滤器,它检查数据库中的用户名,并根据它允许用户登录或返回“无效凭据”
// 我的 UserTest.php 文件:
class UserTest extends TestCase {
public function testUsernameIsNotRequired()
{
// Create a new User
$user = new User;
$user->username = "phil@ipbrown.com";
$user->password = "123456";
//$user->password_confirmation = "password";
// User should save
$this->assertTrue($user->save());
// Save the errors
$password = $user->getAuthPassword();
// There should be 0 error
$this->assertEquals("123456",$password);
$this->seed();
$this->be($user);
$this->assertTrue(Redirect::route('authFilter'));
}
}
只是为了让您知道,一旦测试完成,内存数据库就会丢失,因为与它的所有连接都丢失了,所以我想检查我保存到数据库的用户是否正确插入,其次我想检查是否我可以使用这个新用户的信息登录我的网站。
// 我的 filters.php 文件:
Route::filter('auth', function()
{
if (Auth::guest()) return Redirect::guest('login');
});
Route::filter('auth.basic', function()
{
return Auth::basic('username');
});
Route::filter('guest', function()
{
if (Auth::check()) return Redirect::to('/');
});
Route::filter('csrf', function()
{
if (Session::token() != Input::get('_token'))
{
throw new Illuminate\Session\TokenMismatchException;
}
});
我试图将过滤器附加到路由,以便我可以在测试期间重定向到路由并调用 auth.basic 过滤器以便我可以测试我的过滤器,我知道我做错了很多事情所以请随时纠正你遇到的任何错误
我的 routes.php 文件:>
Route::get('/', function()
{
return View::make('hello');
});
Route::get('/authtest', array('as'=>'/authtest','before' => 'auth.basic', function()
{
return View::make('hello');
}));
Route::group(array('prefix' => 'api/v1', 'before' => 'auth.basic'), function()
{
Route::resource('url', 'UrlController');
});
Route::get('authFilter', array('as'=>'authFilter','before' => 'auth.basic', function()
{
return Auth::basic('username');
}));
我还有一个 uri 控制器,其中包含我网站的所有页面
这就是我目前创建 uri 控制器的方法
我需要一个创建用户的测试用例,将其存储到内存数据库中,然后使用该用户信息进行身份验证。如果有人知道 laravel 过滤器测试,请告诉我我查看了测试过滤器的文档,但我想它没有很好的文档记录。
谢谢你