2019-11-18 17:54:24 +13:00
---
title: Testing
2014-09-21 12:07:58 +12:00
summary: Deploy robust applications by bundling Unit and Behavior tests with your application code and modules.
2019-11-18 17:54:24 +13:00
---
2011-02-07 19:48:44 +13:00
# Unit and Integration Testing
2013-10-04 14:24:56 +13:00
For behaviour testing in SilverStripe, check out [SilverStripe Behat Documentation ](https://github.com/silverstripe-labs/silverstripe-behat-extension/ ).
## Introduction
2012-03-25 10:16:59 +13:00
The SilverStripe core contains various features designed to simplify the process of creating and managing automated tests.
2011-02-07 19:48:44 +13:00
2013-10-04 14:24:56 +13:00
SilverStripe uses [PHPUnit ](http://www.phpunit.de ) for unit tests, and the framework contains features to simplify the
process of creating and managing tests.
If you're more familiar with unit testing, but want a refresher of some of the concepts and terminology, you can browse
2015-02-27 16:09:15 -08:00
the [Testing Glossary ](testing_glossary ). To get started now, follow the installation instructions below.
2013-10-04 14:24:56 +13:00
2014-09-08 17:13:36 +12:00
If you are familiar with PHP coding but new to unit testing then check out Mark's presentation [Getting to Grips with SilverStripe Testing ](http://www.slideshare.net/maetl/getting-to-grips-with-silverstripe-testing ).
2013-10-04 14:24:56 +13:00
2011-02-07 19:48:44 +13:00
You should also read over [the PHPUnit manual ](http://www.phpunit.de/manual/current/en/ ). It provides a lot of
fundamental concepts that we build on in this documentation.
2015-05-19 09:19:55 -07:00
Unit tests are not included in the zip/tar.gz SilverStripe [downloads ](http://www.silverstripe.org/software/download/ ) so to get them, install SilverStripe [with composer ](/getting_started/composer ).
2011-02-07 19:48:44 +13:00
2015-05-19 09:19:55 -07:00
## Invoking phpunit
2014-09-08 17:13:36 +12:00
2015-05-19 09:19:55 -07:00
Once you have used composer to create your project, `cd` to your project root. Composer will have installed PHPUnit alongside the required PHP classes into the `vendor/bin/` directory.
2014-09-12 17:02:04 +12:00
2015-05-19 09:19:55 -07:00
If you don't want to invoke PHPUnit through its full path (`vendor/bin/phpunit` ), add `./vendor/bin` to your $PATH, or symlink phpunit into the root directory of your website:
2014-09-12 17:02:04 +12:00
2015-05-19 09:19:55 -07:00
- `PATH=./vendor/bin:$PATH` in your shell's profile script; **or**
- `ln -s vendor/bin/phpunit phpunit` at the command prompt in your project root
2011-02-07 19:48:44 +13:00
2013-09-12 18:22:46 +01:00
## Configuration
2011-02-07 19:48:44 +13:00
2013-09-12 18:22:46 +01:00
### phpunit.xml
2011-02-07 19:48:44 +13:00
2013-10-04 14:24:56 +13:00
The `phpunit` executable can be configured by command line arguments or through an XML file. File-based configuration has
2013-09-12 18:22:46 +01:00
the advantage of enforcing certain rules across test executions (e.g. excluding files from code coverage reports), and
of course this information can be version controlled and shared with other team members.
2011-02-07 19:48:44 +13:00
2013-09-12 18:22:46 +01:00
**Note: This doesn't apply for running tests through the "sake" wrapper**
2011-02-07 19:48:44 +13:00
2013-09-12 18:22:46 +01:00
SilverStripe comes with a default `phpunit.xml.dist` that you can use as a starting point. Copy the file into a new
2016-03-30 13:17:28 +13:00
`phpunit.xml` and customise to your needs - PHPUnit will auto-detect its existence, and prioritize it over the default
2013-09-12 18:22:46 +01:00
file.
2011-02-07 19:48:44 +13:00
2013-09-12 18:22:46 +01:00
There's nothing stopping you from creating multiple XML files (see the `--configuration` flag in
[PHPUnit documentation ](http://www.phpunit.de/manual/current/en/textui.html )). For example, you could have a
`phpunit-unit-tests.xml` and `phpunit-functional-tests.xml` file (see below).
2011-02-07 19:48:44 +13:00
2013-09-12 18:22:46 +01:00
### Database Permissions
2011-02-07 19:48:44 +13:00
2013-09-12 18:22:46 +01:00
SilverStripe tests create thier own database when they are run. Because of this the database user in your config file
should have the appropriate permissions to create new databases on your server, otherwise tests will not run.
2011-02-07 19:48:44 +13:00
## Writing Tests
2016-02-17 14:21:59 -07:00
Tests are written by creating subclasses of [api:SapphireTest]. You should put tests for your site in the
2011-02-07 19:48:44 +13:00
`mysite/tests` directory. If you are writing tests for a module, put them in the `(modulename)/tests` directory.
Generally speaking, there should be one test class for each application class. The name of the test class should be the
application class, with "Test" as a suffix. For instance, we have all the tests for `SiteTree` in
2012-03-25 10:16:59 +13:00
`framework/tests/SiteTreeTest.php`
2011-02-07 19:48:44 +13:00
You will generally write two different kinds of test classes.
* **Unit Test:** Test the behaviour of one of your DataObjects.
* **Functional Test:** Test the behaviour of one of your controllers.
2012-03-25 10:16:59 +13:00
Tutorials and recipes for creating tests using the SilverStripe framework:
2011-02-07 19:48:44 +13:00
2015-02-18 20:47:57 -06:00
* [Creating a SilverStripe test ](how_tos/write_a_sapphiretest ): Writing tests to check core data objects
* [Creating a functional test ](how_tos/write_a_functionaltest ): An overview of functional tests and how to write a functional test
* [Testing Outgoing Email ](how_tos/testing_email ): An overview of the built-in email testing code
2012-11-15 14:15:46 +01:00
2013-09-12 18:22:46 +01:00
## Running Tests
2012-11-15 14:15:46 +01:00
2013-09-12 18:22:46 +01:00
### Via the "phpunit" Binary on Command Line
2012-11-15 14:15:46 +01:00
2013-09-12 18:22:46 +01:00
The `phpunit` binary should be used from the root directory of your website.
2012-11-15 14:15:46 +01:00
2019-11-18 17:54:24 +13:00
```
2013-09-24 21:09:30 +01:00
# Runs all tests defined in phpunit.xml
phpunit
2012-11-15 14:15:46 +01:00
2013-09-24 21:09:30 +01:00
# Run all tests of a specific module
phpunit framework/tests/
2012-11-15 14:15:46 +01:00
2013-09-24 21:09:30 +01:00
# Run specific tests within a specific module
phpunit framework/tests/filesystem
2011-02-07 19:48:44 +13:00
2013-09-24 21:09:30 +01:00
# Run a specific test
phpunit framework/tests/filesystem/FolderTest.php
2011-02-07 19:48:44 +13:00
2013-09-24 21:09:30 +01:00
# Run tests with optional `$_GET` parameters (you need an empty second argument)
phpunit framework/tests '' flush=all
2012-11-09 19:16:16 +01:00
2019-11-18 17:54:24 +13:00
```
2013-09-12 18:22:46 +01:00
[phpunit.de ](http://www.phpunit.de/manual/current/en/textui.html ).
2011-02-07 19:48:44 +13:00
2013-09-12 18:22:46 +01:00
### Via the "sake" Wrapper on Command Line
2011-02-07 19:48:44 +13:00
2016-03-30 13:17:28 +13:00
The [sake ](/developer_guides/cli/ ) executable that comes with SilverStripe can trigger a customised
2016-02-17 14:21:59 -07:00
[api:TestRunner] class that handles the PHPUnit configuration and output formatting.
2013-09-12 18:22:46 +01:00
While the custom test runner a handy tool, its also more limited than using `phpunit` directly,
particularly around formatting test output.
2011-02-07 19:48:44 +13:00
2019-11-18 17:54:24 +13:00
```
2013-09-24 21:09:30 +01:00
# Run all tests
sake dev/tests/all
2011-02-07 19:48:44 +13:00
2013-09-24 21:09:30 +01:00
# Run all tests of a specific module (comma-separated)
sake dev/tests/module/framework,cms
2011-02-07 19:48:44 +13:00
2013-09-24 21:09:30 +01:00
# Run specific tests (comma-separated)
sake dev/tests/FolderTest,OtherTest
2011-02-07 19:48:44 +13:00
2013-09-24 21:09:30 +01:00
# Run tests with optional `$_GET` parameters
sake dev/tests/all flush=all
2011-02-07 19:48:44 +13:00
2013-09-24 21:09:30 +01:00
# Skip some tests
sake dev/tests/all SkipTests=MySkippedTest
2011-02-07 19:48:44 +13:00
2019-11-18 17:54:24 +13:00
```
2011-02-07 19:48:44 +13:00
2013-09-12 18:22:46 +01:00
Executing tests from the command line is recommended, since it most closely reflects
2015-05-19 09:19:55 -07:00
test runs in any automated testing environments. However, you can also run tests through the browser: