NAME

Test::Builder2::CanLoad - load modules without effecting global variables

SYNOPSIS

package My::Thing;

use Test::Builder2::Mouse;
with "Test::Builder2::CanLoad";

My::Thing->load("Some::Module");

DESCRIPTION

Test::Builder2 must be careful to leave the global state of the test alone. This especially includes things like $@ and $!. Unfortunately, a lot of things change them. require is one of them.

This module provides load as a safe replacement for require which does not affect global variables (except the obvious ones like %INC).

load

$class->load($module);

This works like require to load a module, except it will not affect $! and $@ and not trip a $SIG{__DIE__} handler. Use it internally in your test module when you want to load a module.

It will die on failure if the $module fails to load in which case it will set $@. If you want to trap the failure, see Test::Builder2::CanTry.

SEE ALSO

Test::Builder2::CanTry