Download the PHP package docteurklein/test-double-bundle without Composer
On this page you can find all versions of the php package docteurklein/test-double-bundle. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download docteurklein/test-double-bundle
More information about docteurklein/test-double-bundle
Files in docteurklein/test-double-bundle
Package test-double-bundle
Short Description Easily create test doubles using symfony DIC
License MIT
Informations about the package test-double-bundle
TestDoubleBundle
What ?
A symfony bundle that eases creation of test doubles.
Using DIC tags, you can automatically replace a service with either a stub or a fake.
Why ?
To improve isolation of tests and increase the precision and variation of test fixtures.
Usually, our behat suite is using real data, coming from database fixtures.
This forces us to create gobal, universal, works-for-all fixtures.
A real database also implies to reset the state before each scenario.
This process is slow, and is just a workaround for having broken isolation.
An ideal test suite would run each scenario using only in-memory repositories.
Each scenario should define how the SUS behaves given a specific context.
Having a global implicit context (the database fixtures) makes it really hard to test different cases.
One solution is to replace your repositories with stubs.
Each scenario configures only the stubs required for it to work.
Note: Stubbed data is not resilient across processes, and thus doesn't fit for end-to-end testing like a typical mink+behat suite.
But now that repositories are doubled, how do you know if your real repositories still work?
Well, that's the role of infrastructure tests. Only those run against a real backend,
be it a database for repositories, or a server for an http client.
To access the real services, just use <original-id>.real
.
By doing that, you theoretically have a good coverage, isolation, speed
and you can better catch the origin of a regression.
All this while applying modelling by example.
How ?
install
composer require docteurklein/test-double-bundle --dev
register the bundle
Note: You might want to add this bundle only in test env.
integrate with behat
This approach integrates very well with the Symfony2Extension.
You can then inject the service and/or the prophecy in your context class.
You can also inject the container and access all the services at once.
Examples
Note: The following examples use JmsDiExtraBundle to simplify code.
Stubs
Stubs are created using prophecy.
Note: if you don't provide any tag attribute, then a stub is created. if no class or interface is given to the
stub
attribute, then a stub for the service class will be created. A stubbed class cannot be final.
- First, define a stub DIC tag for the service
- Automatically, the original
github_client
service is replaced with thegithub_client.stub
service.
In order to control this stub, you have to use the github_client.prophecy
service:
Fake
Note: fakes are really just DIC aliases.
Imagine you have a service you want to double.
-
First, create this service and add a tag with the corresponding fake service:
- Then, create a fake implementation and register it with the fake id:
Behat
Note: We tagged
repo.invoices
andhttp.client
as stub.
All versions of test-double-bundle with dependencies
symfony/http-kernel Version ^2.0|^3.0
symfony/dependency-injection Version ^2.0|^3.0
phpspec/prophecy Version ^1.6