The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
package make_dbictest_db_with_unique;

use strict;
use warnings;
use DBI;
use dbixcsl_test_dir qw/$tdir/;


eval { require DBD::SQLite };
my $class = $@ ? 'SQLite2' : 'SQLite';

my $fn = "$tdir/dbictest_with_unique.db";

unlink($fn);
our $dsn = "dbi:$class:dbname=$fn";
my $dbh = DBI->connect($dsn);
$dbh->do('PRAGMA SYNCHRONOUS = OFF');

$dbh->do($_) for (
    q|CREATE TABLE foos (
        fooid INTEGER PRIMARY KEY,
        footext TEXT
      )|,
    q|CREATE TABLE bar (
        barid INTEGER PRIMARY KEY,
        foo_id INTEGER NOT NULL REFERENCES foos (fooid)
      )|,
    q|CREATE TABLE bazs (
        bazid INTEGER PRIMARY KEY,
        baz_num INTEGER NOT NULL UNIQUE,
        stations_visited_id INTEGER REFERENCES stations_visited (id)
      )|,
    q|CREATE TABLE quuxs (
        quuxid INTEGER PRIMARY KEY,
        baz_id INTEGER NOT NULL UNIQUE,
        FOREIGN KEY (baz_id) REFERENCES bazs (baz_num)
      )|,
    q|CREATE TABLE stations_visited (
        id INTEGER PRIMARY KEY,
        quuxs_id INTEGER REFERENCES quuxs (quuxid)
      )|,
    q|CREATE TABLE RouteChange (
        id INTEGER PRIMARY KEY,
        QuuxsId INTEGER REFERENCES quuxs (quuxid),
        Foo2Bar INTEGER
      )|,
    q|CREATE TABLE email (
        id INTEGER PRIMARY KEY,
        to_id INTEGER REFERENCES foos (fooid),
        from_id INTEGER REFERENCES foos (fooid)
      )|,
    q|INSERT INTO foos VALUES (1,'Foos text for number 1')|,
    q|INSERT INTO foos VALUES (2,'Foos record associated with the Bar with barid 3')|,
    q|INSERT INTO foos VALUES (3,'Foos text for number 3')|,
    q|INSERT INTO foos VALUES (4,'Foos text for number 4')|,
    q|INSERT INTO bar VALUES (1,4)|,
    q|INSERT INTO bar VALUES (2,3)|,
    q|INSERT INTO bar VALUES (3,2)|,
    q|INSERT INTO bar VALUES (4,1)|,
    q|INSERT INTO bazs VALUES (1,20,1)|,
    q|INSERT INTO bazs VALUES (2,19,1)|,
    q|INSERT INTO quuxs VALUES (1,20)|,
    q|INSERT INTO quuxs VALUES (2,19)|,
    q|INSERT INTO stations_visited VALUES (1,1)|,
    q|INSERT INTO RouteChange VALUES (1,1,3)|,
);

END { unlink($fn) unless $ENV{SCHEMA_LOADER_TESTS_NOCLEANUP}; }

1;