friends-of-behat/variadic-extension
Variadic support for behat context arguments
Maintainers
Package info
github.com/FriendsOfBehat/VariadicExtension
Language:Gherkin
pkg:composer/friends-of-behat/variadic-extension
Requires
- php: ^8.1
- behat/behat: ^3.8 || ^4.0
- symfony/dependency-injection: ^5.4 || ^6.4 || ^7.4 || ^8.0
Requires (Dev)
Suggests
None
Provides
None
Conflicts
None
Replaces
None
MIT 98b976c017058f8e5d950e10544197435fb0c587
- Łukasz Chruściel <lchrusciel.woop@gmail.com>
README
Adds variadic arguments support to Behat steps definitions.
The why
In Behat, if you want a step definition to accept different numbers of arguments, you normally have to define separate methods for each variation. This quickly becomes repetitive and hard to maintain as the number of argument combinations grows.
This extension solves that by letting you use PHP's variadic syntax (...$args) in your step definitions.
A single method can capture many argument variations, keeping your context classes clean and concise.
Usage
-
Install it:
$ composer require friends-of-behat/variadic-extension --dev
-
Enable it in your Behat configuration:
# behat.yml default: # ... extensions: FriendsOfBehat\VariadicExtension: ~
or if you use a PHP-based configuration:
# behat.php use Behat\Config\Config; use Behat\Config\Extension; use Behat\Config\Profile; use FriendsOfBehat\VariadicExtension\ServiceContainer\VariadicExtension; return (new Config()) ->withProfile( (new Profile('default')) ->withExtension(new Extension(VariadicExtension::class)) );
-
You can use variadic arguments in steps definitions!
/** * @Given the store has( also) :firstProductName and :secondProductName products * @Given the store has( also) :firstProductName, :secondProductName and :thirdProductName products * @Given the store has( also) :firstProductName, :secondProductName, :thirdProductName and :fourthProductName products */ public function theStoreHasProducts(...$productsNames) { foreach ($productsNames as $productName) { $this->saveProduct($this->createProduct($productName)); } } /** * @Given /^(this channel) has "([^"]+)" and "([^"]+)" products$/ * @Given /^(this channel) has "([^"]+)", "([^"]+)" and "([^"]+)" products$/ * @Given /^(this channel) has "([^"]+)", "([^"]+)", "([^"]+)" and "([^"]+)" products$/ */ public function thisChannelHasProducts(ChannelInterface $channel, ...$productsNames) { foreach ($productsNames as $productName) { $product = $this->createProduct($productName, 0, $channel); $this->saveProduct($product); } }
