rmiller / exemplify-extension
PhpSpec extension that adds exemplify command to generate examples in specs
Requires
- php: >=5.4
- phpspec/phpspec: ^3.0
- rmiller/caser: ^0.1
Requires (Dev)
- behat/behat: ^3.0
This package is not auto-updated.
Last update: 2025-01-14 04:40:57 UTC
README
PhpSpec extension that adds exemplify command to generate examples in specs.
For example, running:
bin/phpspec exemplify RMiller/Badger dig
And choosing the default option of 'instance method', will add the following example to the spec/RMiller/BadgerSpec class:
public function it_should_dig()
{
$this->dig();
}
This can then be modified to describe the behaviour for the method.
Installation
Requires:
- PhpSpec 3.0+
- PHP 5.6+
To use 'named constructor' examples , you need to use phpspec >2.1
.
Otherwise the examples will be created but will not run.
Require the extension:
$ composer require --dev rmiller/exemplify-extension:^0.5
Configuration
Activate the extension by specifying its class in your phpspec.yml
:
# phpspec.yml extensions: RMiller\BehatSpec\Extension\ExemplifyExtension\ExemplifyExtension: ~
Method Types
Three different method types are supported, on running the command you will be asked which type of method is being described. These are:
- Instance Method (e.g. $this->dig())
- Static Method (e.g. $this::dig())
- Named Constructor
The names constructor option is for static methods used to instantiate and return an instance of the class. It is essentially another name for a factory method. This is listed separately as the example created is different.
For example, running:
bin/phpspec exemplify RMiller/Badger withName
And choosing the option of 'named constructor', will add the following to the spec/RMiller/BadgerSpec class:
public function it_should_be_constructed_through_with_name()
{
$this->beConstructedThrough('withName');
}
Other Potentially Useful Extensions
-
For further laziness PhpSpecRunExtension will execute the phpspec run command after the describe and exemplify commands, saving a few keystrokes.
-
This extension and PhpSpecRun are also part of BehatSpec which provides integration between Behat and PhpSpec. This includes running the exemplify command automatically for missing methods encountered when running Behat features.