erikgall / eloquent-phpunit
Test Eloquent models, database schemas & tables, relationships/foreign keys using PHPUnit.
Installs: 16 456
Dependents: 0
Suggesters: 0
Security: 0
Stars: 19
Watchers: 2
Forks: 3
Open Issues: 2
Requires
- doctrine/dbal: ^2.5
- laravel/framework: ^5.2|^5.3
README
Test your Laravel Eloquent model's and database schema
This package was inspired by the Ruby on Rails world and the testing framework RSpec. The Ruby on Rails community (for the most part) write tests for their models in a way that they check the model's attributes, relationships, database table and columns settings (defaults, nullable, etc.).
Table of Contents
- What can be tested
- Installation
- Requirements
- Documentation
- Example Model Test Class
- Contributing
- Version Release History
- Projects using Eloquent-PHPUnit
- Author
- License
What can be tested
- Casted attribute array
- Fillable attribute array
- Hidden attribute array
- Dates attribute array
- Relationship methods
You can also test your database tables such as:
- Table exists
- Table column exists
- Table column type (string, text, date, datetime, boolean, etc.).
- Column default value
- Null/Not Null
- Auto-incremented primary keys.
- Table indexes
- Unique indexes
- Foreign Key relationships
Installation
- The easiest way to use/install this package is by using composer in your terminal:
composer require erikgall/eloquent-phpunit
- Or you can add the following line to your
require-dev
dependencies in yourcomposer.json
file
{ "require-dev": { "erikgall/eloquent-phpunit": "~1.0" } }
Requirements
This package requires PHP 5.6
or PHP 7+
. It has been tested and used with Laravel 5.2
and Laravel 5.3
. There should not be a problem using it with Laravel 5.0/1
but it has not been tested or confirmed 100%.
Documentation
Test Class Properties
*These settings are only used if the seedDatabase property is not set to false (the default value for the seedDatabase property is true).
** The subject property is an instance of \Illuminate\Database\Eloquent\Model.
Database Testing Methods
\EGALL\EloquentPHPUnit\Database\Table
Get the EGALL\EloquentPHPUnit\Database\Table
class instance by calling the table property.
Usage:
$this->table
Table methods
column($columnName)
Initializes a new EGALL\EloquentPHPUnit\Database\Column
class instance for table's column name that is passed in.
Usage:
$this->table->column('column_name')
Returns: EGALL\EloquentPHPUnit\Database\Column
exists()
Assert that the table exists in the database.
Usage:
$this->table->exists();
Returns: EGALL\EloquentPHPUnit\Database\Table
hasTimestamps()
Assert that the table has timestamp columns.
Usage:
$this->table->hasTimestamps();
Returns: EGALL\EloquentPHPUnit\Database\Table
resetTable($tableName)
Using this method it is possible to test multiple tables in one test class.
Usage:
The usage code below is using a user/user-roles, example. The relationship is as follows: A user can have many role and a role can have many users (many-to-many). In eloquent, we would describe this relationship as a user belongsToMany
roles through the user_role table and vice-versa.
protected $model = 'App\Role'; public function testDatabase() { // We are testing the roles table below $this->table->column('id')->increments(); $this->table->column('name')->string()->notNull()->unique(); $this->table->column('label')->string()->notNull(); $this->table->hasTimestamps(); // To switch to the user_role table we must reset the table. // You can method chain off of the resetTable() method as well. $this->resetTable('user_role'); // Begin testing user_role table like normal. $this->table->column('role_id')->integer()->primary()->foreign('roles'); $this->table->column('user_id')->integer()->primary()->foreign('roles'); $this->table->hasTimestamps(); }
Returns: EGALL\EloquentPHPUnit\EloquentTestCase
/ $this
Model Testing Methods
// TODO
Example Model Test
Class UserModelTest extends \EGALL\EloquentPHPUnit\EloquentTestCase { protected $model = 'App\User'; // If you want to run the DatabaseSeeder class protected $seedDatabase = true; // If you only want to run a specific seeder protected $seeders = ['UsersTableSeeder', 'SchoolsTableSeeder']; // Change the default seeder that calls the rest of your seeders. // The default is the default Laravel Seeder named: DatabaseSeeder. // Ex. (You have a TestDatabaseSeeder and the default DatabaseSeeder). protected $defaultSeeder = 'TestDatabaseSeeder' /** * Test the database table. */ public function testDatabaseTable() { $this->table->column('id')->integer()->increments(); $this->table->column('name')->string()->nullable(); $this->table->column('email')->string()->notNullable()->unique(); $this->table->column('password')->string()->notNullable(); $this->table->column('dob')->date()->nullable(); $this->table->column('avatar_id')->integer()->foreign('images', 'id', $onUpdate = 'cascade', $onDelete = 'cascade'); $this->table->column('is_verified')->boolean()->defaults(false); $this->table->column('is_admin')->boolean()->defaults(false); $this->table->column('verification_sent_at')->dateTime()->nullable(); $this->table->column('invite_sent_at')->dateTime()->nullable(); $this->table->column('api_token')->string()->index(); $this->table->column('remember_token')->string()->nullable(); $this->table->hasTimestamps(); } /** * Test the model's properties. */ public function testModelProperties() { $this->hasFillable('name', 'email', 'password', 'dob', 'avatar_id') ->hasHidden('password', 'remember_token') ->hasCasts('is_verified', 'boolean') // or ->hasCasts(['is_verified' => 'boolean', 'is_admin' => 'boolean']) ->hasDates('verification_sent_at', 'invite_sent_at') ->belongsTo(Image::class) // if method name = 'image()' or ->belongsTo(Image::class, $customMethod = 'avatar') ->hasMany(Profile::class) ->morphsTo($method = 'slug', $morphTo = 'sluggable') // or: example below assumes the db fields are: 'sluggable_id' and 'sluggable_type' ->morphsTo('sluggable'); } }
Contributing
- Fork it.
- Create your branch:
git checkout -b my-new-feature
- Commit your changes:
git commit -am 'Add some feature'
- Push to the branch:
git push origin my-new-feature
- Submit a pull request.
History
- v1.0.0 Released: 8/5/2016
- v1.0.3 Released: 8/9/2016
- v1.0.6 Released: 9/21/2016
Projects using Eloquent-PHPUnit
- Canvas ★803: A simple, powerful blog publishing platform built on top of Laravel 5 by @austintoddj
Author
License
Eloquent-PHPUnit is an open-sourced software licensed under the MIT license.