From 728e904fa63ff6fe503e21eba35f1e8c04c57591 Mon Sep 17 00:00:00 2001 From: Jesse Luehrs Date: Tue, 5 Apr 2011 21:56:08 -0500 Subject: test for reloading subclasses --- t/data/moose-subclasses/after/Foo.pm | 13 +++++++ t/data/moose-subclasses/before/Foo.pm | 13 +++++++ t/data/moose-subclasses/before/Foo/Sub.pm | 15 ++++++++ t/moose-subclasses.t | 57 +++++++++++++++++++++++++++++++ 4 files changed, 98 insertions(+) create mode 100644 t/data/moose-subclasses/after/Foo.pm create mode 100644 t/data/moose-subclasses/before/Foo.pm create mode 100644 t/data/moose-subclasses/before/Foo/Sub.pm create mode 100644 t/moose-subclasses.t diff --git a/t/data/moose-subclasses/after/Foo.pm b/t/data/moose-subclasses/after/Foo.pm new file mode 100644 index 0000000..9e15e00 --- /dev/null +++ b/t/data/moose-subclasses/after/Foo.pm @@ -0,0 +1,13 @@ +package Foo; +use Moose; + +$::superclass_reloads++; + +has bar => (is => 'ro'); + +sub other_meth { } + +__PACKAGE__->meta->make_immutable; +no Moose; + +1; diff --git a/t/data/moose-subclasses/before/Foo.pm b/t/data/moose-subclasses/before/Foo.pm new file mode 100644 index 0000000..ea3f28b --- /dev/null +++ b/t/data/moose-subclasses/before/Foo.pm @@ -0,0 +1,13 @@ +package Foo; +use Moose; + +$::superclass_reloads++; + +has foo => (is => 'ro'); + +sub meth { } + +__PACKAGE__->meta->make_immutable; +no Moose; + +1; diff --git a/t/data/moose-subclasses/before/Foo/Sub.pm b/t/data/moose-subclasses/before/Foo/Sub.pm new file mode 100644 index 0000000..757d57c --- /dev/null +++ b/t/data/moose-subclasses/before/Foo/Sub.pm @@ -0,0 +1,15 @@ +package Foo::Sub; +use Moose; + +$::subclass_reloads++; + +extends 'Foo'; + +has baz => (is => 'ro'); + +sub meth { } + +__PACKAGE__->meta->make_immutable; +no Moose; + +1; diff --git a/t/moose-subclasses.t b/t/moose-subclasses.t new file mode 100644 index 0000000..bdbdedb --- /dev/null +++ b/t/moose-subclasses.t @@ -0,0 +1,57 @@ +#!/usr/bin/env perl +use strict; +use warnings; +use Test::More; +use Test::Requires 'Moose'; +use lib 't/lib'; +use Test::Class::Refresh; + +use Class::Refresh; + +my $dir = prepare_temp_dir_for('moose-subclasses'); +push @INC, $dir->dirname; + +our ($superclass_reloads, $subclass_reloads) = (0, 0); + +require Foo; +require Foo::Sub; + +Class::Refresh->refresh; + +is($superclass_reloads, 1, "superclass loaded"); +is($subclass_reloads, 1, "subclass loaded"); + +is_deeply([sort map { $_->name } Foo->meta->get_all_attributes], + ['foo'], + "correct starting attr list"); +can_ok('Foo', 'meth'); +ok(!Foo->can('other_meth'), "!Foo->can('other_meth')"); + +is_deeply([sort map { $_->name } Foo::Sub->meta->get_all_attributes], + ['baz', 'foo'], + "correct starting attr list"); +can_ok('Foo::Sub', 'meth'); +ok(!Foo::Sub->can('other_meth'), "!Foo::Sub->can('other_meth')"); + + +sleep 2; +update_temp_dir_for('moose-subclasses', $dir); + +Class::Refresh->refresh; + +is($superclass_reloads, 2, "superclass reloaded"); +is($subclass_reloads, 2, "subclass reloaded"); + +is_deeply([sort map { $_->name } Foo->meta->get_all_attributes], + ['bar'], + "correct new attr list"); +ok(!Foo->can('meth'), "!Foo->can('meth')"); +can_ok('Foo', 'other_meth'); + +is_deeply([sort map { $_->name } Foo::Sub->meta->get_all_attributes], + ['bar', 'baz'], + "correct new attr list"); +can_ok('Foo::Sub', 'meth'); +can_ok('Foo::Sub', 'other_meth'); + +done_testing; -- cgit v1.2.3