【发布时间】:2014-04-30 03:01:46
【问题描述】:
我想编写一个单元测试来检查未经身份验证的用户是否可以查看用户列表(他不应该能够)。
我的路线
Route::group(array('prefix' => 'admin'), function() {
Route::get('login', function() {
return View::make('auth.login');
});
Route::post('login', function() {
Auth::attempt( array('email' => Input::get('email'), 'password' => Input::get('password')) );
return Redirect::intended('admin');
});
Route::get('logout', 'AuthController@logout');
Route::group(array('before' => 'auth'), function() {
Route::get('/', function() {
return Redirect::to('admin/users');
});
Route::resource('users', 'UsersController');
});
});
我的测试
public function testUnauthenticatedUserIndexAccess() {
$response = $this->call('GET', 'admin/users');
$this->assertRedirectedTo('admin/login');
}
我的过滤器
Route::filter('auth', function() {
if (Auth::guest()) return Redirect::guest('admin/login');
});
结果
无法断言 Illuminate\Http\Response 对象 (...) 是“Illuminate\Http\RedirectResponse”类的实例。
如果我从测试中记录 $response,它会显示完整的用户列表,就像管理员在测试期间登录一样。
如果我在没有登录的情况下使用浏览器浏览到管理员/用户,我将被重定向到我应该登录的位置,因此身份验证过滤器确实在工作。
问题
- 默认情况下,Laravel 中有什么东西会在测试期间为您登录第一个用户吗?还是 Auth::guest() 在测试过程中默认总是假的?
- 如果是这样,我如何在单元测试期间“退出”?我尝试了 $this->be(null) 但得到一个错误,说传递的对象必须实现 UserInterface。
【问题讨论】:
标签: unit-testing laravel laravel-4 phpunit