Let's start this course by looking at the default tests when a new Laravel project is created. You can see a folder named tests
with Feature
and Unit
tests.
We will talk more deeply about their differences later in the course. But mainly, most of your tests should be feature. This means you test some feature to see whether it works or not. Unit tests are more about separate, so-called units of your code like a function. You would test that a function internally works correctly. We will focus most on the feature tests in this course.
Now let's look at what is the ExampleTest
in the tests/Feature
folder.
ExampleTest
is a class that extends the TestCase
, and every test or feature to be tested is a function. The test class may contain multiple functions. In each function, you execute some code and then test or assert that something happened and whether it's correct. For example, in this example test case:
public function test_the_application_returns_a_successful_response(): void{ $response = $this->get('/'); $response->assertStatus(200);}
We get the home page URL and assert that the status of that request is 200.
To run these tests in the terminal, we need to run a command that will execute all Feature
and Unit
tests.
php artisan test
We can see that two tests passed. One from Unit
and one from Feature
tests. The names for the tests come from the naming of the function. When naming the test function, don't be afraid of longer names because those will be readable when someone launches tests in the feature.
Now, what happens when a test fails? Let's change the status and re-run the tests.
public function test_the_application_returns_a_successful_response(): void{ $response = $this->get('/'); $response->assertStatus(403);}
Now we can see that 1 passed
and 1 failed
. And inside, we can see which test failed and on which line. And it shows the actual error Expected response status code [403] but received 200.
. This is what a failed test would look like.
So you can see how easy it is to start testing. Most of the tests are just launching some page or calling some API and then testing whether it is successful. There is a specific kind of test called smoked tests, which goes through all the pages and tests if the page returns 200 or whatever the status code expected.
Even these tests would be a great start to ensure your application works when you launch a new feature. All the other parts of the automated testing are about exploring different assertions and ways to simulate those scenarios for specific pages or functionality.