mirror of
https://github.com/archtechx/enums.git
synced 2025-12-12 14:14:05 +00:00
Comparable enum (#20)
* feat: comparable enum * test: comparable enum * ci: php-cs-fixer in repository scope * chore: add `Comparable` usage in README * ci: globally use `php-cs-fixer` * improve Comparable logic * test more PHP versions in CI * update ci job name * remove class name quoting in exceptions to match PHP behavior * migrate pest config * add comment to test --------- Co-authored-by: Samuel Štancl <samuel@archte.ch> Co-authored-by: Samuel Štancl <samuel.stancl@gmail.com>
This commit is contained in:
parent
fb521d2dcb
commit
f0ea4c36c8
9 changed files with 188 additions and 21 deletions
|
|
@ -4,9 +4,12 @@ it('does not override the default BackedEnum from method')
|
|||
->expect(Status::from(0))
|
||||
->toBe(Status::PENDING);
|
||||
|
||||
// Shortened exception message due to inconsistency between PHP 8.1 and 8.2+
|
||||
// 8.1: 2 is not a valid backing value for enum "Status"
|
||||
// 8.2+: 2 is not a valid backing value for enum Status
|
||||
it('does not override the default BackedEnum from method with errors', function () {
|
||||
Status::from(2);
|
||||
})->throws(ValueError::class, '2 is not a valid backing value for enum "Status"');
|
||||
})->throws(ValueError::class, '2 is not a valid backing value for enum');
|
||||
|
||||
it('does not override the default BackedEnum tryFrom method')
|
||||
->expect(Status::tryFrom(1))
|
||||
|
|
@ -22,7 +25,7 @@ it('can select a case by name with from() for pure enums')
|
|||
|
||||
it('throws a value error when selecting a non-existent case with from() for pure enums', function () {
|
||||
Role::from('NOBODY');
|
||||
})->throws(ValueError::class, '"NOBODY" is not a valid name for enum "Role"');
|
||||
})->throws(ValueError::class, '"NOBODY" is not a valid name for enum Role');
|
||||
|
||||
it('can select a case by name with tryFrom() for pure enums')
|
||||
->expect(Role::tryFrom('GUEST'))
|
||||
|
|
@ -38,7 +41,7 @@ it('can select a case by name with fromName() for pure enums')
|
|||
|
||||
it('throws a value error when selecting a non-existent case by name with fromName() for pure enums', function () {
|
||||
Role::fromName('NOBODY');
|
||||
})->throws(ValueError::class, '"NOBODY" is not a valid name for enum "Role"');
|
||||
})->throws(ValueError::class, '"NOBODY" is not a valid name for enum Role');
|
||||
|
||||
it('can select a case by name with tryFromName() for pure enums')
|
||||
->expect(Role::tryFromName('GUEST'))
|
||||
|
|
@ -54,7 +57,7 @@ it('can select a case by name with fromName() for backed enums')
|
|||
|
||||
it('throws a value error when selecting a non-existent case by name with fromName() for backed enums', function () {
|
||||
Status::fromName('NOTHING');
|
||||
})->throws(ValueError::class, '"NOTHING" is not a valid name for enum "Status"');
|
||||
})->throws(ValueError::class, '"NOTHING" is not a valid name for enum Status');
|
||||
|
||||
it('can select a case by name with tryFromName() for backed enums')
|
||||
->expect(Status::tryFromName('DONE'))
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue