2016-04-25 10 views
2

Warum führt der Komponententest in "Test 1" den Statuscode 500, nicht 200? Kann mir jemand das erklären? Hier ist ein Beispiel in 2 Tests für dieselbe Aktion und sie geben unterschiedliche Statuscodes zurück. Ich habe 200 in beiden Tests erwartet?Laravel 5 - Komponententest - Statuscode 500, erwartet 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(); 
    } 
} 

Responses in KMD:

enter image description here

+2

Haben Sie versucht, die Laravel-Fehlerprotokolldatei (en) anzuschauen? – Jono20201

+0

Blick auf die Protokolldatei wird sehr hilfreich sein, aber ich denke, Sie verspotten die SpracheRepo nicht korrekt –

+0

Festlegen eines leeren Arrays für '$ dontReport' (Liste der Ausnahmetypen, die nicht gemeldet werden sollen) in' app/Ausnahmen/Handler. php' kann bei der Fehlersuche in Tests helfen, da sie auf diese Weise in Protokollen angezeigt werden können. – apex39

Antwort

1

Ich habe laravel.log und ich fand das nächste Mal anmeldet: Sprachen

$:

[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:

und nächsten log:

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:

und auf meiner Ansicht gelange ich zu $ ​​Sprache Eigenschaften mit -> char, $ language-> name

aber es ist Array so sollte ich zugreifen mit:

$ language [ 'char'], $ Sprache [ 'name']

und beide Tests funktionieren nun und gibt Statuscode 200.

Vielen Dank für Ihre Hilfe.