NAME

Mock::Data::Plugin - Optional base class for Plugins

DESCRIPTION

Mock::Data plugins do not need to inherit from this class. Mock::Data determines whether a package is a plugin by whether it has a method apply_mockdata_plugin. There is no behavior to inherit, either; a plugin may make any changes it likes to the Mock::Data instance it was given, and the tools to make these changes can be found in the Mock::Data::Util package.

The process of loading a plugin is exactly:

require $plugin_class;
$mock= $plugin_class->apply_mockdata_plugin($mock);

EXTENDING

If you do inherit from this class, you get the benefits of Exporter::Extensible, and @CARP_NOT linkage that makes Carp errors point to the code that called into Mock::Data rather than the code of Mock::Data that called your plugin's function.

package Mock::Data::Plugin::MyPlugin;
use Mock::Data::Plugin -exporter_setup => 1;
sub apply_mockdata_plugin {
  my $mock= shift;
  ...
}

The most common things a plugin might do in that method are:

Add Generators

Generators added by a plugin should include the scope of the package, like

$mock->add_generators( 'MyPlugin::something' => \&something );

This will automatically add that generator as both the name 'MyPlugin::soomething' and 'something' if the name was not already taken. By adding both, other modules can reference the namespaced name when they specifically need it, rather than whatever mix of generators are merged under the generic name or whichever module claimed it first.

Add Parent Classes

If Mock::Data were based on Moo, this would be possible by adding Roles to the object. A similar mechanism is provided by "mock_data_subclas" in Mock::Data::Util, which re-blesses the Mock::Data instance to include other parent classes. This allows you to directly add methods to Mock::Data. Be careful not to use nouns when adding methods, because generators use this same method namespace.

AUTHOR

Michael Conrad <mike@nrdvana.net>

VERSION

version 0.03

COPYRIGHT AND LICENSE

This software is copyright (c) 2021 by Michael Conrad.

This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.