Laravel Unit Testing – HOW TO with Code Examples

larvavel, php framework

Welcome to this guide on unit testing in Laravel. Known for its clear syntax and powerful features, Laravel also provides a strong testing setup, making it ideal for modern web applications. Here, we focus on unit testing—checking individual parts of your code to ensure they work as intended.

Laravel’s built-in tools make testing easier, helping developers catch bugs and boost software quality. This guide covers practical steps for creating unit tests, complete with code examples for clarity. Whether you’re new to Laravel or refining your skills, you’ll find useful insights here. Let’s get started with Laravel unit testing!

Using Data Faker in Laravel Unit Testing

Faker is a PHP library that allows developers to generate fake data for their applications, making it incredibly useful when writing unit tests in Laravel. The library is shipped with Laravel out of the box, thus it can be readily used within your applications.

When writing unit tests, you often need to create objects with specific values, but what about cases when the specific value doesn’t matter? This is where Faker comes into play. It enables you to quickly generate placeholder data that adheres to a specific format, such as names, addresses, paragraphs of text, or even specific types of numbers.

For instance, suppose you’re testing a feature that requires a user model. Instead of manually creating a user and defining all of the fields, you can use Faker to generate this data:

$user = factory(App\User::class)->create();

In this code, Laravel uses Faker behind the scenes to create a User instance with random yet valid data. You can also override specific fields if you need to:

$user = factory(App\User::class)->create([
    'name' => 'John Doe',
]);

Using Faker with Laravel’s factory system allows you to create realistic, valid data for your unit tests, helping to ensure that your application works correctly with a variety of data inputs.

See also  Setting Up Laravel on Docker MacOS Ventura: Step-by-Step

Laravel Unit Testing Example

Here’s an example of a Laravel unit test class that could be used to validate CRUD (Create, Read, Update, Delete) operations for a hypothetical “Book” model:

<?php

namespace Tests\Unit;

use Tests\TestCase;
use Illuminate\Foundation\Testing\RefreshDatabase;
use App\Models\Book;

class BookTest extends TestCase
{
    use RefreshDatabase;

    /**
     * Test creating a book.
     *
     * @return void
     */
    public function testCreateBook()
    {
        $book = Book::factory()->create([
            'title' => 'The Catcher in the Rye',
            'author' => 'J.D. Salinger',
            'published_year' => 1951,
        ]);

        $this->assertDatabaseHas('books', [
            'id' => $book->id,
            'title' => 'The Catcher in the Rye',
            'author' => 'J.D. Salinger',
            'published_year' => 1951,
        ]);
    }

    /**
     * Test updating a book.
     *
     * @return void
     */
    public function testUpdateBook()
    {
        $book = Book::factory()->create();

        $book->update([
            'title' => 'To Kill a Mockingbird',
            'author' => 'Harper Lee',
            'published_year' => 1960,
        ]);

        $this->assertDatabaseHas('books', [
            'id' => $book->id,
            'title' => 'To Kill a Mockingbird',
            'author' => 'Harper Lee',
            'published_year' => 1960,
        ]);
    }

    /**
     * Test deleting a book.
     *
     * @return void
     */
    public function testDeleteBook()
    {
        $book = Book::factory()->create();

        $book->delete();

        $this->assertDatabaseMissing('books', [
            'id' => $book->id,
        ]);
    }

    /**
     * Test retrieving a book.
     *
     * @return void
     */
    public function testRetrieveBook()
    {
        $book = Book::factory()->create();

        $retrievedBook = Book::find($book->id);

        $this->assertEquals($book->id, $retrievedBook->id);
        $this->assertEquals($book->title, $retrievedBook->title);
        $this->assertEquals($book->author, $retrievedBook->author);
        $this->assertEquals($book->published_year, $retrievedBook->published_year);
    }
}

In this example, the RefreshDatabase trait is used to automatically migrate and refresh the database before each test. The testCreateBook method creates a new book using Laravel’s model factory and then checks if the book was successfully inserted into the database using the assertDatabaseHas method.

The testUpdateBook method creates a new book, updates its attributes, and then checks if the updates were successfully applied to the database using the assertDatabaseHas method.

The testDeleteBook method creates a new book, deletes it, and then checks if the book was successfully removed from the database using the assertDatabaseMissing method.

See also  Apache vs Nginx for PHP Projects: Performance, Flexibility & Security

Finally, the testRetrieveBook method creates a new book, retrieves it using the find method, and then checks if the retrieved book matches the original book using the assertEquals method.

This is just an example of how you could test CRUD operations for a Laravel model. Depending on your specific application and requirements, you may need to customize this test class to fit your needs.

Leave a Comment