Skip tests for strict constructor on Moose
[gitmo/Mouse.git] / t / 001_mouse / 054-anon-leak.t
CommitLineData
113a9693 1#!perl
2# This is based on Class-MOP/t/312_anon_class_leak.t
3use strict;
4use warnings;
5use Test::More;
6
7BEGIN {
8 eval "use Test::LeakTrace 0.10;";
9 plan skip_all => "Test::LeakTrace 0.10 is required for this test" if $@;
10}
11
12plan tests => 6;
13
14use Mouse ();
15{
16 package MyRole;
17 use Mouse::Role;
18
19 sub my_role_method{ }
20}
21
22# 5.10.0 has a bug on weaken($hash_ref) which leaks an AV.
23my $expected = ( $] == 5.010_000 ? 1 : 0 );
24
25leaks_cmp_ok {
26 Mouse::Meta::Class->create_anon_class();
27} '<=', $expected, 'create_anon_class()';
28
29leaks_cmp_ok {
30 Mouse::Meta::Class->create_anon_class(superclasses => ['Mouse::Meta::Class']);
31} '<=', $expected, 'create_anon_class() with superclasses';
32
33leaks_cmp_ok {
34 Mouse::Meta::Class->create_anon_class(attributes => [
35 Mouse::Meta::Attribute->new('foo', is => 'bare'),
36 ]);
37} '<=', $expected, 'create_anon_class() with attributes';
38
39leaks_cmp_ok {
40 Mouse::Meta::Class->create_anon_class(roles => [qw(MyRole)]);
41} '<=', $expected, 'create_anon_class() with roles';
42
43
44leaks_cmp_ok {
45 Mouse::Meta::Role->create_anon_role();
46} '<=', $expected, 'create_anon_role()';
47
48if($] < 5.010){
49 $expected = 2; # in MRO::Compat::get_linear_isa, maybe harmless
50}
51leaks_cmp_ok {
52 Mouse::Meta::Role->create_anon_role(roles => [qw(MyRole)]);
53} '<=', $expected, 'create_anon_role() with roles';
54