ergebnis / data-generator
Provides data generators.
Installs: 9 493
Dependents: 1
Suggesters: 0
Security: 0
Stars: 1
Watchers: 1
Forks: 0
Open Issues: 0
pkg:composer/ergebnis/data-generator
Requires
- php: ~8.1.0 || ~8.2.0 || ~8.3.0 || ~8.4.0 || ~8.5.0
Requires (Dev)
- ergebnis/composer-normalize: ^2.48.1
- ergebnis/data-provider: ^3.6.0
- ergebnis/license: ^2.7.0
- ergebnis/php-cs-fixer-config: ^6.54.0
- ergebnis/phpunit-slow-test-detector: ^2.20.0
- fakerphp/faker: ^1.24.1
- infection/infection: ~0.27.11
- phpstan/extension-installer: ^1.4.3
- phpstan/phpstan: ^1.12.10
- phpstan/phpstan-deprecation-rules: ^1.2.1
- phpstan/phpstan-phpunit: ^1.4.0
- phpstan/phpstan-strict-rules: ^1.6.1
- phpunit/phpunit: ^10.5.25
- rector/rector: ^1.2.10
- roave/backward-compatibility-check: ^8.6.0
This package is auto-updated.
Last update: 2025-10-13 18:10:37 UTC
README
This project provides a composer package with data generators.
Installation
Run
composer require ergebnis/data-generator
Usage
This project comes with the following data generators:
Ergebnis\DataGenerator\ConcatenatingValueGeneratorErgebnis\DataGenerator\OptionalValueGeneratorErgebnis\DataGenerator\SequentialValueGeneratorErgebnis\DataGenerator\ValueGenerator
ConcatenatingValueGenerator
Use the ConcatenatingValueGenerator to generate values by concatenating values generated from one or more StringGenerators:
<?php declare(strict_types=1); use Ergebnis\DataGenerator; $generator = new DataGenerator\ConcatenatingValueGenerator( new DataGenerator\ValueGenerator( 'foo', 'bar', 'baz', ), new DataGenerator\ValueGenerator('-'), new DataGenerator\ValueGenerator( 'qux', 'quux', ), ); foreach ($generator->generate() as $value) { echo $value . PHP_EOL } // foo-qux // foo-quux // bar-qux // bar-quux // baz-qux // baz-quux
OptionalValueGenerator
Use the OptionalValueGenerator to generate an empty string and one or more values from a list of string values:
<?php declare(strict_types=1); use Ergebnis\DataGenerator; $generator = new DataGenerator\OptionalValueGenerator( 'foo', 'bar', 'baz', ); foreach ($generator->generate() as $value) { echo $value . PHP_EOL } // empty string // foo // bar // baz
SequentialValueGenerator
Use the SequentialValueGenerator to generate one or more values from one or more StringGenerators:
<?php declare(strict_types=1); use Ergebnis\DataGenerator; $generator = new DataGenerator\SequentialValueGenerator( new DataGenerator\ValueGenerator( 'foo', 'bar', 'baz', ), new DataGenerator\ValueGenerator( 'qux', 'quux', ), ); foreach ($generator->generate() as $value) { echo $value . PHP_EOL } // foo // bar // baz // qux // quux
ValueGenerator
Use the ValueGenerator to generate one or more values from a list of string values:
<?php declare(strict_types=1); use Ergebnis\DataGenerator; $generator = new DataGenerator\ValueGenerator( 'foo', 'bar', 'baz', ); foreach ($generator->generate() as $value) { echo $value . PHP_EOL } // foo // bar // baz
Changelog
The maintainers of this project record notable changes to this project in a changelog.
Contributing
The maintainers of this project suggest following the contribution guide.
Code of Conduct
The maintainers of this project ask contributors to follow the code of conduct.
General Support Policy
The maintainers of this project provide limited support.
You can support the maintenance of this project by sponsoring @ergebnis.
PHP Version Support Policy
This project supports PHP versions with active and security support.
The maintainers of this project add support for a PHP version following its initial release and drop support for a PHP version when it has reached the end of security support.
Security Policy
This project has a security policy.
License
This project uses the MIT license.
Social
Follow @localheinz and @ergebnis on Twitter.