Group
Extension

Moose/t/cmop/class_errors_and_edge_cases.t

use strict;
use warnings;

use Test::More;
use Test::Fatal;

use Class::MOP;

{
    isnt( exception {
        Class::MOP::Class->initialize();
    }, undef, '... initialize requires a name parameter' );

    isnt( exception {
        Class::MOP::Class->initialize('');
    }, undef, '... initialize requires a name valid parameter' );

    isnt( exception {
        Class::MOP::Class->initialize(bless {} => 'Foo');
    }, undef, '... initialize requires an unblessed parameter' );
}

{
    isnt( exception {
        Class::MOP::Class->_construct_class_instance();
    }, undef, '... _construct_class_instance requires an :package parameter' );

    isnt( exception {
        Class::MOP::Class->_construct_class_instance(':package' => undef);
    }, undef, '... _construct_class_instance requires a defined :package parameter' );

    isnt( exception {
        Class::MOP::Class->_construct_class_instance(':package' => '');
    }, undef, '... _construct_class_instance requires a valid :package parameter' );
}


{
    isnt( exception {
        Class::MOP::Class->create();
    }, undef, '... create requires an package_name parameter' );

    isnt( exception {
        Class::MOP::Class->create(undef);
    }, undef, '... create requires a defined package_name parameter' );

    isnt( exception {
        Class::MOP::Class->create('');
    }, undef, '... create requires a valid package_name parameter' );

    isnt( exception {
        Class::MOP::Class->create('+++');
    }, qr/^\+\+\+ is not a module name/, '... create requires a valid package_name parameter' );
}

{
    isnt( exception {
        Class::MOP::Class->clone_object(1);
    }, undef, '... can only clone instances' );
}

{
    isnt( exception {
        Class::MOP::Class->add_method();
    }, undef, '... add_method dies as expected' );

    isnt( exception {
        Class::MOP::Class->add_method('');
    }, undef, '... add_method dies as expected' );

    isnt( exception {
        Class::MOP::Class->add_method('foo' => 'foo');
    }, undef, '... add_method dies as expected' );

    isnt( exception {
        Class::MOP::Class->add_method('foo' => []);
    }, undef, '... add_method dies as expected' );
}

{
    isnt( exception {
        Class::MOP::Class->has_method();
    }, undef, '... has_method dies as expected' );

    isnt( exception {
        Class::MOP::Class->has_method('');
    }, undef, '... has_method dies as expected' );
}

{
    isnt( exception {
        Class::MOP::Class->get_method();
    }, undef, '... get_method dies as expected' );

    isnt( exception {
        Class::MOP::Class->get_method('');
    }, undef, '... get_method dies as expected' );
}

{
    isnt( exception {
        Class::MOP::Class->remove_method();
    }, undef, '... remove_method dies as expected' );

    isnt( exception {
        Class::MOP::Class->remove_method('');
    }, undef, '... remove_method dies as expected' );
}

{
    isnt( exception {
        Class::MOP::Class->find_all_methods_by_name();
    }, undef, '... find_all_methods_by_name dies as expected' );

    isnt( exception {
        Class::MOP::Class->find_all_methods_by_name('');
    }, undef, '... find_all_methods_by_name dies as expected' );
}

{
    isnt( exception {
        Class::MOP::Class->add_attribute(bless {} => 'Foo');
    }, undef, '... add_attribute dies as expected' );
}


{
    isnt( exception {
        Class::MOP::Class->has_attribute();
    }, undef, '... has_attribute dies as expected' );

    isnt( exception {
        Class::MOP::Class->has_attribute('');
    }, undef, '... has_attribute dies as expected' );
}

{
    isnt( exception {
        Class::MOP::Class->get_attribute();
    }, undef, '... get_attribute dies as expected' );

    isnt( exception {
        Class::MOP::Class->get_attribute('');
    }, undef, '... get_attribute dies as expected' );
}

{
    isnt( exception {
        Class::MOP::Class->remove_attribute();
    }, undef, '... remove_attribute dies as expected' );

    isnt( exception {
        Class::MOP::Class->remove_attribute('');
    }, undef, '... remove_attribute dies as expected' );
}

{
    isnt( exception {
        Class::MOP::Class->add_package_symbol();
    }, undef, '... add_package_symbol dies as expected' );

    isnt( exception {
        Class::MOP::Class->add_package_symbol('');
    }, undef, '... add_package_symbol dies as expected' );

    isnt( exception {
        Class::MOP::Class->add_package_symbol('foo');
    }, undef, '... add_package_symbol dies as expected' );

    isnt( exception {
        Class::MOP::Class->add_package_symbol('&foo');
    }, undef, '... add_package_symbol dies as expected' );

#    throws_ok {
#        Class::MOP::Class->meta->add_package_symbol('@-');
#    } qr/^Could not create package variable \(\@\-\) because/,
#      '... add_package_symbol dies as expected';
}

{
    isnt( exception {
        Class::MOP::Class->has_package_symbol();
    }, undef, '... has_package_symbol dies as expected' );

    isnt( exception {
        Class::MOP::Class->has_package_symbol('');
    }, undef, '... has_package_symbol dies as expected' );

    isnt( exception {
        Class::MOP::Class->has_package_symbol('foo');
    }, undef, '... has_package_symbol dies as expected' );
}

{
    isnt( exception {
        Class::MOP::Class->get_package_symbol();
    }, undef, '... get_package_symbol dies as expected' );

    isnt( exception {
        Class::MOP::Class->get_package_symbol('');
    }, undef, '... get_package_symbol dies as expected' );

    isnt( exception {
        Class::MOP::Class->get_package_symbol('foo');
    }, undef, '... get_package_symbol dies as expected' );
}

{
    isnt( exception {
        Class::MOP::Class->remove_package_symbol();
    }, undef, '... remove_package_symbol dies as expected' );

    isnt( exception {
        Class::MOP::Class->remove_package_symbol('');
    }, undef, '... remove_package_symbol dies as expected' );

    isnt( exception {
        Class::MOP::Class->remove_package_symbol('foo');
    }, undef, '... remove_package_symbol dies as expected' );
}

done_testing;


Powered by Groonga
Maintained by Kenichi Ishigaki <ishigaki@cpan.org>. If you find anything, submit it on GitHub.