1
0
Fork 0
mirror of https://github.com/archtechx/enums.git synced 2025-12-13 04:34:04 +00:00

Extend functionality to work with pure enums (#6)

* Extend functionality to work with pure enums

* Code review changes

Altered `::values()` to act like `::names()` for backed enums, code style fixes, general cleanups
This commit is contained in:
Samuel Levy 2022-03-24 06:42:35 +10:00 committed by GitHub
parent 20fa78c2b1
commit 0c87357a6e
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
9 changed files with 109 additions and 16 deletions

View file

@ -2,18 +2,33 @@
use ArchTech\Enums\Exceptions\UndefinedCaseError;
it('can be used as a static method', function () {
it('can be used as a static method with backed enums', function () {
expect(Status::PENDING())->toBe(0);
expect(Status::DONE())->toBe(1);
});
it('can be invoked as an instance', function () {
it('can be used as a static method with pure enums', function () {
expect(Role::ADMIN())->toBe('ADMIN');
expect(Role::GUEST())->toBe('GUEST');
});
it('can be invoked as an instance as a backed enum', function () {
$status = Status::PENDING;
expect($status())->toBe(0);
expect($status())->toBe($status->value);
});
it('throws an error when a nonexistent case is being used', function () {
it('can be invoked as an instance as a pure enum', function () {
$role = Role::ADMIN;
expect($role())->toBe('ADMIN');
});
it('throws an error when a nonexistent case is being used for backed enums', function () {
Status::INVALID();
})->expectException(UndefinedCaseError::class);
it('throws an error when a nonexistent case is being used for pure enums', function () {
Role::INVALID();
})->expectException(UndefinedCaseError::class);