Updates see below
My controllers distinguish between ajax and other requests (using Request::ajax()
as a condition). That works quite fine but I wonder if there is a way of unit testing the controllers handling the the requests. How should a test look like?
Something like this probably but it doesn't work ...
<?php
class UsersControllerTest extends TestCase
{
public function testShowUser()
{
$userId = 1;
$response = $this->call('GET', '/users/2/routes', array(), array(), array(
'HTTP_CUSTOM' => array(
'X-Requested-With' => 'XMLHttpRequest'
)
));
}
}
Update
I kind of found a solution. Maybe. Since I am not interested in testing the proper functionality of the Request class (very likely all native classes provided by Laravel, Symfony, etc. are enough unit tested already) best way might be to mock its ajax method. Like this:
public function testShowUser()
{
$mocked = Request::shouldReceive('ajax')
->once()
->andReturn(true);
$controller = new UsersCustomRoutesController;
$controller->show(2,2);
}
Because the real Request
class and not its mocked substitute is used when using the call
method of the Testcase
class I had to instantiate the method which is called when the specified route is entered by hand. But I think that is okay because I just want to control that the expressions inside the Request::ajax()
condition work as expected with this test.
Here's the solution for Laravel 5.2.
It's that simple.
Intenally,
json
method applies following headers:You need to prefix the actual header with HTTP_, no need to use HTTP_CUSTOM:
Alternative syntax which looks a bit better IMO:
Here are some similar code examples for JSON headers (
Request::isJson()
andRequest::wantsJson()
):Here's a useful helper method you can put in your TestCase:
In Laravel 5:
Then you can chain the normal assertions: