marcin-orlowski / phpunit-extra-asserts
Extra asserts and helpers to make your unit testing easier.
Installs: 15 980
Dependents: 5
Suggesters: 0
Security: 0
Stars: 2
Watchers: 2
Forks: 0
Open Issues: 0
pkg:composer/marcin-orlowski/phpunit-extra-asserts
Requires
- php: ^8.0
- marcin-orlowski/type-asserts: ^2.0.0
Requires (Dev)
- phpstan/phpstan: ^1.9.1
- phpunit/php-code-coverage: ^9.0
- phpunit/phpunit: ^9.5.26
README
Collection of additional asserts to be used with PHP Unit testing framework. Helpers are split into dedicated namespaces:
- ExtraAsserts: various asserts to help testing your code,
- Generator: various helper methods producing random values for your tests,
Installation
composer require --dev marcin-orlowski/phpunit-extra-asserts
Usage
As ExtraAsserts come as set of static methods so you just need to add related use to your test
class and all
the methods should be simply available via static reference ExtraAsserts::.... For example:
use \MarcinOrlowski\PhpunitExtraAsserts\ExtraAsserts; class MyBaseTestClass extends ... { use \MarcinOrlowski\PhpunitExtraAsserts\ExtraAsserts; use \MarcinOrlowski\PhpunitExtraAsserts\Type; [...] public function testSomething(): void { [...] ExtraAsserts::assertIsType($val, [Type::STRING, Type::BOOL]); ExtraAsserts::assertRFC3339($stamp); } }
Available asserts
| Assert | Description | Added | 
|---|---|---|
| assertArrayElement(string $key, array $array, string $expected_value) | Asserts given array has specified key and it's value is according to expectations. | v1.0.0 | 
| assertArrayEquals(array $array_a, array $array_b) | Asserts two arrays are equivalent. | v1.0.0 | 
| assertArrayHasKeys(array $required_keys, array $array) | Asserts array has ALL the required keys. | v1.0.0 | 
| assertArraysHaveDifferences(int $diff_count, array $array_a, array $array_b) | Asserts two arrays differ by exactly given number of elements (default is 0). | v1.0.0 | 
| assertRFC3339(string $stamp) | Asserts provided string is valid RFC3339 timestamp string. | v1.0.0 | 
| assertRFC3339OrNull(string $stamp) | Asserts $stamp string is valid RFC3339 timestamp string or @null. | v1.0.0 | 
| massAssertEquals(array $array_a, array $array_b, array $ignored_keys) | Assert if keys from response have the same values as in original array. Keys listed in $skip_keys are ignored. | v1.0.0 | 
| assertIsObjectOrExistingClass(string OR object $cls_or_obj, ?string $var_nam = null) | Asserts given $value (which the value of variable named $var_name) is an object or name name of existing class. | v3.0.0 | 
| [DEPRECATED] assertIsArray(mixed $value, ?string $var_name = null) | Asserts given $value (which the value of variable named $var_name) is an array. | v3.0.0 | 
| [DEPRECATED] assertIsBool(mixed $value, ?string $var_name = null) | Asserts given $value (which the value of variable named $var_name) is a boolean. | v3.0.0 | 
| [DEPRECATED] assertIsFloat(mixed $value, ?string $var_name = null) | Asserts given $value (which the value of variable named $var_name) is an float. | v3.0.0 | 
| [DEPRECATED] assertIsInteger(mixed $value, ?string $var_name = null) | Asserts given $value (which the value of variable named $var_name) is an integer. | v3.0.0 | 
| [DEPRECATED] assertIsInteger(mixed $value, ?string $var_name = null) | Asserts given $value (which the value of variable named $var_name) is an integer. | v3.0.0 | 
| [DEPRECATED] assertIsObject(mixed $value, ?string $var_name = null) | Asserts given $value (which the value of variable named $var_name) is an object (of any class). | v3.0.0 | 
| [DEPRECATED] assertIsString(mixed $value, ?string $var_name = null) | Asserts given $value (which the value of variable named $var_name) is an string. | v3.0.0 | 
NOTE: Deprecated methods will be removed in v5.4.0
Helper methods
| Method | Description | 
|---|---|
| printArray(array $array, int $indent) | Prints content of given array in compacted form. | 
Generator methods
| Method | Description | 
|---|---|
| getRandomString(?string $prefix = null, int $length = 24, string $separator = '_') | Returns string of total length equal to specified limit (incl. optional prefix or separator strings) | 
| getRandomStringOrNull(?string $prefix = null, int $length = 24, string $separator = '_', float $trueValueProbability = 0.5) | Returns either random stringorNULL. Probability (float value in range 0-1) specifies the chance of drawing thestringvalue. The higher the value of this argument, the higher the chance forstringbeing returned. | 
| getRandomFloat(float $min, float $max, int $fractionalDigits = 0) | Draws random floatfrom given range. If givenmaxis lower thanmin, these two will be swapped.  If number of fractional digits is non-zero, value will be rounded to given number of fractional digits. Value0means not rounding. | 
| getRandomInt(int $min = 0, int $max = 100) | Draws random intfrom given range. If givenmaxis lower thanmin, these two will be swapped. | 
| getRandomBool(float $trueValueProbability = 0.5) | Draws random booleanvalue. Float value (in 0-1 range) defining the chances of drawing the value ofTRUE. The higher the of this argument, the higher the chances to drawTRUE. | 
| getRandomLatitude(float $min, float $max, int $round=0) | Draws random latitude from given range (default is max allowed range). If given maxis lower thanmin, these two will be swapped. | 
| getRandomLongitude(float $min, float $max, int $round=0) | Draws random longitude from given range (default is max allowed range). If given maxis lower thanmin, these two will be swapped. | 
License
- Written and copyrighted ©2014-2022 by Marcin Orlowski
- Open-sourced software licensed under the MIT license