Package Data | |
---|---|
Maintainer Username: | motty |
Maintainer Contact: | israel@motty.io (Israel Sotomayor) |
Package Create Date: | 2015-06-30 |
Package Last Update: | 2015-07-03 |
Home Page: | |
Language: | PHP |
License: | MIT |
Last Refreshed: | 2024-12-29 15:01:32 |
Package Statistics | |
---|---|
Total Downloads: | 52 |
Monthly Downloads: | 0 |
Daily Downloads: | 0 |
Total Stars: | 2 |
Total Watchers: | 1 |
Total Forks: | 2 |
Total Open Issues: | 0 |
This are a bunch of classes
/ traits
that try to add all the missed parts from Laravel 5.1 new testing integration suite in an attempt to make our testing life even easier
We will need to setup the following environments parameters in order to make the testing helpers work.
FACTORIES_PATH = [...]
MIGRATIONS_PATH = [...]
MODELS_NAMESPACE = [...]
We will find the following Traits
to be used in our TestCase
:
use Motty\Laravel\Common\Testing\Api;
use Motty\Laravel\Common\Testing\CleanDatabase;
use Motty\Laravel\Common\Testing\MigrateDatabase;
use Motty\Laravel\Common\Testing\ResetModelEvents;
use Motty\Laravel\Common\Testing\RelocateFactories;
class ApiTestCase extends TestCase
{
use Api, CleanDatabase, MigrateDatabase, RelocateFactories, ResetModelEvents;
...
This trait
will provide us with a bunch of methods to help us when testing APIs
// Decode as json the response from call and store it on jsonResponse object
getJson()
// Asserts that an object has a specified attributes
assertObjectHasAttributes()
Method used to clean the database, this will be a specific method in charge of restart all the autoincrement index, truncate the tables if needed and all the tasks related to prepare the database before each the test case
I was needed to seed the database for each test case independently, however I ran into a problem in where the autoincrement
value of my tables do not get restarted when rolling back
or when using a transaction
We can use Laravel trait DatabaseTransactions
to delete all our just saved records after each test case
however that won't restart the index database's table, which you could need if you need to access any of the elements that you have saved into the database previously.
Note: This just work at the moment with Postgres database, you could if you whish at a PR for other Database
Trait used to migrate the database according to our environment parameter MIGRATIONS_PATH
/**
* @beforeClass
*/
public static function migrateDatabase()
{
// migrate database according to our environment parameter MIGRATIONS_PATH
Artisan::call('migrate', ['--path' => env('MIGRATIONS_PATH', 'database/migrations')]);
}
Trait used to relocate Factories according to our environment parameter FACTORIES_PATH, by default Laravel use the factories that are on the path database/factories
however to override this behaviour and use our own path for the factories is no trivial.
Trait used to reset Models' events after each test to trigger eloquent models events when testing
In order to made this trait
work we'll need to specify our models like so in our TestCase
class:
protected $models = [
'Contact',
'User'
];