peridot-php / peridot-httpkernel-plugin
A Peridot plugin to simplify testing HttpKernel applications
Installs: 7 428
Dependents: 0
Suggesters: 0
Security: 0
Stars: 4
Watchers: 4
Forks: 3
Open Issues: 0
Requires
- peridot-php/peridot: ~1.0
- symfony/browser-kit: ~2.0
Requires (Dev)
- silex/silex: ~1.0
This package is not auto-updated.
Last update: 2024-12-17 03:30:28 UTC
README
Easily test HttpKernel applications with Peridot.
Some HttpKernel based frameworks:
- Silex
- [Laravel] (http://laravel.com/)
- [Symfony2] (http://symfony.com/what-is-symfony)
##Usage
We recommend installing this plugin to your project via composer:
$ composer require --dev peridot-php/peridot-httpkernel-plugin:~1.0
You can register the plugin via your peridot.php file.
<?php use Evenement\EventEmitterInterface; use Peridot\Plugin\HttpKernel\HttpKernelPlugin; return function(EventEmitterInterface $emitter) { //the second argument expects an HttpKernelInterface or a function that returns one HttpKernelPlugin::register($emitter, include __DIR__ . '/app.php'); };
By registering the plugin, your Peridot tests will now have a $client
property available:
<?php describe('Api', function() { describe('/info', function() { it('should return info about Peridot', function() { $this->client->request('GET', '/info'); $response = $this->client->getResponse(); $info = json_decode($response->getContent()); assert($info->project == "Peridot", "project should be Peridot"); assert($info->description == "Event driven testing framework", "description should describe Peridot"); assert($info->styles == "BDD, TDD", "styles should be BDD, TDD"); }); }); describe('/author', function() { it('should return info about the author', function() { $this->client->request('GET', '/author'); $author = json_decode($this->client->getResponse()->getContent()); assert($author->name == "Brian Scaturro", "author name should be on response"); assert($author->likes == "pizza", "author should like pizza"); }); }); });
VoilĂ !
Don't want a client in all of your tests? No problem.
###Using on a test by test basis
Like any other peridot scope, you can mix the HttpKernelScope
provided by this plugin
on a test by test, or suite by suite basis.
<?php use Peridot\Plugin\HttpKernel\HttpKernelScope; describe('Api', function() { //here we manually mixin the http kernel scope $scope = new HttpKernelScope(include __DIR__ . '/../app.php'); $this->peridotAddChildScope($scope); describe('/author', function() { it('should return info about the author', function() { $this->client->request('GET', '/author'); $author = json_decode($this->client->getResponse()->getContent()); assert($author->name == "Brian Scaturro", "author name should be on response"); assert($author->likes == "pizza", "author should like pizza"); }); }); });
###Configuring the client property name
If $this->client
is a little too generic for your tastes, both the scope and plugin take an optional last argument that allows you to
you set this.
HttpKernelPlugin::register($emitter, include __DIR__ . '/app.php', "browser"); $scope = new HttpKernelScope($application, "browser");
Your tests now become:
<?php use Peridot\Plugin\HttpKernel\HttpKernelScope; describe('Api', function() { describe('/author', function() { it('should return info about the author', function() { $this->browser->request('GET', '/author'); $author = json_decode($this->browser->getResponse()->getContent()); assert($author->name == "Brian Scaturro", "author name should be on response"); assert($author->likes == "pizza", "author should like pizza"); }); }); });
##Example specs
This repo comes with a sample Silex application that is tested with this plugin.
To test examples that are using the plugin, run the following:
$ vendor/bin/peridot -c app/peridot.php app/specs/api.spec.php
To test examples that are manually adding the scope in, run this:
$ vendor/bin/peridot app/specs/no-plugin.spec.php
##Running plugin tests
$ vendor/bin/peridot specs/