2012-03-25 10:16:59 +13:00
# How To Create a SilverStripe Test
2011-02-07 19:48:44 +13:00
2011-03-09 10:05:51 +13:00
A unit test class will test the behaviour of one of your `[api:DataObjects]` . This simple fragment of `[api:SiteTreeTest]`
provides us the basics of creating unit tests.
2011-02-07 19:48:44 +13:00
:::php
< ?php
class SiteTreeTest extends SapphireTest {
2012-06-02 12:56:10 +02:00
// Define the fixture file to use for this test class
2013-03-21 19:48:54 +01:00
private static $fixture_file = 'SiteTreeTest.yml';
2011-02-07 19:48:44 +13:00
2012-06-02 12:56:10 +02:00
/**
2011-02-07 19:48:44 +13:00
* Test generation of the URLSegment values.
* - Turns things into lowercase-hyphen-format
* - Generates from Title by default, unless URLSegment is explicitly set
* - Resolves duplicates by appending a number
*/
2012-01-30 23:13:42 +01:00
public function testURLGeneration() {
2011-02-07 19:48:44 +13:00
$expectedURLs = array(
'home' => 'home',
'staff' => 'my-staff',
'about' => 'about-us',
'staffduplicate' => 'my-staff-2',
'product1' => '1-1-test-product',
'product2' => 'another-product',
'product3' => 'another-product-2',
'product4' => 'another-product-3',
);
foreach($expectedURLs as $fixture => $urlSegment) {
$obj = $this->objFromFixture('Page', $fixture);
$this->assertEquals($urlSegment, $obj->URLSegment);
}
}
}
There are a number of points to note in this code fragment:
2011-03-09 10:05:51 +13:00
* Your test is a **subclass of SapphireTest** . Both unit tests and functional tests are a subclass of `[api:SapphireTest]` .
2011-02-07 19:48:44 +13:00
* **static $fixture_file** is defined. The testing framework will automatically set up a new database for **each** of
2012-06-02 12:56:10 +02:00
your tests. The initial database content will be sourced from the YML file that you list in $fixture_file. The property can take an array of fixture paths.
2011-02-07 19:48:44 +13:00
* Each **method that starts with the word "test"** will be executed by the TestRunner. Define as many as you like; the
database will be rebuilt for each of these.
* ** $this->objFromFixture($className, $identifier)** can be used to select one of the objects named in your fixture
file. To identify to the object, we provide a class name and an identifier. The identifier is specified in the YML
2011-03-09 10:05:51 +13:00
file but not saved in the database anywhere. objFromFixture() looks the `[api:DataObject]` up in memory rather than using the
2011-02-07 19:48:44 +13:00
database. This means that you can use it to test the functions responsible for looking up content in the database.
## Assertion commands
2012-06-02 12:56:10 +02:00
**$this->assertEquals()** is an example of an assertion function.
These functions form the basis of our tests - a test
2011-02-07 19:48:44 +13:00
fails if and only if one or more of the assertions fail.
2012-06-02 12:56:10 +02:00
See [the PHPUnit manual ](http://www.phpunit.de/manual/current/en/api.html#api.assert )
2011-02-07 19:48:44 +13:00
for a listing of all PHPUnit's built-in assertions.
2012-06-02 12:56:10 +02:00
The `[api:SapphireTest]` class comes with additional assertions which are more
specific to the framework, e.g. `[assertEmailSent](api:SapphireTest->assertEmailSent())`
which can simulate sending emails through the `Email->send()` API without actually
using a mail server (see the [testing emails ](email-sending )) guide.
2011-02-07 19:48:44 +13:00
2012-12-07 18:44:00 +01:00
## Fixtures
2011-02-07 19:48:44 +13:00
2012-12-07 18:44:00 +01:00
Often you need to test your functionality with some existing data, so called "fixtures".
These records are inserted on a fresh test database automatically.
[Read more about fixtures ](fixtures ).