foothing/laravel-fixture

There is no license information available for the latest version (v0.1.0) of this package.

Lightweight fixtures for Laravel 4

v0.1.0 2015-02-16 19:21 UTC

This package is auto-updated.

Last update: 2024-10-22 23:46:38 UTC


README

Basic light-weight fixtures management for Laravel 4.

How to use

Setup the tearDown() in your test cases

public function tearDown() {
	// Your code
    // ...
	Fixture::tearDown();
}

Usage of Fixture::need()

class FooTest {
	public function testBar() {
    	// Create your fixture by passing the namespaced class name
        // you want to fixture and an array of attributes.
        // If an User instance matching the given attributes is found,
        // then it will be returned. Otherwise a new User instance will be
        // saved to the testing database.
        // Note that User must be an Eloquent implementation.
		$user = Fixture::need('User', array('email' => 'email1'));

        // Example, $user now exists with the given attributes.
        $this->assertEquals($user->email, 'email1');

        // ...
        // more tests.
	}
}

You'll want to use the need method when your test requires a given instance.

Usage of Fixture::needNot()

class FooTest {
	public function testBar() {
    	// Ensure that no instances of Some\Object matching the given
        // attributes are stored in the testing database.
		Fixture::needNot('Some\Object', array('attribute' => 'value'));
	}
}

You'll use this when your test requires that your database is clean before running.

This may save you some time since you can have a fine data setup instead of running migrations that slower down test execution time.

Note that Fixture is not a Facade, so you don't need to configure any service provider.