e1e56b4bb2fa8deb4dd5187a30f02cbe2374e896
[dbsrgits/DBIx-Class.git] / t / lib / DBICTest / Schema / Track.pm
1 package # hide from PAUSE
2     DBICTest::Schema::Track;
3
4 use base qw/DBICTest::BaseResult/;
5 use Carp qw/confess/;
6
7 __PACKAGE__->load_components(qw{
8     +DBICTest::DeployComponent
9     InflateColumn::DateTime
10     Ordered
11 });
12
13 __PACKAGE__->table('track');
14 __PACKAGE__->add_columns(
15   'trackid' => {
16     data_type => 'integer',
17     is_auto_increment => 1,
18   },
19   'cd' => {
20     data_type => 'integer',
21   },
22   'position' => {
23     data_type => 'int',
24     accessor => 'pos',
25   },
26   'title' => {
27     data_type => 'varchar',
28     size      => 100,
29   },
30   last_updated_on => {
31     data_type => 'datetime',
32     accessor => 'updated_date',
33     is_nullable => 1
34   },
35   last_updated_at => {
36     data_type => 'datetime',
37     is_nullable => 1
38   },
39 );
40 __PACKAGE__->set_primary_key('trackid');
41
42 __PACKAGE__->add_unique_constraint([ qw/cd position/ ]);
43 __PACKAGE__->add_unique_constraint([ qw/cd title/ ]);
44
45 __PACKAGE__->position_column ('position');
46 __PACKAGE__->grouping_column ('cd');
47
48
49 __PACKAGE__->belongs_to( cd => 'DBICTest::Schema::CD', undef, {
50     proxy => { cd_title => 'title' },
51 });
52 __PACKAGE__->belongs_to( disc => 'DBICTest::Schema::CD' => 'cd', {
53     proxy => 'year'
54 });
55
56 __PACKAGE__->might_have( cd_single => 'DBICTest::Schema::CD', 'single_track' );
57 __PACKAGE__->might_have( lyrics => 'DBICTest::Schema::Lyrics', 'track_id' );
58
59 __PACKAGE__->belongs_to(
60     "year1999cd",
61     "DBICTest::Schema::Year1999CDs",
62     { "foreign.cdid" => "self.cd" },
63     { join_type => 'left' },  # the relationship is of course optional
64 );
65 __PACKAGE__->belongs_to(
66     "year2000cd",
67     "DBICTest::Schema::Year2000CDs",
68     { "foreign.cdid" => "self.cd" },
69     { join_type => 'left' },
70 );
71
72 __PACKAGE__->has_many (
73   next_tracks => __PACKAGE__,
74   sub {
75     my $args = shift;
76
77     # This is for test purposes only. A regular user does not
78     # need to sanity check the passed-in arguments, this is what
79     # the tests are for :)
80     my @missing_args = grep { ! defined $args->{$_} }
81       qw/self_alias foreign_alias self_resultsource foreign_relname/;
82     confess "Required arguments not supplied to custom rel coderef: @missing_args\n"
83       if @missing_args;
84
85     return (
86       { "$args->{foreign_alias}.cd"       => { -ident => "$args->{self_alias}.cd" },
87         "$args->{foreign_alias}.position" => { '>' => { -ident => "$args->{self_alias}.position" } },
88       },
89       $args->{self_rowobj} && {
90         "$args->{foreign_alias}.cd"       => $args->{self_rowobj}->get_column('cd'),
91         "$args->{foreign_alias}.position" => { '>' => $args->{self_rowobj}->pos },
92       }
93     )
94   }
95 );
96
97 our $hook_cb;
98
99 sub sqlt_deploy_hook {
100   my $class = shift;
101
102   $hook_cb->($class, @_) if $hook_cb;
103   $class->next::method(@_) if $class->next::can;
104 }
105
106 1;