X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=dbsrgits%2FDBIx-Class.git;a=blobdiff_plain;f=t%2Flib%2FDBICTest%2FSchema%2FYear2000CDs.pm;h=1cf1b3736ea86b6cb24c7d2e5fd9b47d448760ef;hp=7f75f5fa8532fbf7e1eddf7a8f8163b61bde22c2;hb=4c90556806f286093d0806e858abdba329e6dfd3;hpb=846e17a679e91078d7c7fd3a2f0ca80749dc5d34 diff --git a/t/lib/DBICTest/Schema/Year2000CDs.pm b/t/lib/DBICTest/Schema/Year2000CDs.pm index 7f75f5f..1cf1b37 100644 --- a/t/lib/DBICTest/Schema/Year2000CDs.pm +++ b/t/lib/DBICTest/Schema/Year2000CDs.pm @@ -1,30 +1,26 @@ -package # hide from PAUSE +package # hide from PAUSE DBICTest::Schema::Year2000CDs; -## Used in 104view.t -use base qw/DBICTest::BaseResult/; +use warnings; +use strict; -__PACKAGE__->table_class('DBIx::Class::ResultSource::View'); +use base qw/DBICTest::Schema::CD/; + +# FIXME not entirely sure *why* this particular bit trips up tests +# and even more mysteriously: only a single oracle test... +# Running out of time and no local Oracle so can't investigate :/ +use mro 'c3'; +__PACKAGE__->table_class('DBIx::Class::ResultSource::View'); __PACKAGE__->table('year2000cds'); -__PACKAGE__->result_source_instance->view_definition( - "SELECT cdid, artist, title FROM cd WHERE year ='2000'" -); -__PACKAGE__->add_columns( - 'cdid' => { - data_type => 'integer', - is_auto_increment => 1, - }, - 'artist' => { - data_type => 'integer', - }, - 'title' => { - data_type => 'varchar', - size => 100, - }, -); -__PACKAGE__->set_primary_key('cdid'); -__PACKAGE__->add_unique_constraint([ qw/artist title/ ]); +# need to operate on the instance for things to work +__PACKAGE__->result_source_instance->view_definition( sprintf ( + "SELECT %s FROM cd WHERE year = '2000'", + join (', ', __PACKAGE__->columns), +)); + +__PACKAGE__->belongs_to( artist => 'DBICTest::Schema::Artist' ); +__PACKAGE__->has_many( tracks => 'DBICTest::Schema::Track', 'cd' ); 1;