otgs / unit-tests-framework
A framework to build unit tests with OTGS products
Installs: 470 384
Dependents: 10
Suggesters: 0
Security: 0
Stars: 1
Watchers: 20
Forks: 0
Open Issues: 0
pkg:composer/otgs/unit-tests-framework
Requires
- 10up/wp_mock: ^0.4
- dms/phpunit-arraysubset-asserts: ~0.5.0
- lucatume/function-mocker: ^2.0
- phpunit/phpunit: ^9.6
- roave/security-advisories: dev-master
- symfony/css-selector: ^5.0
- symfony/dom-crawler: ^5.0
- dev-develop
- 4.1.0
- 4.0.0
- 3.0.0
- 2.0.0
- 1.2.8
- 1.2.7
- 1.2.6
- 1.2.5
- 1.2.4
- 1.2.3
- 1.2.2
- 1.2.1
- 1.2.0
- 1.1.2
- 1.1.1
- 1.1.0
- 1.0.2
- 1.0.1
- 1.0.0
- dev-develop-wpml
- dev-feature/systemsdev-7273
- dev-revert-8-feature/systemsdev-3038
- dev-feature/systemsdev-3038
- dev-christian/wpmlsystem-34
- dev-phpunit-7b
- dev-phpunit-7a
- dev-phpunit-7
- dev-phpunit-5
- dev-php74
- dev-wpmlga-568
- dev-php-74
- dev-master
- dev-hotfix/wpmlga-524
- dev-toolset-mod
- dev-last-php52-compatible
- dev-fail-on-wpdb-errors
- dev-dep-updates
- dev-php7-bump
- dev-phpunit7-dev
- dev-fluent-mocks
- dev-lock-function-mocker-to-1.3.4
- dev-fix-function-mocker
- dev-new-stubs
- dev-remove-stubs
- dev-add_property_to_wp_query
- dev-wpmlcore-4171
- dev-wpmlcore-4184
- dev-stubs-removal
- dev-wp_send_json
- dev-wpmlcore-3198
This package is auto-updated.
Last update: 2025-10-02 15:29:18 UTC
README
- Create a testsdirectory in your project
- Create a phpunitsubdirectory intests1
- Copy samples/phpunit.xmlfile in the root of your project2- Change test-suite-nameinto something appropriated
- Most likely, you won't need to change anything else in that file
 
- Change 
- Copy samples/bootstrap.phpintotests/phpunit- Read the comments in this file and make the appropriated changes
 
- Run composer require --dev otgs/unit-tests-framework3
- Create another testssubdirectory intests/phpunit- Write your tests there
- Unless you have customized the phpunit.xmlfile, you don't need to name the test files and classes in any particular way
 
- Run phpunitfrom your project's root to start your tests4
How to use the OTGS_TestCase class
In order to take the most of this library, all your tests classes should extext OTGS_TestCase.
Once you do that, this will happen:
- \OTGS_TestCase::setupBeforeClass:
- $_GETand- $_POSTare set to an empty array
- An instance of FactoryMuffinis provided: you can refer to it asself::$fm(see "Resources and dependencies" for more details)
- \OTGS_TestCase::setUp
- FunctionMockeris initialized (see "Resources and dependencies" for more details)
- WP_Mockis initialized (see "Resources and dependencies" for more details)
- \OTGS_TestCase::tearDown
- WP_Mockis destroyed
- FunctionMockeris destroyed
- Mockeryis destroyed (just in case it has been used)
- \OTGS_TestCase::tearDownAfterClass
- Deletes all models created with FactoryMuffin
Mock WP Core functions
This class also provide an helper method to quickly mock the functions defined by WordPress by using the \OTGS_TestCase::get_mocked_wp_core_functions which returns an instance of OTGS_Mocked_WP_Core_Functions.
OTGS_Mocked_WP_Core_Functions organize mocks in methods named using the same name of the file where the function is defined in WordPress codebase.
For instance, to mock of all functions defined in post.php like get_post, in your test you should simply call $this->get_mocked_wp_core_functions()->post().
To mock add_query_arg yo call $this->get_mocked_wp_core_functions()->functions() because add_query_arg is defined in functions.php.
OTGS_Mocked_WP_Core_Functions tries to handle dependencies.
So, if you call $this->get_mocked_wp_core_functions()->post() to mock wp_insert_post, you automatically call $this->get_mocked_wp_core_functions()->post(), so to get all the meta related functions mocked as well.
Finally, there is a "mock all" method you could use (though is discouraged) with $this->mock_all_core_functions().
Stub WP common classes
\OTGS_TestCase provides a helpful way to quickly get a stub of some of the most commonly used classes in WordPress.
By calling $this->stubs->wpdb() you will get a stub you can pass as a dependency of the classes you are testing.
If you need to control the behavior of this stub, you just use the standard PHPUnit mock helpers.
E.g. 1:
$wpdb = $this->stubs->wpdb(); $wpdb->method( 'get_var' )->willReturn( 1 );
E.g. 2:
$results = array( array( 'translation_id' => 1, 'element_id' => 1, 'language_code' => 'en', 'source_language_code' => null, 'trid' => 1, 'element_type' => 'post_page' ), array( 'translation_id' => 2, 'element_id' => 2, 'language_code' => 'fr', 'source_language_code' => 'en', 'trid' => 1, 'element_type' => 'post_page' ), ); $wpdb = $this->this->wpdb(); $wpdb->expects( $this->exactly( 2 ) )->method( 'get_results' )->willReturn( $results );
Other stubs you can get:
- WP_Widgetwith- $this->stubs->WP_Widget()
- WP_Themewith- $this->stubs->WP_Theme()
- WP_Filesystem_Directwith- $this->stubs->WP_Filesystem_Direct()
- WP_Querywith- $this->stubs->WP_Query()
It is important to know that, if you only need the class to be defined (e.g. hard-dependency, or sub-classing), you don't need to assig the stub to a variable: just call the method.
A good example is with WordPress' widgets, where you may have your own widget which is supposed to extend WP_Widget.
In this case, unless you want to mock some of the WP_Widget methods, you simply call $this->stubs->WP_Widget(), then write your tests.
The class which extends WP_Widget will find a definition of this class, with all the methods (doing nothing).
Resources and dependencies
Below are some resources on writing unit tests which lead to the creation of this library and links to the libraries included here:
- Start from here for a general explanation: http://wordpress.stackexchange.com/a/164138/7291
- 10up's WP_Mock`: https://github.com/10up/wp_mock
- Mockery: https://github.com/padraic/mockery
- Function mocker: https://github.com/lucatume/function-mocker
- Factory Muffin: https://github.com/thephpleague/factory-muffin
- Factory Muffin Faker: https://github.com/thephpleague/factory-muffin-faker
- The DomCrawler Component: http://symfony.com/doc/current/components/dom_crawler.html
- The CssSelector Component: http://symfony.com/doc/current/components/css_selector.html
- php-loremipsum: https://github.com/joshtronic/php-loremipsum
Footnotes
- 
it is recommended to keep your PHPUnit tests into a subfolder, because there are good changes you want to add other kind of tests (e.g. QUnit, PHPSpec, etc.) ↩ 
- 
in case, for whatever reason, you can't do that, copy this file in tests/phpunitor wherever you find it more convenient ↩
- 
In some cases, you may want to use composer require --dev otgs/unit-tests-framework:dev-develop. When you do that, you may also need to run this command firstcomposer config minimum-stability dev↩
- 
If you've placed the phpunit.xmlyou need to either move to that directory first, or tell phpunit where the file is withphpunit --configuration path/to/phpunit.xml↩