"テスト1"の単体テストが200ではなくステータスコード500を返すのはなぜですか?誰かが私を説明できますか? ここでは、2つのテストで同じアクションを実行する例を示し、異なるステータスコードを返します。私は両方のテストで200を期待しましたか? CMDにLaravel 5 - ユニットテスト - ステータスコード500、予想される値200
LanguageController
class LanguageController extends Controller implements IEntityViewManager
{
public function showAllView()
{
$allLanguages = $this->languageRepo->orderBy('id');
return view('admin.languages.showAll')->with('languages', $allLanguages);
}
}
LanguageControllerTest
class LanguageControllerTest extends TestCase
{
public function __construct($name = NULL, array $data = array(), $dataName = '')
{
parent::__construct($name, $data, $dataName);
}
public function setUp()
{
parent::setUp();
}
public function tearDown()
{
Mockery::close();
}
protected function setUpMock()
{
$mock = Mockery::mock(LanguageRepositoryInterface::class);
$this->app->instance(LanguageRepositoryInterface::class, $mock);
return $mock;
}
// test 1
public function testShowAllLanguages()
{
$mock = $this->setUpMock();
$mock->shouldReceive('orderBy')->once()->andReturn([1]);
$result = $this->action('GET', 'Entities\[email protected]');
var_dump("Test 1 : " . $result->getStatusCode()); // RETURNS 500
}
// test 2
public function testShowAllView()
{
$result = $this->action('GET', 'Entities\[email protected]');
var_dump("Test 2 : " . $result->getStatusCode()); // RETURNS 200
$this->assertViewHas('languages');
$this->assertResponseOk();
}
}
応答:
Laravelエラーログファイルを見てみましたか? – Jono20201
ログファイルを見ると非常に役に立ちますが、languageRepoを正しく嘲笑していないと思います。 –
'$ dontReport'(報告されるべきではない例外タイプのリスト)のための空の配列を' app/exceptions/Handler 'に設定しています。このようにログで見ることができるので、phpはテストでのエラーのトラブルシューティングに役立ちます。 – apex39