summaryrefslogtreecommitdiff
path: root/t/roles/overloading_to_class.t
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();