NAME Data::Fake - Declaratively generate fake structured data for testing VERSION version 0.002 SYNOPSIS use Data::Fake qw/Core Names Text Dates/; my $hero_generator = fake_hash( { name => fake_name(), battlecry => fake_sentences(1), birthday => fake_past_date("%Y-%m-%d"), friends => fake_array( fake_int(2,4), fake_name() ), gender => fake_pick(qw/Male Female Other/), } ); my $hero = $hero_generator->(); ### example output ### # { # 'name' => 'Antonio Nicholas Preston' # 'battlecry' => 'Est ipsum corrupti quia voluptatibus.', # 'birthday' => '2004-04-21', # 'friends' => [ # 'Jaylin Lillianna Morgan', # 'Colin Noel Estes', # 'Justice Aron Hale', # 'Franco Zane Oneil' # ], # 'gender' => 'Male', # }; DESCRIPTION This module generates randomized, fake structured data using declarative syntax. "Data::Fake" is built on higher-order programming principles. It provides users with "factory" functions, which create "generator" functions for specific pieces of data. Wherever randomized, fake data is desired, a generator code reference is used as a placeholder for the desired output. Each time the top-level generator is run, nested generators are recursively run to turn placeholders into the desired randomized data. For example, the SYNOPSIS declares the desired form of a "hero" using the "fake_hash" factory function. The input is a hash-reference, with nested generators created as placeholders by the "fake_name", "fake_sentences", etc. factory functions: my $hero_generator = fake_hash( { name => fake_name(), battlecry => fake_sentences(1), birthday => fake_past_date("%Y-%m-%d"), friends => fake_array( fake_int(2,4), fake_name() ), gender => fake_pick(qw/Male Female Other/), } ); Every time $hero_generator is run, a new hash is generated based on the template and nested generators. USAGE Loading the right submodules Factory functions are exported by submodules, loosely grouped by topic: * Data::Fake::Core – general purpose generators: hashes, arrays, numeric values, string templates * Data::Fake::Company – company name, job title * Data::Fake::Dates – past and future dates * Data::Fake::Internet – domain names, email addresses * Data::Fake::Names – first and last names * Data::Fake::Text – characters, words, sentences, paragraphs Submodules can be loaded directly, to control exactly which functions are exported, or they can be loaded by the "Data::Fake" import function like so: use Data::Fake qw/Core Company Dates Names/; In this case, the listed submodules are loaded and all their functions are imported. Constructing the desired output Use the factory functions to construct a generator for your data. Start with the highest level structure using fake_hash or fake_array. Use other factory functions to create placeholders with specific data types. For example, a hash generator with placeholders for phone numbers: $hash_generator = fake_hash( { home => fake_digits("###-###-####"), work => fake_digits("###-###-####"), cell => fake_digits("###-###-####"), } ); Or build them up piece by piece. For example, an array of 100 of the previous hash references: $array_generator = fake_array( 100, $hash_generator ); Then generate the hundred instances, each with three fake phone numbers: $aoh = $array_generator->(); See Data::Fake::Examples for ideas for how to use and combine generators. Using custom generators Generators are just code references. You can use your own anywhere a Data::Fake generator could be used: $generator = fake_hash( favorite_color => \&my_favorite_color_picker, number_squared => sub { ( int(rand(10)) + 1 ) ** 2 }, ); You can (and probably should) write your own factory functions for anything complex or that you'll use more than once. You can use Data::Fake generators as part of these functions. use Data::Fake qw/Core/; sub fake_squared_int { my $max_int = shift; my $prng = fake_int( 1, $max_int ); return sub { $prng->() ** 2 }; } $generator = fake_hash( number_squared => fake_squared_int(10), ); Caveats and special cases Because many data structures are walked recursively looking for code-references to replace, circular references will cause an infinite loop. If you need a code references as part of your output data structure, you need to wrap it in a code reference. $generator = fake_hash( a_function => sub { \&some_function }, ); CONTRIBUTING If you have ideas for additional generator functions and think they would be sensible additions to the main distribution, please open a support ticket to discuss it. To be included in the main distribution, additional dependencies should add few, if any, additional dependencies. If you would like to release your own distributions in the "Data::Fake::*" namespace, please follow the conventions of the existing modules: * factory function names start with "fake_" * export all factory functions by default * allow code-references where you would allow a sizing constant SEE ALSO * Data::Faker – similar but object oriented; doesn't do structured data; always loads all plugins * Data::Random – generate several random types of data * Test::Sims – generator for libraries generating random data * Text::Lorem – just fake text SUPPORT Bugs / Feature Requests Please report any bugs or feature requests through the issue tracker at <https://github.com/dagolden/Data-Fake/issues>. You will be notified automatically of any progress on your issue. Source Code This is open source software. The code repository is available for public review and contribution under the terms of the license. <https://github.com/dagolden/Data-Fake> git clone https://github.com/dagolden/Data-Fake.git AUTHOR David Golden <dagolden@cpan.org> COPYRIGHT AND LICENSE This software is Copyright (c) 2015 by David Golden. This is free software, licensed under: The Apache License, Version 2.0, January 2004