blob: 16972a78164b9abb690b09d7b6fae2c872dd28fc (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
|
use strict;
use warnings;
use Test::More 0.88;
use Test::Warnings;
use overload ();
use lib 't/lib';
use OverloadingTests;
use Overloading::ClassWithOneRole;
ok(
Overloading::ClassWithOneRole->DOES('Overloading::RoleWithOverloads'),
'Overloading::ClassWithOneRole consumed Overloading::RoleWithOverloads',
);
OverloadingTests::test_overloading_for_package($_) for qw(
Overloading::RoleWithOverloads
Overloading::ClassWithOneRole
);
OverloadingTests::test_overloading_for_object(
'Overloading::ClassWithOneRole');
{
package Role1;
use Moose::Role;
use overload
q{""} => '_role1_stringify',
q{+} => '_role1_plus',
fallback => 0;
sub _role1_stringify {__PACKAGE__}
sub _role1_plus {42}
}
{
package Class1;
use Moose;
use overload
q{""} => '_class1_stringify',
fallback => 1;
with 'Role1';
sub _class1_stringify {__PACKAGE__}
}
is(
Class1->meta->get_overload_fallback_value,
1,
'fallback setting for class overrides setting in composed role'
);
is(
Class1->new . q{},
'Class1',
'overload method for class overrides method in composed role'
);
my $overload = Class1->meta->get_overloaded_operator(q{+});
is(
$overload->original_overload->associated_metaclass->name,
'Role1',
'+ overloading for Class1 originally came from Role1'
);
done_testing();
|