kuria / phpunit-extras
Additional functionality for PHPUnit (such as assertions)
Installs: 3 262
Dependents: 1
Suggesters: 0
Security: 0
Stars: 1
Watchers: 2
Forks: 0
Open Issues: 0
Requires
- php: >=7.1
- kuria/iterable: ^1.0
- phpunit/phpunit: ^7.3.5
Requires (Dev)
- kuria/clock: ^1.0
- kuria/dev-meta: ^0.6
README
Additional functionality for PHPUnit (such as assertions).
Contents
- Requirements
- Usage
AssertionTrait
assertLooselyIdentical($expected, $actual, $canonicalizeKeys = false)
assertSameIterable(iterable $expected, $actual)
assertLooselyIdenticalIterable(iterable $expected, $actual, $canonicalizeKeys = false)
assertEqualIterable(iterable $expected, $actual)
looselyIdenticalTo($value, $canonicalizeKeys = false)
identicalIterable(iterable $expected)
looselyIdenticalIterable(iterable $expected, $canonicalizeKeys = false)
equalIterable(iterable $expected)
ClockTrait
Requirements
- PHP 7.1+
Usage
AssertionTrait
This trait exposes additional assertion methods to your test case.
<?php namespace Acme; use Kuria\PhpUnitExtras\Traits\AssertionTrait; use PHPUnit\Framework\TestCase; class ExampleTest extends TestCase { use AssertionTrait; function testFooBar() { $this->assertEqualIterable([1, 2, 3], new \ArrayObject([1, 2, 3])); } }
assertLooselyIdentical($expected, $actual, $canonicalizeKeys = false)
Assert that two values have the same type and value, but consider different instances of the same class identical as long as they have identical properties.
If $canonicalizeKeys = TRUE
, then array key order is ignored.
assertSameIterable(iterable $expected, $actual)
Assert that two iterables contain the same values and types in the same order
Types are compared the same way as with the ===
operator.
assertLooselyIdenticalIterable(iterable $expected, $actual, $canonicalizeKeys = false)
Assert that two iterables contain the same values and types in the same order, but consider different instances of the same class identical as long as they have identical properties.
If $canonicalizeKeys = TRUE
, then array key order is ignored.
assertEqualIterable(iterable $expected, $actual)
Assert that two iterables contain equal values in any order
Types are compared the same way as with the ==
operator.
looselyIdenticalTo($value, $canonicalizeKeys = false)
Create the IsLooselyIdentical
constraint. See assertLooselyIdentical()
.
identicalIterable(iterable $expected)
Create the IsIdenticalIterable
constraint. See assertSameIterable()
.
looselyIdenticalIterable(iterable $expected, $canonicalizeKeys = false)
Create the IsLooselyIdenticalIterable
constraint. See assertLooselyIdenticalIterable()
.
equalIterable(iterable $expected)
Create the IsEqualIterable
constraint. See assertEqualIterable()
.
ClockTrait
Mock current time in tests.
Only affects code that uses the kuria/clock component.
<?php namespace Acme; use Kuria\PhpUnitExtras\Traits\ClockTrait; use PHPUnit\Framework\TestCase; class ExampleTest extends TestCase { use ClockTrait; function testFooBar() { $this->atTime(1535904500, function () { // some code that uses Kuria/Clock/Clock }); } }