Schema support added, DBICTest refactored to use it
[dbsrgits/DBIx-Class.git] / t / lib / DBICTest.pm
CommitLineData
510ca912 1use strict;
2use warnings;
a02675cd 3use DBICTest::Schema;
60786fdc 4use DateTime;
510ca912 5
6my $db_file = "t/var/DBIxClass.db";
7
8unlink($db_file) if -e $db_file;
9unlink($db_file . "-journal") if -e $db_file . "-journal";
10mkdir("t/var") unless -d "t/var";
11
a02675cd 12DBICTest::Schema->compose_connection('DBICTest' => "dbi:SQLite:${db_file}");
510ca912 13
a02675cd 14my $dbh = DBICTest->storage->dbh;
510ca912 15
16my $sql = <<EOSQL;
17CREATE TABLE artist (artistid INTEGER NOT NULL PRIMARY KEY, name VARCHAR);
18
19CREATE TABLE cd (cdid INTEGER NOT NULL PRIMARY KEY, artist INTEGER NOT NULL,
20 title VARCHAR, year VARCHAR);
21
22CREATE TABLE liner_notes (liner_id INTEGER NOT NULL PRIMARY KEY, notes VARCHAR);
23
24CREATE TABLE track (trackid INTEGER NOT NULL PRIMARY KEY, cd INTEGER NOT NULL,
25 position INTEGER NOT NULL, title VARCHAR);
26
27CREATE TABLE tags (tagid INTEGER NOT NULL PRIMARY KEY, cd INTEGER NOT NULL,
28 tag VARCHAR);
29
30CREATE TABLE twokeys (artist INTEGER NOT NULL, cd INTEGER NOT NULL,
31 PRIMARY KEY (artist, cd) );
32
6eec7501 33CREATE TABLE fourkeys (foo INTEGER NOT NULL, bar INTEGER NOT NULL,
34 hello INTEGER NOT NULL, goodbye INTEGER NOT NULL,
35 PRIMARY KEY (foo, bar, hello, goodbye) );
36
510ca912 37CREATE TABLE onekey (id INTEGER NOT NULL PRIMARY KEY,
38 artist INTEGER NOT NULL, cd INTEGER NOT NULL );
39
40INSERT INTO artist (artistid, name) VALUES (1, 'Caterwauler McCrae');
41
42INSERT INTO artist (artistid, name) VALUES (2, 'Random Boy Band');
43
44INSERT INTO artist (artistid, name) VALUES (3, 'We Are Goth');
45
46INSERT INTO cd (cdid, artist, title, year)
47 VALUES (1, 1, "Spoonful of bees", 1999);
48
49INSERT INTO cd (cdid, artist, title, year)
50 VALUES (2, 1, "Forkful of bees", 2001);
51
52INSERT INTO cd (cdid, artist, title, year)
53 VALUES (3, 1, "Caterwaulin' Blues", 1997);
54
55INSERT INTO cd (cdid, artist, title, year)
56 VALUES (4, 2, "Generic Manufactured Singles", 2001);
57
58INSERT INTO cd (cdid, artist, title, year)
59 VALUES (5, 3, "Come Be Depressed With Us", 1998);
60
61INSERT INTO liner_notes (liner_id, notes)
62 VALUES (2, "Buy Whiskey!");
63
64INSERT INTO liner_notes (liner_id, notes)
65 VALUES (4, "Buy Merch!");
66
67INSERT INTO liner_notes (liner_id, notes)
68 VALUES (5, "Kill Yourself!");
69
70INSERT INTO tags (tagid, cd, tag) VALUES (1, 1, "Blue");
71
72INSERT INTO tags (tagid, cd, tag) VALUES (2, 2, "Blue");
73
74INSERT INTO tags (tagid, cd, tag) VALUES (3, 3, "Blue");
75
76INSERT INTO tags (tagid, cd, tag) VALUES (4, 5, "Blue");
77
78INSERT INTO tags (tagid, cd, tag) VALUES (5, 2, "Cheesy");
79
80INSERT INTO tags (tagid, cd, tag) VALUES (6, 4, "Cheesy");
81
82INSERT INTO tags (tagid, cd, tag) VALUES (7, 5, "Cheesy");
83
84INSERT INTO tags (tagid, cd, tag) VALUES (8, 2, "Shiny");
85
86INSERT INTO tags (tagid, cd, tag) VALUES (9, 4, "Shiny");
87
88INSERT INTO twokeys (artist, cd) VALUES (1, 1);
89
90INSERT INTO twokeys (artist, cd) VALUES (1, 2);
91
92INSERT INTO twokeys (artist, cd) VALUES (2, 2);
93
6eec7501 94INSERT INTO fourkeys (foo, bar, hello, goodbye) VALUES (1, 2, 3, 4);
95
96INSERT INTO fourkeys (foo, bar, hello, goodbye) VALUES (5, 4, 3, 6);
97
510ca912 98INSERT INTO onekey (id, artist, cd) VALUES (1, 1, 1);
99
100INSERT INTO onekey (id, artist, cd) VALUES (2, 1, 2);
101
102INSERT INTO onekey (id, artist, cd) VALUES (3, 2, 2);
103EOSQL
104
105$dbh->do($_) for split(/\n\n/, $sql);
106
510ca912 1071;