feat: add toHaveCamelCaseKeys

This commit is contained in:
Maurizio
2023-08-17 20:51:14 +02:00
parent 0b115230f9
commit 5d81cf0d4c
2 changed files with 53 additions and 0 deletions

View File

@ -784,4 +784,26 @@ final class Expectation
return $this;
}
/**
* Asserts that the given expectation is iterable and contains camelCase keys.
*
* @return self<TValue>
*/
public function toHaveCamelCaseKeys(string $message = ''): self
{
if (! is_iterable($this->value)) {
InvalidExpectationValue::expected('iterable');
}
foreach ($this->value as $k => $item) {
$this->and($k)->toBeCamelCase($message);
if (is_array($item)) {
$this->and($item)->toHaveCamelCaseKeys($message);
}
}
return $this;
}
}

View File

@ -0,0 +1,31 @@
<?php
use Pest\Exceptions\InvalidExpectationValue;
use PHPUnit\Framework\ExpectationFailedException;
$array = [
'camel' => true,
'camelCase' => [
'camel' => true,
'camelCase' => [
'camel' => true,
'camelCase' => true,
],
],
];
test('pass', function () use ($array) {
expect($array)->toHaveCamelCaseKeys();
});
test('failures', function () {
expect('not-an-array')->toHaveCamelCaseKeys();
})->throws(InvalidExpectationValue::class);
test('failures with message', function () use ($array) {
expect($array)->not->toHaveCamelCaseKeys('oh no!');
})->throws(ExpectationFailedException::class, 'oh no!');
test('not failures', function () use ($array) {
expect($array)->not->toHaveCamelCaseKeys();
})->throws(ExpectationFailedException::class);