2017 © Pedro Peláez
 

library transmogrifier

Fixture library and commmand-line tools

image

linkorb/transmogrifier

Fixture library and commmand-line tools

  • Monday, March 2, 2015
  • by joostfaassen
  • Repository
  • 10 Watchers
  • 7 Stars
  • 99 Installations
  • PHP
  • 1 Dependents
  • 0 Suggesters
  • 2 Forks
  • 0 Open issues
  • 3 Versions
  • 0 % Grown

The README.md

Transmogrifier

, (*1)

Transmogrifier is a tool to help setup your database fixtures before running your tests., (*2)

You can use it in the following ways:, (*3)

  1. As a simple command-line utility (great for your build scripts and continuous integration)
  2. As a PHP library
  3. As a Behat extension, enabling Gherkin statements for automated BDD database testing

1. Command-line utility

You can use Transmogrifier as a command-line utility (stand-alone, or as part of your PHP project through composer)., (*4)

Standalone

  1. clone this git repository
  2. run composer install to install all dependencies
  3. run bin/transmogrifier --help for a list of available commands

Through composer, in your PHP project:

Open your composer.json file, and add this to the require section:, (*5)

"linkorb/transmogrifier": "dev-master"

You can now run vendor/bin/transmogrifier., (*6)

Adding transmogrifier commands to an existing Symfony/Console application

Add the following line to an existing Symfony/Console application in order to enable the Transmogrifier commands to it:, (*7)

$application->add(new \LinkORB\Transmogrifier\Command\DatasetApplyCommand());

Available commands

transmogrifier:datasetapply

The most interesting usage through the command-line is the transmogrifier:applydataset command., (*8)

You can use it like this:, (*9)

bin/transmogrifier transmogrifier:applydataset --dbname=test example/user.yml

This command will ensure that the dbname database contains the dataset specified in example/user.yml, (*10)

2. PHP Library

You can use the Transmogrifier very easily from within your own PHP projects as a library., (*11)

Installing the library through composer

pen your composer.json file, and add this to the require section:, (*12)

"linkorb/transmogrifier": "dev-master"

How to use the library

The 2 main classes are:, (*13)

  • Dataset: A class that can load datasets from files, and apply them to databases.
  • Database: A connection to a database, providing helpers for initializing the connection.

Here's an example usage:, (*14)

$db = new Database();
// Optionally initialize db parameters by file, cli options, or explicit values
$db->parseConf('/path/to/my/dbconf/test.conf');
$db->connect();

$dataset = new Dataset();
$dataset->loadDatasetFile('/path/to/my/dataset.yml');
$dataset->applyTo($db);

3. Behat Extension

There is a Transmogrifier Extension available for Behat!, (*15)

This allows you to use Transmogrifier directly from your Behat .feature files., (*16)

Check out the extension and it's documentation here:, (*17)

Supported file-formats

The dataset importer is based on phpunit/dbunit. It currently supports the following file-formats:, (*18)

  • YAML
  • Flat XML
  • XML
  • CSV

The Dataset loader guesses the format based on the file-extension., (*19)

Please refer to the example/ directory for datasets in these formats. The PHPUnit documentation contains further information about the loaders:, (*20)

Database .conf files

To simplify connecting to your database, Transmogrify can load conneciton settings from a simple .conf file., (*21)

An example file looks like this:, (*22)

name=test
server=127.0.0.1
username=susie
password=mrbun
driver=mysql

You can use these .conf files in all Transmogrifier modes: Command-line, Behat, or library. The connection is established through PDO, so all PDO supported databases will work., (*23)

Example datasets

The examples/ directory contains a few datasets you can use to try out Transmogrifier, see how it works, and copy as a starting-point for your own datasets., (*24)

Create the schema

The examples will ensure 2 users, 'Calvin' and 'Hobbes', are registed in your user table., (*25)

Before you can try these out, use the following SQL to generate the user table in your test database:, (*26)

CREATE TABLE user (id int, name varchar(16), email varchar(32), password varchar(32));

Brought to you by the LinkORB Engineering team


Check out our other projects at linkorb.com/engineering., (*27)

Btw, we're hiring!, (*28)

The Versions

02/03 2015

dev-master

9999999-dev http://www.github.com/linkorb/transmogrifier

Fixture library and commmand-line tools

  Sources   Download

The Requires

 

The Development Requires

database testing php fixture transmogrifier

02/03 2015

v1.1.0

1.1.0.0 http://www.github.com/linkorb/transmogrifier

Fixture library and commmand-line tools

  Sources   Download

The Requires

 

The Development Requires

database testing php fixture transmogrifier

26/02 2015

v1.0.0

1.0.0.0 http://www.github.com/linkorb/transmogrifier

Fixture library and commmand-line tools

  Sources   Download

The Requires

 

The Development Requires

database testing php fixture transmogrifier