Laravel 5.4
Awesome Laravel
- Awesome Laravel (Chirag Gude)
Prologue
- Release Notes
- Upgrade Guide
Getting Started
- Installation
- Configuration
- Directory Structure
- Laravel Homestead
- valet
Architecture Concepts
- Request Lifecycle
- Service Container
- Service Providers
- Facades
The Basics
- Routing
- Errors & Logging
- Middleware
- CSRF Protection
- Controllers
- HTTP Requests
- HTTP Responses
- Views
- HTTP Session
- Validation
Frontend
- Blade Templates
- Localization
- JavaScript & CSS Scaffolding
- Compiling Assets (Laravel Mix)
Security
- Authentication
- API Authentication (Passport)
- Authorization
- Encryption
- Hashing
- Resetting Passwords
Digging Deeper
- Artisan Console
- Queues
- Package Development
- Task Scheduling
- Broadcasting
- Cache
- Collections
- Events
- File Storage
- helpers
- Notifications
Database
- Database Getting Started
- Database Query Builder
- Database Pagination
- Database Migrations
- Database Seeding
- Redis
Eloquent ORM
- Eloquent Getting Started
- Eloquent Relationships
- Eloquent Collections
- Eloquent Mutators
- Eloquent Serialization
Testing
- Testing Getting Started
- HTTP Tests
- Browser Tests (Laravel Dusk)
- Database Testing
- Mocking
- redirect
Official Packages
- Laravel Cashier
- Envoy Task Runner
- Laravel Scout
Database Testing
Introduction
Laravel provides a variety of helpful tools to make it easier to test your database driven applications. First, you may use the assertDatabaseHas
helper to assert that data exists in the database matching a given set of criteria. For example, if you would like to verify that there is a record in the users
table with the email
value of [email protected]
, you can do the following:
Of course, the assertDatabaseHas
method and other helpers like it are for convenience. You are free to use any of PHPUnit’s built-in assertion methods to supplement your tests.
Resetting The Database After Each Test
It is often useful to reset your database after each test so that data from a previous test does not interfere with subsequent tests.
Using Migrations
One approach to resetting the database state is to rollback the database after each test and migrate it before the next test. Laravel provides a simple DatabaseMigrations
trait that will automatically handle this for you. Simply use the trait on your test class and everything will be handled for you:
|
Using Transactions
Another approach to resetting the database state is to wrap each test case in a database transaction. Again, Laravel provides a convenient DatabaseTransactions
trait that will automatically handle this for you:
|
By default, this trait will only wrap the default database connection in a transaction. If your application is using multiple database connections, you should define a $connectionsToTransact
property on your test class. This property should be an array of connection names to execute the transactions on.
Writing Factories
When testing, you may need to insert a few records into your database before executing your test. Instead of manually specifying the value of each column when you create this test data, Laravel allows you to define a default set of attributes for each of your Eloquent models using model factories. To get started, take a look at the database/factories/ModelFactory.php
file in your application. Out of the box, this file contains one factory definition:
Within the Closure, which serves as the factory definition, you may return the default test values of all attributes on the model. The Closure will receive an instance of the Faker PHP library, which allows you to conveniently generate various kinds of random data for testing.
Of course, you are free to add your own additional factories to the ModelFactory.php
file. You may also create additional factory files for each model for better organization. For example, you could create UserFactory.php
and CommentFactory.php
files within your database/factories
directory. All of the files within the factories
directory will automatically be loaded by Laravel.
Factory States
States allow you to define discrete modifications that can be applied to your model factories in any combination. For example, your User
model might have a delinquent
state that modifies one of its default attribute values. You may define your state transformations using the state
method:
Using Factories
Creating Models
Once you have defined your factories, you may use the global factory
function in your tests or seed files to generate model instances. So, let’s take a look at a few examples of creating models. First, we’ll use the make
method to create models but not save them to the database:
You may also create a Collection of many models or create models of a given type:
Applying States
You may also apply any of your states to the models. If you would like to apply multiple state transformations to the models, you should specify the name of each state you would like to apply:
Overriding Attributes
If you would like to override some of the default values of your models, you may pass an array of values to the make
method. Only the specified values will be replaced while the rest of the values remain set to their default values as specified by the factory:
Persisting Models
The create
method not only creates the model instances but also saves them to the database using Eloquent’s save
method:
You may override attributes on the model by passing an array to the create
method:
Relationships
In this example, we’ll attach a relation to some created models. When using the create
method to create multiple models, an Eloquent collection instance is returned, allowing you to use any of the convenient functions provided by the collection, such as each
:
Relations & Attribute Closures
You may also attach relationships to models using Closure attributes in your factory definitions. For example, if you would like to create a new User
instance when creating a Post
, you may do the following:
These Closures also receive the evaluated attribute array of the factory that defines them: