return $self->{_relationship_data}{%1$s};
}
else {
- my $rel_info = $self->result_source->relationship_info(%1$s);
- my $cond = $self->result_source->_resolve_condition(
- $rel_info->{cond}, %1$s, $self, %1$s
+ my $relcond = $self->result_source->_resolve_relationship_condition(
+ rel_name => %1$s,
+ foreign_alias => %1$s,
+ self_alias => 'me',
+ self_result_object => $self,
);
- if ($rel_info->{attrs}->{undef_on_null_fk}){
- return undef unless ref($cond) eq 'HASH';
- return undef if grep { not defined $_ } values %%$cond;
- }
- my $val = $self->find_related( %1$s => {} );
+
+ return undef if (
+ $relcond->{join_free_condition}
+ and
+ $relcond->{join_free_condition} ne DBIx::Class::_Util::UNRESOLVABLE_CONDITION
+ and
+ scalar grep { not defined $_ } values %%{ $relcond->{join_free_condition} || {} }
+ and
+ $self->result_source->relationship_info(%1$s)->{attrs}{undef_on_null_fk}
+ );
+
+ my $val = $self->search_related( %1$s )->single;
return $val unless $val; # $val instead of undef so that null-objects can go through
return $self->{_relationship_data}{%1$s} = $val;
{ join_type => 'left'},
);
+__PACKAGE__->belongs_to( single_track_opaque => 'DBICTest::Schema::Track',
+ sub {
+ my $args = &check_customcond_args;
+ \ " $args->{foreign_alias}.trackid = $args->{self_alias}.single_track ";
+ },
+ { join_type => 'left'},
+);
+
# add a non-left single relationship for the complex prefetch tests
__PACKAGE__->belongs_to( existing_single_track => 'DBICTest::Schema::Track',
{ 'foreign.trackid' => 'self.single_track' },
--- /dev/null
+use strict;
+use warnings;
+
+use Test::More;
+
+use lib 't/lib';
+use DBICTest;
+
+my $schema = DBICTest->init_schema( no_populate => 1, quote_names => 1 );
+
+$schema->resultset('CD')->create({
+ title => 'Equinoxe',
+ year => 1978,
+ artist => { name => 'JMJ' },
+ genre => { name => 'electro' },
+ tracks => [
+ { title => 'e1' },
+ { title => 'e2' },
+ { title => 'e3' },
+ ],
+ single_track => {
+ title => 'o1',
+ cd => {
+ title => 'Oxygene',
+ year => 1976,
+ artist => { name => 'JMJ' },
+ },
+ },
+});
+
+my $cd = $schema->resultset('CD')->search({ single_track => { '!=', undef } })->first;
+
+$schema->is_executed_sql_bind(
+ sub { is( eval{$cd->single_track_opaque->title}, 'o1', 'Found correct single track' ) },
+ [
+ [
+ 'SELECT "me"."trackid", "me"."cd", "me"."position", "me"."title", "me"."last_updated_on", "me"."last_updated_at"
+ FROM cd "cd__row"
+ JOIN "track" "me"
+ ON me.trackid = cd__row.single_track
+ WHERE "cd__row"."cdid" = ?
+ ',
+ [
+ { dbic_colname => "cd__row.cdid", sqlt_datatype => "integer" }
+ => 2
+ ]
+ ],
+ ],
+);
+
+done_testing;