Merge pull request #7079 from andrewandante/patch-1

Add $fixture_file to the fixtures docs
This commit is contained in:
Daniel Hensby 2017-06-30 15:45:46 +01:00 committed by GitHub
commit c6a6fdd784

View File

@ -9,6 +9,42 @@ SilverStripe starts with a fresh database containing no records. `Fixtures` prov
to load into the database. The [api:SapphireTest] class takes care of populating a test database with data from to load into the database. The [api:SapphireTest] class takes care of populating a test database with data from
fixtures - all we have to do is define them. fixtures - all we have to do is define them.
<div class="info" markdown='1'>
To include your fixture file in your tests, you should define it as your `$fixture_file`:
**mysite/tests/MyNewTest.php**
:::php
<?php
class MyNewTest extends SapphireTest {
protected static $fixture_file = 'fixtures.yml';
}
You can also use an array of fixture files, if you want to use parts of multiple other tests:
**mysite/tests/MyNewTest.php**
:::php
<?php
class MyNewTest extends SapphireTest {
protected static $fixture_file = [
'fixtures.yml',
'otherfixtures.yml'
];
}
</div>
Typically, you'd have a separate fixture file for each class you are testing - although overlap between tests is common.
Fixtures are defined in `YAML`. `YAML` is a markup language which is deliberately simple and easy to read, so it is Fixtures are defined in `YAML`. `YAML` is a markup language which is deliberately simple and easy to read, so it is
ideal for fixture generation. Say we have the following two DataObjects: ideal for fixture generation. Say we have the following two DataObjects: