NAME

Module::Mask::Deps - Mask modules not listed as dependencies

SYNOPSIS

Cause your test suite to blow up if you require a module not listed as a requirement in Build.PL:

perl Build.PL
PERL_HARNESS_SWITCHES=-MModule::Mask::Deps ./Build test

Or use directly in your testing code:

use Module::Mask::Deps;

BEGIN {
    # die if an unlisted module is used
    use_ok('My::Module');
}

# turn off masking (at compile time)
no Module::Mask::Deps;

# .. or at run-time
unimport Module::Mask::Deps;

Or use lexically:

require Module::Mask::Deps;

{
    my $mask = new Module::Mask::Deps;

    # Non-dependencies masked until end-of-scope.

    # ... 
}

require Arbitrary::Module;

DESCRIPTION

This module aims to help module developers keep track of their dependencies by only allowing modules to be loaded if they are in core or are listed as dependencies.

It uses Module::CoreList and either Module::Build or ExtUtils::MakeMaker to build its list of declared dependant modules.

Under Module::Build, the core module collection for the declared minimum perl version is used instead of the current core list.

METHODS

import

use Module::Mask::Deps;

import Module::Mask::Deps;

Causes a Module::Mask::Deps object to be created as $Module::Mask::Deps::Mask. This means that when called with use the mask object is is in scope at compile time and therefore should affect all subsequent use and require statements in the program.

unimport

unimport Module::Mask::Deps

no Module::Mask::Deps;

Stops the mask from working until import is called again. See clear_mask in Module::Mask

Note that no Module::Mask::Deps occurs at compile time and is not lexical int he same way as no strict and <no warnings> are.

new

$obj = $class->new()

Returns a new Module::Mask::Deps object. See Module::Mask for details about how modules are masked.

set_mask

$obj = $obj->set_mask()

Overloaded from Module::Mask to place the mask object after any relative paths at the beginning of @INC.

Typically, in a testing environment, local paths are unshifted into @INC by blib.pm, lib.pm or command-line switches. We don't want the mask to affect those paths.

Also, relative paths passed to require will not be masked.

# Will check @INC but won't be masked
require 't/my_script.pl';

# Won't even check @INC
require './t/my_script.pl';

get_deps

@deps = $class->get_deps()

Returns current dependencies as defined in either Build.PL or Makefile.PL. This is used internally by import and new, so there's no need to call it directly.

It returns all explicitly defined dependencies, plus all core dependencies.

Module::Build

If Build.PL exists, Module::Build->current is used to obtain a Module::Build object, and its requires and build_requires fields are used as dependencies.

This means that the dependencies can only be picked up if Build.PL has already been run.

If a particular perl version is specified as a dependency, then the list of core modules for that version of perl is used.

Note that modules in recommends are not included.

ExtUtils::MakeMaker

If Makefile.PL exists, dependencies are obtained by running perl Makefile.PL PREREQ_PRINT=1.

The current perl version ($]) is always used to determine core modules.

BUGS

Like Module::Mask, already loaded modules cannot be masked. This means that dependencies of Module::Mask::Deps can never be masked.

Notably, Module::Mask, Module::Util and Module::CoreList fall into this category.

To see a full list of modules for which this applies, run:

perl -le 'require Module::Mask::Deps; print for keys %INC'

DIAGNOSTICS

All error messages are prefixes by the name of the calling class, e.g.

Module::Mask::Deps: Couldn't find dependencies

The following fatal errors can occur:

  • Couldn't find dependencies

    The class couldn't find dependencies for the current distribution.

    If you are using Module::Build, ensure that you have run Build.PL and generated a Build script.

    If you are using ExtUtils::MakeMaker, ensure that the current directory contains your Makefile.PL script.

    Further information about the error might be provided on subsequent lines.

  • Couldn't find core modules for perl $version

    The given perl version couldn't be found in %Module::CoreList::version, you might need to upgrade Module::CoreList, or the perl version specified in Build.PL might be invalid. Otherwise, please report it as a bug.

SEE ALSO

Module::Mask, Module::CoreList

AUTHOR

Matt Lawrence <mattlaw@cpan.org>