Aion-Enum
view release on metacpan or search on metacpan
t/aion/enum.t view on Meta::CPAN
#
# Aion::Enum - пеÑеÑиÑÐ»ÐµÐ½Ð¸Ñ Ð² ÑÑиле ÐÐÐ, когда каждое пеÑеÑÑление ÑвлÑеÑÑÑ Ð¾Ð±ÑекÑом
#
# # VERSION
#
# 0.0.2
#
# # SYNOPSIS
#
# Файл lib/StatusEnum.pm:
#@> lib/StatusEnum.pm
#>> package StatusEnum;
#>>
#>> use Aion::Enum;
#>>
#>> # Active status
#>> case active => 1, 'Active';
#>>
#>> # Passive status
#>> case passive => 2, 'Passive';
#>>
#>> 1;
#@< EOF
#
subtest 'SYNOPSIS' => sub {
use StatusEnum;
::is scalar do {&StatusEnum::active->does('Aion::Enum')}, "1", '&StatusEnum::active->does(\'Aion::Enum\') # => 1';
::is scalar do {StatusEnum->active->name}, "active", 'StatusEnum->active->name # => active';
::is scalar do {StatusEnum->passive->value}, "2", 'StatusEnum->passive->value # => 2';
::is scalar do {StatusEnum->active->alias}, "Active status", 'StatusEnum->active->alias # => Active status';
::is scalar do {StatusEnum->passive->stash}, "Passive", 'StatusEnum->passive->stash # => Passive';
::is_deeply scalar do {[ StatusEnum->cases ]}, scalar do {[StatusEnum->active, StatusEnum->passive]}, '[ StatusEnum->cases ] # --> [StatusEnum->active, StatusEnum->passive]';
::is_deeply scalar do {[ StatusEnum->names ]}, scalar do {[qw/active passive/]}, '[ StatusEnum->names ] # --> [qw/active passive/]';
::is_deeply scalar do {[ StatusEnum->values ]}, scalar do {[qw/1 2/]}, '[ StatusEnum->values ] # --> [qw/1 2/]';
::is_deeply scalar do {[ StatusEnum->aliases ]}, scalar do {['Active status', 'Passive status']}, '[ StatusEnum->aliases ] # --> [\'Active status\', \'Passive status\']';
::is_deeply scalar do {[ StatusEnum->stashes ]}, scalar do {[qw/Active Passive/]}, '[ StatusEnum->stashes ] # --> [qw/Active Passive/]';
#
# # DESCRIPTION
#
# `Aion::Enum` позволÑÐµÑ ÑоздаваÑÑ Ð¿ÐµÑеÑиÑлениÑ-обÑекÑÑ. ÐаннÑе пеÑеÑиÑÐ»ÐµÐ½Ð¸Ñ Ð¼Ð¾Ð³ÑÑ ÑодеÑжаÑÑ Ð´Ð¾Ð¿Ð¾Ð»Ð½Ð¸ÑелÑнÑе меÑÐ¾Ð´Ñ Ð¸ ÑвойÑÑва. РниÑ
можно до...
#
# Ðажной оÑобенноÑÑÑÑ ÑвлÑеÑÑÑ ÑоÑ
Ñанение поÑÑдка пеÑеÑиÑлениÑ.
#
# `Aion::Enum` подобен пеÑеÑиÑлениÑм из php8, но Ð¸Ð¼ÐµÐµÑ Ð´Ð¾Ð¿Ð¾Ð»Ð½Ð¸ÑелÑнÑе ÑвойÑÑва `alias` и `stash`.
#
# # SUBROUTINES
#
# ## case ($name, [$value, [$stash]])
#
# СоздаÑÑ Ð¿ÐµÑеÑиÑление: его конÑÑанÑÑ.
#
::done_testing; }; subtest 'case ($name, [$value, [$stash]])' => sub {
package OrderEnum {
use Aion::Enum;
case 'first';
case second => 2;
case other => 3, {data => 123};
}
::is scalar do {&OrderEnum::first->name}, "first", '&OrderEnum::first->name # => first';
::is scalar do {&OrderEnum::first->value}, scalar do{undef}, '&OrderEnum::first->value # -> undef';
::is scalar do {&OrderEnum::first->stash}, scalar do{undef}, '&OrderEnum::first->stash # -> undef';
::is scalar do {&OrderEnum::second->name}, "second", '&OrderEnum::second->name # => second';
::is scalar do {&OrderEnum::second->value}, scalar do{2}, '&OrderEnum::second->value # -> 2';
::is scalar do {&OrderEnum::second->stash}, scalar do{undef}, '&OrderEnum::second->stash # -> undef';
::is scalar do {&OrderEnum::other->name}, "other", '&OrderEnum::other->name # => other';
::is scalar do {&OrderEnum::other->value}, scalar do{3}, '&OrderEnum::other->value # -> 3';
::is_deeply scalar do {&OrderEnum::other->stash}, scalar do {{data => 123}}, '&OrderEnum::other->stash # --> {data => 123}';
#
# ## issa ($nameisa, [$valueisa], [$stashisa], [$aliasisa])
#
# УказÑÐ²Ð°ÐµÑ Ñип (isa) знаÑений и дополнений.
#
# ÐÑ Ð½Ð°Ð·Ð²Ð°Ð½Ð¸Ðµ â оÑÑÑлка к богине ÐÑÑе из повеÑÑи «Ðод лÑнами ÐаÑÑа» ÐеÑÑоÑза.
#
::done_testing; }; subtest 'issa ($nameisa, [$valueisa], [$stashisa], [$aliasisa])' => sub {
eval {
package StringEnum;
use Aion::Enum;
issa Str => Int => Undef => Undef;
case active => "Active";
};
::like scalar do {$@}, qr{active value must have the type Int. The it is 'Active'}, '$@ # ~> active value must have the type Int. The it is \'Active\'';
eval {
package StringEnum;
use Aion::Enum;
issa Str => Str => Int;
case active => "Active", "Passive";
};
::like scalar do {$@}, qr{active stash must have the type Int. The it is 'Passive'}, '$@ # ~> active stash must have the type Int. The it is \'Passive\'';
#
# Файл lib/StringEnum.pm:
#@> lib/StringEnum.pm
#>> package StringEnum;
#>> use Aion::Enum;
#>>
#>> issa Str => Undef => Undef => StrMatch[qr/^[A-Z]/];
#>>
#>> # pushkin
#>> case active => ;
#>>
#>> 1;
#@< EOF
#
::cmp_ok do { eval {require StringEnum}; $@ }, '=~', '^' . quotemeta 'active alias must have the type StrMatch[qr/^[A-Z]/]. The it is \'pushkin\'!', 'require StringEnum # @-> active alias must have the type StrMatch[qr/^[A-Z]/]. The it is \'pushkin\'...
#
# # CLASS METHODS
#
# ## cases ($cls)
#
# СпиÑок пеÑеÑиÑлений.
#
::done_testing; }; subtest 'cases ($cls)' => sub {
::is_deeply scalar do {[ OrderEnum->cases ]}, scalar do {[OrderEnum->first, OrderEnum->second, OrderEnum->other]}, '[ OrderEnum->cases ] # --> [OrderEnum->first, OrderEnum->second, OrderEnum->other]';
#
# ## names ($cls)
#
# Ðмена пеÑеÑиÑлений.
#
::done_testing; }; subtest 'names ($cls)' => sub {
::is_deeply scalar do {[ OrderEnum->names ]}, scalar do {[qw/first second other/]}, '[ OrderEnum->names ] # --> [qw/first second other/]';
#
# ## values ($cls)
#
# ÐнаÑÐµÐ½Ð¸Ñ Ð¿ÐµÑеÑиÑлений.
#
::done_testing; }; subtest 'values ($cls)' => sub {
::is_deeply scalar do {[ OrderEnum->values ]}, scalar do {[undef, 2, 3]}, '[ OrderEnum->values ] # --> [undef, 2, 3]';
#
# ## stashes ($cls)
#
# ÐÐ¾Ð¿Ð¾Ð»Ð½ÐµÐ½Ð¸Ñ Ð¿ÐµÑеÑиÑлений.
#
::done_testing; }; subtest 'stashes ($cls)' => sub {
::is_deeply scalar do {[ OrderEnum->stashes ]}, scalar do {[undef, undef, {data => 123}]}, '[ OrderEnum->stashes ] # --> [undef, undef, {data => 123}]';
#
# ## aliases ($cls)
#
# ÐÑÐµÐ²Ð´Ð¾Ð½Ð¸Ð¼Ñ Ð¿ÐµÑеÑиÑлений.
#
# Файл lib/AuthorEnum.pm:
#@> lib/AuthorEnum.pm
#>> package AuthorEnum;
#>>
#>> use Aion::Enum;
#>>
#>> # Pushkin Aleksandr Sergeevich
#>> case pushkin =>;
#>>
#>> # Yacheykin Uriy
#>> case yacheykin =>;
#>>
#>> case nouname =>;
#>>
#>> 1;
#@< EOF
#
::done_testing; }; subtest 'aliases ($cls)' => sub {
require AuthorEnum;
::is_deeply scalar do {[ AuthorEnum->aliases ]}, scalar do {['Pushkin Aleksandr Sergeevich', 'Yacheykin Uriy', undef]}, '[ AuthorEnum->aliases ] # --> [\'Pushkin Aleksandr Sergeevich\', \'Yacheykin Uriy\', undef]';
#
# ## fromName ($cls, $name)
#
# ÐолÑÑиÑÑ case по имени c иÑклÑÑением.
#
::done_testing; }; subtest 'fromName ($cls, $name)' => sub {
::is scalar do {OrderEnum->fromName('first')}, scalar do{OrderEnum->first}, 'OrderEnum->fromName(\'first\') # -> OrderEnum->first';
::like scalar do {eval { OrderEnum->fromName('not_exists') }; $@}, qr{Did not case with name `not_exists`\!}, 'eval { OrderEnum->fromName(\'not_exists\') }; $@ # ~> Did not case with name `not_exists`!';
#
# ## tryFromName ($cls, $name)
#
# ÐолÑÑиÑÑ case по имени.
#
::done_testing; }; subtest 'tryFromName ($cls, $name)' => sub {
::is scalar do {OrderEnum->tryFromName('first')}, scalar do{OrderEnum->first}, 'OrderEnum->tryFromName(\'first\') # -> OrderEnum->first';
::is scalar do {OrderEnum->tryFromName('not_exists')}, scalar do{undef}, 'OrderEnum->tryFromName(\'not_exists\') # -> undef';
( run in 1.863 second using v1.01-cache-2.11-cpan-f56aa216473 )