2016-04-25 4 views
2

"テスト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(); 
    } 
} 

応答:

enter image description here

+2

Laravelエラーログファイルを見てみましたか? – Jono20201

+0

ログファイルを見ると非常に役に立ちますが、languageRepoを正しく嘲笑していないと思います。 –

+0

'$ dontReport'(報告されるべきではない例外タイプのリスト)のための空の配列を' app/exceptions/Handler 'に設定しています。このようにログで見ることができるので、phpはテストでのエラーのトラブルシューティングに役立ちます。 – apex39

答えて

1

私はlaravel.logをチェックし、私は次のログが見つかりました:

[2016-04-26 08:45:49] testing.ERROR: exception 'ErrorException' with message 'Trying to get property of non-object' in C:\xampp\htdocs\STP\storage\framework\views\76c117f88e2ab8d2c5f85f5187e254573559a2c3.php:7 Stack trace:

と次のログ:

$言語:

Next exception 'ErrorException' with message 'Trying to get property of non-object (View: C:\xampp\htdocs\STP\resources\views\admin\languages\showAll.blade.php)' in C:\xampp\htdocs\STP\storage\framework\views\76c117f88e2ab8d2c5f85f5187e254573559a2c3.php:7

Stack trace:

と私の見解では、私は$言語プロパティにアクセス - > char、$ language-> name

しかし、それで配列にアクセスする必要があります。

$言語[ '文字']、$言語[ '名前']

との両方のテストが正しく動作しステータスコード200を返します。

ありがとうございました。

関連する問題