2017 © Pedro Peláez
 

library glean

Generate fixture files from the output of any object method

image

shift31/glean

Generate fixture files from the output of any object method

  • Monday, December 29, 2014
  • by shift31
  • Repository
  • 1 Watchers
  • 1 Stars
  • 560 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 0 Forks
  • 0 Open issues
  • 3 Versions
  • 0 % Grown

The README.md

Glean

A fixture generator for Laravel, (*1)

This library provides a Laravel Artisan command which generates fixture files from the output of any object method. It leverages Laravel's Service Container and PHP's Reflection capabilities to instantiate classes and call the desired object methods with the specified arguments. Data may be saved in raw PHP, YAML, JSON, or XML., (*2)

Use Case

While there are quite a few test double libraries designed to ingest fixtures (which reflect model classes) for the purpose of database seeding, in complex applications, it may be desirable to have reusable fixture data from other types of classes (i.e. services). Glean provides an easy way to capture arbitrary/complex data structures. The fixture files generated by this tool are intended to be used with unit tests in any case where you might need to reuse expectation data (i.e. stubbing)., (*3)

Usage

  1. composer require shift31/glean
  2. Add Shift31\Glean\GleanServiceProvider to the 'providers' array in your app/config/app.php.

Help

Run php artisan help glean from the root of your Laravel project, (*4)

Examples

Imagine a Acme\Users\UsersService class with a getUserRoles($userId) method that returns an array of roles for a particular user:, (*5)

php artisan glean -a user_roles 'Acme\Users\UsersService' getUserRoles 12345, (*6)

By default, this will generate a PHP file in app/storage/fixtures called user_roles.php with the data gleaned from UsersService::getUserRoles., (*7)

With interfaces

Glean resolves classes using Laravel's Service Container, so feel free to specify an interface for the className argument., (*8)

In a test

$expectedUserRoles = include(__DIR__ . '/../app/storage/fixtures/user_roles.php');

Limitations

Method arguments can only be PHP scalar values or null. A possible workaround for this is to extend the GleanCommand class and create your own custom "gleaner.", (*9)

Todo

  • Build a fixture loader
  • Make it framework-agnostic?
  • Make writing custom gleaners easier?

The Versions

29/12 2014

dev-master

9999999-dev

Generate fixture files from the output of any object method

  Sources   Download

MIT

The Requires

 

29/12 2014

dev-develop

dev-develop

Generate fixture files from the output of any object method

  Sources   Download

MIT

The Requires

 

29/12 2014

1.0

1.0.0.0

Generate fixture files from the output of any object method

  Sources   Download

MIT

The Requires