Tip
Some methods provided by this bundle have been implemented in Symfony. Alternative ways will be shown below.
Use $this->makeClient
to create a Client object. Client is a Symfony class
that can simulate HTTP requests to your controllers and then inspect the
results. It is covered by the functional tests
section of the Symfony documentation.
After making a request, use assertStatusCode
to verify the HTTP status code.
If it fails it will display the last exception message or validation errors
encountered by the Client object.
If you are expecting validation errors, test them with assertValidationErrors
.
use Liip\FunctionalTestBundle\Test\WebTestCase;
class MyControllerTest extends WebTestCase
{
public function testContact()
{
$client = $this->makeClient();
$crawler = $client->request('GET', '/contact');
$this->assertStatusCode(200, $client);
$form = $crawler->selectButton('Submit')->form();
$crawler = $client->submit($form);
// We should get a validation error for the empty fields.
$this->assertStatusCode(200, $client);
$this->assertValidationErrors(['data.email', 'data.message'], $client->getContainer());
// Try again with with the fields filled out.
$form = $crawler->selectButton('Submit')->form();
$form->setValues(['contact[email]' => 'nobody@example.com', 'contact[message]' => 'Hello']);
$client->submit($form);
$this->assertStatusCode(302, $client);
}
}
Tip
Instead of calling $this->makeClient
, consider calling createClient()
from Symfony's WebTestCase
:
use Symfony\Bundle\FrameworkBundle\Test\WebTestCase;
class MyControllerTest extends WebTestCase
{
public function testContact()
{
$client = static::createClient();
$client->request('GET', '/contact');
// …
}
}
Check that the request succeeded:
$client = $this->makeClient();
$client->request('GET', '/contact');
// Successful HTTP request
$this->isSuccessful($client->getResponse());
Tip
Call assertResponseIsSuccessful()
from Symfony's WebTestCase
:
use Symfony\Bundle\FrameworkBundle\Test\WebTestCase;
class MyControllerTest extends WebTestCase
{
public function testContact()
{
$client = static::createClient();
$client->request('GET', '/contact');
self::assertResponseIsSuccessful();
}
}
Add false
as the second argument in order to check that the request failed:
$client = $this->makeClient();
$client->request('GET', '/error');
// Request returned an error
$this->isSuccessful($client->getResponse(), false);
In order to test more specific status codes, use assertStatusCode()
:
Check the HTTP status code from the request:
$client = $this->makeClient();
$client->request('GET', '/contact');
// Standard response for successful HTTP request
$this->assertStatusCode(302, $client);
Tip
Call assertResponseStatusCodeSame()
from Symfony's WebTestCase
:
use Symfony\Bundle\FrameworkBundle\Test\WebTestCase;
class MyControllerTest extends WebTestCase
{
public function testContact()
{
$client = static::createClient();
$client->request('GET', '/contact');
self::assertResponseStatusCodeSame(302);
}
}
Get a Crawler instance from an URL:
$crawler = $this->fetchCrawler('/contact');
// There is one <body> tag
$this->assertSame(
1,
$crawler->filter('html > body')->count()
);
Tip
Use the crawler returned by request()
from Symfony's WebTestCase
:
use Symfony\Bundle\FrameworkBundle\Test\WebTestCase;
class MyControllerTest extends WebTestCase
{
public function testContact()
{
$client = static::createClient();
$crawler = $client->request('GET', '/contact');
// There is one <body> tag
$this->assertSame(
1,
$crawler->filter('html > body')->count()
);
}
}
Get the content of an URL:
$content = $this->fetchContent('/contact');
// `filter()` can't be used since the output is HTML code, check the content directly
$this->assertStringContainsString(
'<h1>LiipFunctionalTestBundle</h1>',
$content
);
Tip
Call getResponse()->getContent()
from Symfony's WebTestCase
:
use Symfony\Bundle\FrameworkBundle\Test\WebTestCase;
class MyControllerTest extends WebTestCase
{
public function testContact()
{
$client = static::createClient();
$client->request('GET', '/contact');
$this->assertStringContainsString(
'<h1>LiipFunctionalTestBundle</h1>',
$client->getResponse()->getContent()
);
}
}
Generate an URL from a route:
$path = $this->getUrl(
'route_name',
array(
'argument_1' => 'liip',
'argument_2' => 'test',
)
);
$client = $this->makeClient();
$client->request('GET', $path);
$this->isSuccessful($client->getResponse());
Tip
Consider hard-coding the URLs in the test: it will ensure that if a route is changed, the test will fail, so you'll know that there is a Breaking Change.
← Installation • Command test →