package # hide from PAUSE DBICTest::Schema::Artwork; use base qw/DBICTest::BaseResult/; use Carp qw/confess/; __PACKAGE__->table('cd_artwork'); __PACKAGE__->add_columns( 'cd_id' => { data_type => 'integer', is_nullable => 0, }, ); __PACKAGE__->set_primary_key('cd_id'); __PACKAGE__->belongs_to('cd', 'DBICTest::Schema::CD', 'cd_id'); __PACKAGE__->has_many('images', 'DBICTest::Schema::Image', 'artwork_id'); __PACKAGE__->has_many('artwork_to_artist', 'DBICTest::Schema::Artwork_to_Artist', 'artwork_cd_id'); __PACKAGE__->many_to_many('artists', 'artwork_to_artist', 'artist'); # both to test manytomany with custom rel __PACKAGE__->many_to_many('artists_test_m2m', 'artwork_to_artist', 'artist_test_m2m'); __PACKAGE__->many_to_many('artists_test_m2m_noopt', 'artwork_to_artist', 'artist_test_m2m_noopt'); # other test to manytomany __PACKAGE__->has_many('artwork_to_artist_test_m2m', 'DBICTest::Schema::Artwork_to_Artist', sub { my $args = shift; # This is for test purposes only. A regular user does not # need to sanity check the passed-in arguments, this is what # the tests are for :) my @missing_args = grep { ! defined $args->{$_} } qw/self_alias foreign_alias self_resultsource foreign_relname/; confess "Required arguments not supplied to custom rel coderef: @missing_args\n" if @missing_args; return ( { "$args->{foreign_alias}.artwork_cd_id" => { -ident => "$args->{self_alias}.cd_id" }, }, $args->{self_rowobj} && { "$args->{foreign_alias}.artwork_cd_id" => $args->{self_rowobj}->cd_id, } ); } ); __PACKAGE__->many_to_many('artists_test_m2m2', 'artwork_to_artist_test_m2m', 'artist'); 1;