NAME

Test::Mimic::Library - Perl library supporting the Test::Mimic suite.

SYNOPSIS

use Test::Mimic::Library qw< encode >;

my $coded_val = encode( 'a string', 0 );

DESCRIPTION

Test::Mimic::Library provides a number of tools required in common by Test::Mimic, Test::Mimic::Recorder, and Test::Mimic::Generator. It also stores internally certain portions of the recording.

init_records()

Prepares the library for a new recording.

load_records($file_name)

Loads the portion of the recording specific to the library. Prepares for playback. Dies on any IO errors.

get_references()

Returns the reference table. This subroutine is for use by generated code files and should be considered private to the Test::Mimic suite.

write_records($file_name)

Write the portion of the recording specific to the library. Dies on any IO errors.

descend($dir_name)

Changes the current directory to $dir_name creating it if necessary. Dies on IO errors.

execute( $package, $subroutine_name, $behavior_hash, $args )

Emulates "$package::$subroutine_name" based on the information stored in $behavior_hash given $args. This subroutine should be considered private to the Test::Mimic suite.

gen_arg_key_by($preferences)

Accepts a hash reference describing which key generator to use given package and subroutine names. It should have the following structure:

{ 'key' => \&generic_sub, 'packages' => { 'Foo::Bar' => { 'key' => \%more_specific, 'subs' => { 'foo' => { 'key' => \&most_specific, } } } } }

Each of the subroutines should accept an array reference to the arguments and return a key suitable for use in a hash. Furthermore, they must be the same from run to run and MUST use get_id if they access the state of any particular argument.

gen_arg_key( $package, $subroutine, $args )

Accepts the name of the package, the name of the subroutine currently being emulated (typically with execute) and an array reference to the arguments. Returns a hash key based on those arguments using the requested key generator, or, if none was specified, the default key generator. The generator will be selected from most to least specific. The default is to encode the arguments by expanding references into values for 2 levels and then merely note the type. The ids returned by get_id are used instead if an argument is being micked. stringify is used to convert the above structure into a key.

get_id($value)

When constructing a key in your generator you can't wildly examine any old argument. This is because the arguments are actually tied values and you will probably consume their state. Call get_id first. If undef is returned you can proceed, but if you have an aggregate you must use get_id recursively. Otherwise you will be given a unique integer id. Incorporate this into your key instead and do not examine the state.

stringify_by($coderef)

Accepts a reference to a subroutine that takes a single argument and returns a stringified version of it. This subroutine will then be used for all stringification in the Test::Mimic suite. It is important that identical structures stringify to the same value from one run to another. Specifically, the order of hash keys must remain the same or the default key generator will break. If you really need to you could ignore this, but you would need a different key generator.

stringify($value)

Returns a stringified version of $value. The behavior of stringify can be set with stringify_by. If this was not done then a default stringifier will be used.

destringify_by($coderef)

Accepts a reference to a subroutine that is the inverse of the subroutine that stringify_by was given. All destringification done in the Test::Mimic suite will then use this subroutine.

destringify($stringified_value)

The inverse of stringify.

monitor_args_by($preferences)

Accepts a hash reference describing which argument monitor to use given package and subroutine names. It should have the following structure:

{ 'monitor_args' => \&generic_sub, 'packages' => { 'Foo::Bar' => { 'monitor_args' => \%more_specific, 'subs' => { 'foo' => { 'monitor_args' => \&most_specific, } } } } }

Each of the subroutines should accept an array reference to the arguments and return a scalar representing the history of the monitored arguments. Only those arguments the user considers important need be monitored.

monitor_args( $package, $subroutine, $arguments )

Accepts the package and name of the subroutine being called along with an array reference to its arguments. Monitors the arguments with the argument monitor requested with a call to monitor_args_by, or, if none was requested, the default. This is simply to monitor each argument that is not read only. Returns a scalar that should passed to play_args during the playback phase.

play_args_by($preferences)

Accepts a hash reference describing which argument player to use given package and subroutine names. It should have the following structure:

{ 'play_args' => \&generic_sub, 'packages' => { 'Foo::Bar' => { 'play_args' => \%more_specific, 'subs' => { 'foo' => { 'play_args' => \&most_specific, } } } } }

Each of the subroutines should accept an array reference to the arguments and the scalar returned by monitor_args. They should hijack the arguments as necessary and need not return anything.

play_args( $package, $subroutine, $arguments, $coded_arguments )

Accepts the package and name of the subroutine being called, an array reference to its arguments and the scalar returned by monitor_args. The arguments will be hijacked as specified with play_args_by, or, if no behavior was specified, the default -- which corresponds to the default monitor_args behavior.

monitor($value)

Accepts an arbitrary scalar, ensures that its value over time will be recorded (if it is a reference), and returns a scalar representing it. This return value will be suitable for stringification.

encode( $value, $volatility_depth )

Accepts an arbitrary scalar and the depth at which the dereferenced value may be subject to change (assuming that it is a reference). 0 is for the passed reference itself, 1, for example, may be the elements of an array reference, but not the array itself. Circular structures are not allowed unless they are contained entirely below the volatility depth. The history of the values above the volatility depth is not recorded. Returns a scalar representing the value. This will be suitable for stringification.

decode($coded_value)

Given the coded value returned by encode or monitor returns an approximation to the original. This method is somewhat smart -- the same coded value passed to decoded will return the exact same reference, i.e. refaddr( decode($coded_value) ) == refaddr( decode($coded_value) ). If history was recorded, as opposed to purely state, this information will be used when the user accesses the variable.

play($coded_value)

Given the coded value returned by decode returns an approximation to the original. Note that decode can handle anything returned by either monitor or encode, but play can handle only monitor returns, so it almost always makes sense to use decode.

EXPORT

None by default. The following are exported by request:

SCALAR_CONTEXT
LIST_CONTEXT
VOID_CONTEXT
STABLE
VOLATILE
NESTED
RETURN
EXCEPTION
ARBITRARY
CODE_E
SCALAR_E
ARRAY_E
HASH_E
ENCODE_TYPE
DATA
DATA_TYPE
HISTORY
CLASS

encode
decode
monitor
play
monitor_args
monitor_args_by
play_args
play_args_by
gen_arg_key
gen_arg_key_by
stringify
stringify_by
destringify
destringify_by
init_records
load_records
write_records
get_references
execute
descend
load_preferences

SEE ALSO

Other members of the Test::Mimic suite: Test::Mimic Test::Mimic::Recorder Test::Mimic::Generator

The latest source for the Test::Mimic suite is available at:

git://github.com/brendanr/Test--Mimic.git

AUTHOR

Concept by Tye McQueen.

Development by Brendan Roof, <brendanroof@gmail.com<gt>

COPYRIGHT AND LICENSE

Made possible by WhitePages Inc.

Copyright (C) 2009 by Brendan Roof

This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself, either Perl version 5.8.8 or, at your option, any later version of Perl 5 you may have available.