Provided by: libtest-dbix-class-perl_0.52-2_all bug

NAME

       Test::DBIx::Class - Easier test cases for your DBIx::Class applications

SYNOPSIS

       The following is example usage for this module.  Assume you create a standard Perl testing script, such
       as "MyApp/t/schema/01-basic.t" which is run from the shell like "prove -l t/schema/01-basic.t" or during
       "make test".  That test script could contain:

           use Test::More;

           use strict;
           use warnings;

           use Test::DBIx::Class {
               schema_class => 'MyApp::Schema',
               connect_info => ['dbi:SQLite:dbname=:memory:','',''],
               connect_opts => { name_sep => '.', quote_char => '`', },
               fixture_class => '::Populate',
           }, 'Person', 'Person::Employee' => {-as => 'Employee'}, 'Job', 'Phone';

           ## Your testing code below ##

           ## Your testing code above ##

           done_testing;

       Yes, it looks like a lot of boilerplate, but sensible defaults are in place (the above code example shows
       most of the existing defaults) and configuration data can be loaded from a central file.  So, assuming
       you put all of your test configuration in the standard place, your 'real life' example is going to look
       closer to:

           use Test::More;

           use strict;
           use warnings;
           use Test::DBIx::Class qw(:resultsets);

           ## Your testing code below ##
           ## Your testing code above ##

           done_testing;

       Then, assuming the existence of a DBIx::Class::Schema subclass called, "MyApp::Schema" and some
       DBIx::Class::ResultSources named like "Person", "Person::Employee", "Job" and "Phone", will automatically
       deploy a testing schema in the given database / storage (or auto deploy to an in-memory based DBD::SQLite
       database), install fixtures and let you run some test cases, such as:

           ## Your testing code below ##

           fixtures_ok 'basic'
             => 'installed the basic fixtures from configuration files';

           fixtures_ok [
               Job => [
                   [qw/name description/],
                   [Programmer => 'She who writes the code'],
                   ['Movie Star' => 'Knows nothing about the code'],
               ],
           ], 'Installed some custom fixtures via the Populate fixture class',

           ok my $john = Person->find({email=>'jjnapiork@cpan.org'})
             => 'John has entered the building!';

           is_fields $john, {
               name => 'John Napiorkowski',
               email => 'jjnapiork@cpan.org',
               age => 40,
           }, 'John has the expected fields';

           is_fields ['job_title'], $john->jobs, [
               {job_title => 'programmer'},
               {job_title => 'administrator'},
           ],
           is_fields 'job_title', $john->jobs,
               [qw/programmer administrator/],
               'Same test as above, just different compare format;

           is_fields [qw/job_title salary/], $john->jobs, [
               ['programmer', 100000],
               ['administrator, 120000],
           ], 'Got expected fields from $john->jobs';

           is_fields [qw/name age/], $john, ['John Napiorkowski', 40],
             => 'John has expected name and age';

           is_fields_multi 'name', [
               $john, ['John Napiorkowski'],
               $vanessa, ['Vanessa Li'],
               $vincent, ['Vincent Zhou'],
           ] => 'All names as expected';

           is_fields 'fullname',
               ResultSet('Country')->find('USA'),
               'United States of America',
               'Found the USA';

           is_deeply [sort Schema->sources], [qw/
               Person Person::Employee Job Country Phone
           /], 'Found all expected sources in the schema';

           fixtures_ok my $first_album = sub {
               my $schema = shift @_;
               my $cd_rs = $schema->resultset('CD');
               return $cd_rs->create({
                   name => 'My First Album',
                   track_rs => [
                       {position=>1, title=>'the first song'},
                       {position=>2, title=>'yet another song'},
                   ],
                   cd_artist_rs=> [
                       {person_artist=>{person => $vanessa}},
                       {person_artist=>{person => $john}},
                   ],
               });
           }, 'You can even use a code reference for custom fixtures';

           ## Your testing code above ##

       Please see the test cases for more examples.

DESCRIPTION

       The goal of this distribution is to make it easier to write test cases for your DBIx::Class based
       applications.  It does this in three ways.  First, it trys to make it easy to deploy your Schema.  This
       can be to your dedicated testing database, or a simple SQLite database.  This allows you to run tests
       without interfering with your development work and having to stop and set up a testing database instance.

       Second, we allow you to load test fixtures via several different tools.  Last we create some helper
       functions in your test script so that you can reduce repeated or boilerplate code.

       Overall, we attempt to reduce the amount of code you have to write before you can begin writing tests.

IMPORTED METHODS

       The following methods are automatically imported when you use this module.

   Schema
       You probably won't need this directly in your tests unless you have some application logic methods in it.

   ResultSet ($source, ?{%search}, ?{%conditions})
       Although you can import your sources as local keywords, sometimes you might need to get a particular
       resultset when you don't wish to import it globally.  Use like

           ok ResultSet('Job'), "Yeah, some jobs in the database";
           ok ResultSet( Job => {hourly_pay=>{'>'=>100}}), "Good paying jobs available!";

       Since this returns a normal DBIx::Class::ResultSet, you can just call the normal methods against it.

           ok ResultSet('Job')->search({hourly_pay=>{'>'=>100}}), "Good paying jobs available!";

       This is the same as the test above.

       ResultSet can also be called with a "$source, [\%search, \%condition]" signature.

   fixtures_ok
       This is used to install and verify installation of fixtures, either inlined, from a fixture set in a
       file, or through a custom sub reference.  Accept three argument styles:

       coderef
           Given  a code reference, execute it against the currently defined schema.  This is used when you need
           a lot of control over installing your fixtures.  Example:

               fixtures_ok sub {
                   my $schema = shift @_;
                   my $cd_rs = $schema->resultset('CD');
                   return $cd_rs->create({
                       name => 'My First Album',
                       track_rs => [
                           {position=>1, title=>'the first song'},
                           {position=>2, title=>'yet another song'},
                       ],
                       cd_artist_rs=> [
                           {person_artist=>{person => $vanessa}},
                           {person_artist=>{person => $john}},
                       ],
                   });

               }, 'Installed fixtures';

           The above gets executed at runtime and if there is an error it is trapped, reported and we move on to
           the next test.

       arrayref
           Given an array reference, attempt to process it via  the  default  fixtures  loader  or  through  the
           specified loader.

               fixtures_ok [
                   Person => [
                       ['name', 'age', 'email'],
                       ['John', 40, 'john@nowehere.com'],
                       ['Vincent', 15, 'vincent@home.com'],
                       ['Vanessa', 35, 'vanessa@school.com'],
                   ],
               ], 'Installed fixtures';

           This  is a good option to use while you are building up your fixture sets or when your sets are going
           to be small and not reused across lots of tests.  This will get you rolling  without  messing  around
           with configuration files.

       fixture set name
           Given a fixture name, or array reference of names, install the fixtures.

               fixtures_ok 'core';
               fixtures_ok [qw/core extra/];

           Fixtures are installed in the order specified.

       All different types can be mixed and matched in a given test file.

   is_result ($result, ?$result)
       Quick  test  to  make  sure  $result does inherit from DBIx::Class or that it inherits from a subclass of
       DBIx::Class.

   is_resultset ($resultset, ?$resultset)
       Quick test to make sure $resultset does  inherit  from  DBIx::Class::ResultSet  or  from  a  subclass  of
       DBIx::Class::ResultSet.

   eq_resultset ($resultset, $resultset, ?$message)
       Given  two  ResultSets,  determine  if  the  are  equal based on class type and data.  This is a true set
       equality that ignores sorting order of items inside the set.

   eq_result ($resultset, $resultset, ?$message)
       Given two row objects, make sure they are the same.

   hri_dump ($resultset)
       Not  a  test,  just  returns  a   version   of   the   ResultSet   that   has   its   inflator   set   to
       DBIx::Class::ResultClass::HashRefInflator,  which  returns  a  set  of hashes and makes it easier to stop
       issues.  This return value is suitable for dumping via Data::Dump, for example.

   reset_schema
       Wipes and reloads the schema.

   cleanup_schema
       Wipes schema and disconnects.

   dump_settings
       Returns the configuration and related settings used to initialize this testing module.  This is mostly to
       help you debug trouble with configuration and to help the authors find and fix bugs.  At some point  this
       won't  be  exported  by  default so don't use it for your real tests, just to help you understand what is
       going on.  You've been warned!

   is_fields
       A 'Swiss Army Knife' method to check your results or  resultsets.   Tests  the  values  of  a  Result  or
       ResultSet  against  expected  via  a  pattern.   A pattern is automatically created by instrospecting the
       fields of your ResultSet or Result.

       Example usage for testing a result follows.

           ok my $john = Person->find('john');

           is_fields 'name', $john, ['John Napiorkowski'],
             'Found name of $john';

           is_fields [qw/name age/], $john, ['John Napiorkowski', 40],
             'Found $johns name and age';

           is_fields $john, {
               name => 'John Napiorkowski',
               age => 40,
               email => 'john@home.com'};  # Assuming $john has only the three columns listed

       In the case where we need to infer the match pattern, we get the columns of the given result  but  remove
       the primary key.  Please note the following would also work:

           is_fields [qw/name age/] $john, {
               name => 'John Napiorkowski',
               age => 40}, 'Still got the name and age correct';

       You should choose the method that makes most sense in your tests.

       Example usage for testing a resultset follows.

           is_fields 'name', Person, [
               'John',
               'Vanessa',
               'Vincent',
           ];

           is_fields ['name'], Person, [
               'John',
               'Vanessa',
               'Vincent',
           ];

           is_fields ['name','age'], Person, [
               ['John',40],
               ['Vincent',15],
               ['Vanessa',35],
           ];

           is_fields ['name','age'], Person, [
               {name=>'John', age=>40},
               {name=>'Vanessa',age=>35},
               {name=>'Vincent', age=>15},
           ];

       I  find  the  array  version is most consise.  Please note that the match is not ordered.  If you need to
       test that a given Resultset is in a particular order, you will currently need to write a custom test.  If
       you have a big need for this I'd be willing to write a test for it, or gladly accept a patch to add it.

       You should examine the test cases for more examples.

   is_fields_multi
           TBD: Not yet written.

SETUP AND INITIALIZATION

       The generic usage for this would look like one of the following:

           use Test::DBIx::Class \%options, @sources
           use Test::DBIx::Class %options, @sources

       Where %options are key value pairs and @sources an array as specified below.

   Initialization Options
       The only difference between the hash and hash reference version of %options  is  that  the  hash  version
       requires  its  keys  to  be  prepended  with  "-".   If  you are inlining a lot of configuration the hash
       reference version may look neater, while if you are only setting one or  two  options  the  hash  version
       might be more readable.  For example, the following are the same:

           use Test::DBIx::Class -config_path=>[qw(t etc config)], 'Person', 'Job';
           use Test::DBIx::Class {config_path=>[qw(t etc config)]}, 'Person', 'Job';

       The  following  options  are  currently  standard and always available.  Depending on your storage engine
       (such as SQLite or MySQL) you will have other options.

       config_path
           These are the relative  paths  searched  for  configuration  file  information.  See  "Initialization
           Sources" for more.

           In the case were we have both inlined and file based configurations, the inlined is merged last (that
           is, has highest authority to override configuration files).

           When the final merging of all configurations (both anything inlined at 'use' time, and anything found
           in  any  of  the specified config_paths, we do a single 'post' config_path check.  This allows you to
           add in a configuration file from inside a configuration file.  For safety and sanity you can only  do
           this  once.   This  feature  makes  it  easier  to globalize any additional configuration files.  For
           example, I often store user specific settings in "~/etc/conf.*".  This feature allows me to add  that
           into my standard "t/etc/schema.*" so it's available to all my test cases.

       schema_class
           Required. This must be your subclass of DBIx::Class::Schema that defines your database schema.

       connect_info
           Required.  This  will  accept  anything  you  can  send  to  "connect"  in DBIx::Class.  Defaults to:
           ['dbi:SQLite:dbname=:memory:','',''] if left blank (but see 'traits' below for more)

       connect_opts
           Use this to customise connect_info if you have left that  blank  in  order  to  have  the  dsn  auto-
           generated, but require extra attributes such as name_sep and quote_char.

       deploy_opts
           Use this to customise any arguments that are to be passed to "deploy" in DBIx::Class::Schema, such as
           add_drop_table or quote_identifiers.

       default_resultset_attributes
           Allows  you to specify default_resultset_attributes to be set on the schema.  These will be used when
           creating all new resultsets.

           This is typically done to enable caching or turn on the software_limit flag.

       fixture_path
           These are a list of relative paths search for  fixtures.   Each  item  should  be  a  directory  that
           contains files loadable by Config::Any and suitable to be installed via one of the fixture classes.

       fixture_class
           Command  class that installs data into the database.  Must provide a method called 'install_fixtures'
           that accepts a perl data structure and installs it  into  the  database.   Must  capture  and  report
           errors.   Default  value  is  "::Populate",  which loads Test::DBIx::Class::FixtureCommand::Populate,
           which is a command class based on "populate" in DBIx::Class::Schema.

       resultsets
           Lets you add in some  result  source  definitions  to  be  imported  at  test  script  runtime.   See
           "Initialization Sources" for more.

       force_drop_table
           When  deploying  the  database  this option allows you add a 'drop table' statement before the create
           ddl.  Since this will return an error if you attempt to drop a table that doesn't exist, this is  off
           by  default  for  SQLite  storage  engines.  You may need to enble it you you are using the following
           'keep_db' option.

       keep_db
           By default your testing database is 'cleaned up' after you are finished.  This drops all the  created
           tables  (but  currently  doesn't delete any related files or database users, if any).  If you want to
           keep your testing database after all the tests are run, you can set this to true.   If  so,  you  may
           also  need  to  set  the  previously  mentioned option 'force_drop_table' to true as well, or we will
           attempt to create tables and populate them when they are already populated and created.

       deploy_db
           By default a fresh version of the schema is deployed when 'Test::DBIx::Class'  is  invoked.   If  you
           want to skip the schema deployment and instead connect to an already existing and populated database,
           set this option to false.

       traits
           Traits  are  Moose::Roles that are applied to the class managing the connection to your database.  If
           you leave  this  option  blank  and  you  don't  specify  anything  for  'connect_info'  (above),  we
           automatically      load      the      SQLite      trait     (which     can     be     reviewed     at
           Test::DBIx::Class::SchemaManager::Trait::SQLite).  This trait installs the ability  to  automatically
           discover and deploy to an in memory or a filesystem SQLite database.  If you are just getting started
           with testing, this is probably your easiest option.

           Currently  there  are  only  three  traits,  the  SQLite  trait  just  described  (and since it get's
           automatically     loaded     you     never     need     to      load      it      yourself).      The
           Test::DBIx::Class::SchemaManager::Trait::Testmysqld  trait, which is built on top of Test::mysqld and
           allows you the ability to deploy to and run tests against a temporary instance  of  MySQL.  For  this
           trait  MySQL  and DBD::mysql needs to be installed, but MySQL does not need to be running, nor do you
           need    to    create    a    test    database    or    user.      The    third     one     is     the
           Test::DBIx::Class::SchemaManager::Trait::Testpostgresql   trait,   which   is   built   on   top   of
           Test::Postgresql58 and allows you to deploy  to  and  run  tests  against  a  temporary  instance  of
           Postgresql.   For  this  trait  Postgresql and DBD::Pg needs to be installed, but Postgresql does not
           need to be running, nor do you need to create a test database or user.  See "TRAITS" for more.

       fail_on_schema_break
           Makes the test run fail when the schema can not be created.  Normally the test run  is  skipped  when
           the  schema  fails  to  create.   A  failure can be more convenient when you want to spot compilation
           failures.

       Please note that although all initialization options can be set inlined or in a configuration file,  some
       options can also be set via %ENV variables. %ENV settings will only apply IF there are no existing values
       for  the  option  in  any  configuration  file.   As of this time we don't merge %ENV settings, they only
       provider overrides to the default settings. Example  use  (assumes  you  are  using  the  default  SQLite
       database)

           DBNAME=test.db KEEP_DB=1 prove -lv t/schema/check-person.t

       After  running  the  test  there  will  be  a  new  file  called  'test.db' in the home directory of your
       distribution.  You can use:

           sqlite3 test.db

       to open and view the tables and  their  data  as  loaded  by  any  fixtures  or  create  statements.  See
       Test::DBIx::Class::SchemaManager::Trait::SQLite  for  more.   Note that you can specify both 'dbpath' and
       'keep_db' in your configuration files if you prefer.  I tried to expose a subset of configuration to %ENV
       that I thought the most useful.  Patches and suggestions welcomed.

   Initialization Sources
       The @sources are a list of result sources that you want helper methods injected  into  your  test  script
       namespace.  This is the 'Source' part of:

           $schema->resultset('Source');

       Injecting methods are optional since you can also use the 'ResultSet' keyword

       Imported  Source  keywords  use  Sub::Exporter  so  you  have  quite a few options for controling how the
       keywords are imported.  For example:

           use Test::DBIx::Class
             'Person',
             'Person::Employee' => {-as => 'Employee'},
             'Person' => {search => {age=>{'>'=>55}}, -as => 'OlderPerson'};

       This  would  import  three  local  keywork  methods,  "Person",  "Employee"   and   "OlderPerson".    For
       "OlderPerson",  the  search  parameter  would  automatically  be  resolved via $resultset->search and the
       correct resultset returned.  You may wish to preconfigure all your test result set cases in one go at the
       top of your test script as a way to promote reusability.

       In addition to the 'search' parameter, there is also an 'exec' parameter which  let's  you  process  your
       resultset programatically.  For example:

           'Person' => {exec => sub { shift->older_than(55) }, -as => 'OlderPerson'};

       This  code  reference  gets  passed  the resultset object.  So you can use any method on $resultset.  For
       example:

           'Person' => {exec => sub { shift->find('john') }, -as => 'John'};

           is_result John;
           is John->name, 'John Napiorkowski', "Got Correct Name";

       Although since fixtures will not yet be installed, the above is probably  not  going  to  be  a  normally
       working example :)

       Additionally,  since you can also initialize sources via the 'resultsets' configuration option, which can
       be placed into your global configuration files this means you can predefine and result resultsets  across
       all  your  tests.  Here is an example 't/etc/schema.pl' file where I initialize pretty much everything in
       one file:

            {
             'schema_class' => 'Test::DBIx::Class::Example::Schema',
             'resultsets' => [
               'Person',
               'Job',
               'Person' => { '-as' => 'NotTeenager', search => {age=>{'>'=>18}}},
             ],
             'fixture_sets' => {
               'basic' => [
                 'Person' => [
                   [
                     'name',
                     'age',
                     'email'
                   ],
                   [
                     'John',
                     '40',
                     'john@nowehere.com'
                   ],
                   [
                     'Vincent',
                     '15',
                     'vincent@home.com'
                   ],
                   [
                     'Vanessa',
                     '35',
                     'vanessa@school.com'
                   ]
                 ]
               ]
             },
           };

       In this case you can simple do "use Test::DBIx::Class" and everything will happen automatically.

       In the example 't/etc/schema.pl' file, instead of (or as well as) fixture_sets you could  instead  define
       fixture_path to allow resultset data outside of the main 't/etc/schema.pl' file.

            'fixture_path' => [qw{t etc fixtures}],

       Create the file './t/etc/fixtures/basic.pl' and insert

           [
             'Person' => [
               [
                 'name',
                 'age',
                 'email'
               ],
               [
                 'John',
                 '40',
                 'john@nowehere.com'
               ],
               [
                 'Vincent',
                 '15',
                 'vincent@home.com'
               ],
               [
                 'Vanessa',
                 '35',
                 'vanessa@school.com'
               ]
             ]
           ]

       Additional rulesets should be included within the outermost [ ] like this.

           [
             'Person' => [
               ...
             ],
             'Job' => [
               ...
             ]
           ]

       The 'basic' fixture would be used with fixtures_ok in exactly the same way as when it was embedded within
       schema.pl using fixture_sets.

CONFIGURATION BY FILE

       By default, we try to load configuration files from the following locations:

            ./t/etc/schema.*
            ./t/etc/[test file path].*

       Where  "."  is  the  root of the distribution and "*" is any of the configuration file types supported by
       Config::Any configuration loader.  This allows you to store configuration in the format of your choice.

       "[test file path]" is the relative path part under the "t" directory of the  calling  test  script.   For
       example, if your test script is "t/mytest.t" we add the path "./t/etc/mytest.*" to the path.

       Additionally,  we do a merge using Hash::Merge of all the matching found configurations.  This allows you
       to do 'cascading' configuration from the most global to the most local settings.

       You can override this search path with the "-config_path" key in  options.  For  example,  the  following
       searches  for  "t/etc/myconfig.*"  (or  whatever  is  the  correct directory separator for your operating
       system):

           use Test::DBIx::Class -config_path => [qw/t etc myconfig/];

       Relative paths are rooted to the distribution home directory (ie, the one that contains  your  'lib'  and
       't' directories).  Full paths are searched without modification.

       You can specify multiple paths.  The following would search for both "schema.*"  and "share/schema".

           use Test::DBIx::Class -config_path => [[qw/share schema/], [qw/schema/]];

       Lastly,  you  can use the special symbol "+" to indicate that your custom path adds to or prepends to the
       default search path.  Since as indicated we merge all the configurations found, this means it's  easy  to
       create user level configuration settings mixed with global settings, as in:

           use Test::DBIx::Class
               -config_path => [
                   [qw(/ etc myapp test-schema)],
                   '+',
                   [qw(~ etc test-schema)],
               ];

       Which  would  search  and  combine  "/etc/myapp/test-schema.*",  "./t/etc/schema.*",  "./etc/[test script
       name].*" and "~/etc/test-schema.*".  This would let you set up server level global settings, distribution
       level settings and finally user level settings.

       Please note that in all the examples given, paths are written as an array reference of path parts, rather
       than as a string with delimiters (i.e. we do [qw(t etc)] rather than "t/etc").  This is not required  but
       recommended.   All arguments, either string or array references, are passed to Path::Class so that we can
       maintain better compatibility with non unix filesystems.  If you are writing for  CPAN,  please  consider
       our non Unix filesystem friends :)

       Lastly,  there  is  an  %ENV variable named 'TEST_DBIC_CONFIG_SUFFIX' which, if it exists, can be used to
       further customize your configuration path.  If we find  that  $ENV{TEST_DBIC_CONFIG_SUFFIX}  is  set,  we
       attempt  to  find  configuration  files  with the suffix appended to each of the items in the config_path
       option.  So, if you have:

           use Test::DBIx::Class
               -config_path => [
                   [qw(/ etc myapp test-schema)],
                   '+',
                   [qw(~ etc test-schema)],
               ];

       and $ENV{TEST_DBIC_CONFIG_SUFFIX} = '-mysql' we will check the following  paths  for  valid  and  loading
       configuration files (assuming unix filesystem conventions)

           /etc/myapp/test-schema.*
           /etc/myapp/test-schema-mysql.*
           ./t/etc/schema.*
           ./t/etc/schema-mysql.*
           ./etc/[test script name].*
           ./etc/[test script name]-mysql.*
           ~/etc/test-schema.*
           ~/etc/test-schema-mysql.*

       Each  path is tested in turn and all found configurations are merged from top to bottom.  This feature is
       intended to make it easier to switch between sets of configuration files when developing.   For  example,
       you  can  create  a  test suite intended for a MySQL database, but allow a failback to the default Sqlite
       should certain enviroment variables not exist.

