Doodle

 view release on metacpan or  search on metacpan

lib/Doodle/Relation/Helpers.pm  view on Meta::CPAN

  on_delete(Str $action) : Relation

Denote the "ON DELETE" action for a foreign key constraint and returns the Relation.

=over 4

=item on_delete example #1

  # given: synopsis

  my $on_delete = $self->on_delete('cascade');

=back

=cut

=head2 on_update

  on_update(Str $action) : Relation

Denote the "ON UPDATE" action for a foreign key constraint and returns the Relation.

=over 4

=item on_update example #1

  # given: synopsis

  my $on_update = $self->on_update('cascade');

=back

=cut

=head1 AUTHOR

Al Newkirk, C<awncorp@cpan.org>

=head1 LICENSE

t/Doodle_Relation_Helpers.t  view on Meta::CPAN

=signature on_delete

on_delete(Str $action) : Relation

=cut

=example-1 on_delete

  # given: synopsis

  my $on_delete = $self->on_delete('cascade');

=cut

=method on_update

Denote the "ON UPDATE" action for a foreign key constraint and returns the Relation.

=cut

=signature on_update

on_update(Str $action) : Relation

=cut

=example-1 on_update

  # given: synopsis

  my $on_update = $self->on_update('cascade');

=cut

package main;

my $test = Test::Auto->new(__FILE__);

my $subtests = $test->subtests->standard;

$subtests->synopsis(fun($tryable) {
  ok my $result = $tryable->result, 'result ok';

  $result;
});

$subtests->example(-1, 'on_delete', 'method', fun($tryable) {
  ok my $result = $tryable->result, 'result ok';
  is $result->data->{on_delete}, 'cascade', 'on-delete meta key ok';

  $result;
});

$subtests->example(-1, 'on_update', 'method', fun($tryable) {
  ok my $result = $tryable->result, 'result ok';
  is $result->data->{on_update}, 'cascade', 'on-update meta key ok';

  $result;
});

subtest 't/0.05/can/Doodle_Relation_Helpers_on_update.t', fun() {
  can_ok 'Doodle::Relation::Helpers', 'on_update';

  my $d = Doodle->new;
  my $t = $d->table('users');
  my $r = $t->relation('profile_id', 'profiles');

  $r->on_update('cascade');

  isa_ok $r, 'Doodle::Relation';

  is $r->data->{on_update}, 'cascade';

  ok 1 and done_testing;
};

subtest 't/0.05/can/Doodle_Relation_Helpers_on_delete.t', fun() {
  can_ok 'Doodle::Relation::Helpers', 'on_delete';

  my $d = Doodle->new;
  my $t = $d->table('users');
  my $r = $t->relation('profile_id', 'profiles');

  $r->on_delete('cascade');

  isa_ok $r, 'Doodle::Relation';

  is $r->data->{on_delete}, 'cascade';

  ok 1 and done_testing;
};

ok 1 and done_testing;



( run in 0.474 second using v1.01-cache-2.11-cpan-49f99fa48dc )