use strict;
use lib qw(t/lib);
my $schema = DBICTest->init_schema();
diag
'Update foreign key with an updated primary key (similar to "Create foreign key col obj including PK" in 96multi_create.t)';
eval {
my $new_cd_hashref = {
cdid => 30,
title => 'Boogie Woogie',
year => '2007',
artist => { artistid => 1 }
};
my $cd = $schema->resultset("CD")->find(1);
is( $cd->artist->id, 1, 'rel okay' );
my $new_cd = $schema->resultset("CD")->recursive_update($new_cd_hashref);
is( $new_cd->artist->id, 1, 'new id retained okay' );
};
eval {
my $updated_cd = $schema->resultset("CD")->recursive_update(
{ cdid => 30,
title => 'Boogie Wiggle',
year => '2007',
artist => { artistid => 2 }
}
);
is( $updated_cd->artist->id, 2, 'related artist changed correctly' );
};
is( $@, '', 'new cd created without clash on related artist' );
diag
'The same as the last test, but on a relationship with accessor "single".';
eval {
my $new_lyrics_hashref = {
lyric_id => 1,
track => { trackid => 4 }
};
my $new_lyric = $schema->resultset("Lyrics")->recursive_update($new_lyrics_hashref);
is( $new_lyric->track->trackid, 4, 'new id retained okay' );
};
eval {
my $updated_lyric = $schema->resultset("Lyrics")->recursive_update(
{
lyric_id => 1,
track => { trackid => 5 }
}
);
is( $updated_lyric->track->trackid, 5, 'related artist changed correctly' );
};
is( $@, '', 'new cd created without clash on related artist' );
done_testing;
# vim: set ft=perl ts=4 expandtab: