mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 12:05:37 +00:00
Merge pull request #7079 from andrewandante/patch-1
Add $fixture_file to the fixtures docs
This commit is contained in:
commit
c6a6fdd784
@ -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
|
||||
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
|
||||
ideal for fixture generation. Say we have the following two DataObjects:
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user