CONFIGURATION SUBSTITUTIONS

       Similarly to Catalyst::Plugin::ConfigLoader, there are some macro style keyword inflators  available  for
       use within your configuration files.  This allows you to set the value of a configuration setting from an
       external source, such as from %ENV.  There are currently two macro substitutions:

       ENV Given  a value in %ENV, substitute the keyword for the value of the named substitution.  For example,
           if you had:

               email = 'vanessa__ENV(TEST_DBIC_LAST_NAME)__@school.com'

           in your configuration filem your could:

               TEST_DBIC_LAST_NAME=_lee prove -lv t/schema-your-test.t

           and then:

               is $vanessa->email, 'vanessa_lee@school.com', 'Got expected email';

           You might find this useful for configuring localized username and passwords although  personally  I'd
           rather set that via configuration in the user home directory.

TRAITS

       As  described,  a  trait  is  a  Moose::Role that is applied to the class managing your database and test
       instance.  Traits are installed by the 'traits' configuration option, which expects an  ArrayRef  as  its
       input (however will also normalize a scalar to an ArrayRef).

       Available traits are as follows.

   SQLite
       This  is  the  default  trait  which  will  be  loaded  if no other traits are installed and there is not
       'connect_info' in the configuration.  In this case we assume you want us  to  go  and  create  a  tempory
       SQLite database for testing.  Please see Test::DBIx::Class::SchemaManager::Trait::SQLite for more.

   Testmysqld
       If  MySQL is installed on the testing machine, and DBD::mysql, we try to auto create an instance of MySQL
       and deploy our tests to that.  Similarly to the way the SQLite trait works,  we  attempt  to  create  the
       database without requiring any other using effort or setup.

       See Test::DBIx::Class::SchemaManager::Trait::Testmysqld for more.

   Testpostgresql
       If  Postgresql is installed on the testing machine, along with DBD::Pg, we try to auto create an instance
       of Postgresql in a testing area and deploy our tests and fixtures to it.

       See Test::DBIx::Class::SchemaManager::Trait::Testpostgresql for more.

SEE ALSO

       The following modules or resources may be of interest.

       DBIx::Class, DBIx::Class::Schema::PopulateMore, DBIx::Class::Fixtures

AUTHOR

           John Napiorkowski C<< <jjnapiork@cpan.org> >>

CONTRIBUTORS

           Tristan Pratt
           Tomas Doran C<< <bobtfish@bobtfish.net> >>
           Kyle Hasselbacher C<< kyleha@gmail.com >>
           cvince
           colinnewell
           rbuels
           wlk
           yanick
           hippich
           lecstor
           bphillips
           abraxxa
           oalders
           felliott
           Vadim Pushtaev C<< <pushtaev@cpan.org> >>
           simonamor

COPYRIGHT & LICENSE

       Copyright 2012, John Napiorkowski "<jjnapiork@cpan.org>"

       This program is free software; you can redistribute it and/or modify it under  the  same  terms  as  Perl
       itself.

perl v5.36.0                                       2023-01-29                             Test::DBIx::Class(3pm)