NAME
Fuckin::Lazy - Lazy way to produce test structures (Or a very bad idea)
WARNING
Warning! Using the module would fall squarely into BAD PRACTICE. You should predict what structures your code produces and put them into the test yourself. Simply sumping a result and testing against it is a bad idea. The only exception to this policy is when writing tests to make sure the output does not change from what it currently is.
SYNOPSIS
use Test::More;
use Fuckin::Lazy qw/LAZY/;
my $foo = { a => 1, b => 2 };
is_deeply($foo, Fuckin'Lazy($foo), "Foo");
is_deeply(
$foo,
LAZY($foo),
"Foo"
);
is_deeply($foo, LAZY($foo), "Foo");
done_testing;
The first time you run the above test it will alter the test file itself to produce this:
use Test::More;
use Fuckin::Lazy qw/LAZY/;
my $foo = { a => 1, b => 2 };
is_deeply($foo, {"a" => 1,"b" => 2}, "Foo");
is_deeply(
$foo,
{"a" => 1,"b" => 2},
"Foo"
);
is_deeply($foo, {"a" => 1,"b" => 2}, "Foo");
done_testing;
DESCRIPTION
A poor implementation of a bad idea!
EXPORTS
- LAZY($var)
-
This function will turn the argument into the code for a perl data structure and replace itself with the code. This is done when the file is run. The data structure passed in is returned unchanged allowing the test to pass.
MAGIC
- Fuckin'Lazy($var)
-
Same as the LAZY() export, except it is the Fuckin::Lazy function, not exported. The
'
can be used in place of::
due to legacy perl support.
IDEA
Thanks to Joshua Keroes for proposing the idea.
COPYRIGHT
Copyright 2014 Chad Granum <exodist7@gmail.com>.
This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.
See http://www.perl.com/perl/misc/Artistic.html