NAME

Fennec::Assert::Core::Anonclass - Easily build a temporary class

DESCRIPTION

Sometimes you need a class that uses a module or implements some functionality in order to test another module. This provides a simple way to do that.

SYNOPSIS

use Fennec::Assert::Core::Anonclass;

my $anonclass = anonclass(
    use => $package || \@packages
    isa => $base || \@bases,
    accessors => \@accessor_names,
    subs => {
        name => sub { ... },
        ...
    },
);

# can() and isa() check against the anonymous class, not the
# Fennec::Assert::Core::Anonclass package.
ok( $anonclass->can( ... ));
ok( $anonclass->isa( ... ));

# You can instanciate your class
my $instance = $anonclass->new( ... );

# You can use all core testing functions as methods on your object
$instance->is_deeply( $want, $name );
$instance->can_ok( @list );
$instance->isa_ok( $base );

1;

SCOPE WARNING

The anonymous class will be destroyed when the $anonclass object and all instances fall out of scope. This will most likely never be a problem, but it is important to know.

CLASS METHODS

$instance = $anonclass->new( ... )

Create a new instance of the anonymous class. Will call any new() method provided during anonclass construction, otherwise will bless a hashref containing any params provided.

$subref = $anonclass->can( $name )

can() on an anonclass object will act against the blessed anonymous class, not against the anonclass package.

$bool = $anonclass->isa( $package )

isa() on an anonclass object will act against the blessed anonymous class, not against the anonclass package.

$package = $anonclass->class()

Return the full package name of the anonymous class. This will be a strange looking package name with seemingly random characters at the end, but it is valid until the anonclass object is destroyed.

MANUAL

Fennec::Manual::Quickstart

The quick guide to using Fennec.

Fennec::Manual::User

The extended guide to using Fennec.

Fennec::Manual::Developer

The guide to developing and extending Fennec.

Fennec::Manual

Documentation guide.

AUTHORS

Chad Granum exodist7@gmail.com

COPYRIGHT

Copyright (C) 2010 Chad Granum

Fennec is free software; Standard perl licence.

Fennec is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the license for more details.