Data-Object-Role-Tryable

 view release on metacpan or  search on metacpan

t/Data_Object_Role_Tryable.t  view on Meta::CPAN

use 5.014;

use strict;
use warnings;
use routines;

use Test::Auto;
use Test::More;

=name

Data::Object::Role::Tryable

=cut

=abstract

Tryable Role for Perl 5

=cut

=includes

method: try

=cut

=synopsis

  package Example;

  use Moo;

  with 'Data::Object::Role::Tryable';

  package main;

  use routines;

  my $example = Example->new;

=cut

=description

This package provides a wrapper around the L<Data::Object::Try> class which
provides an object-oriented interface for performing complex try/catch
operations.

=cut

=method try

The try method takes a method name or coderef and returns a
L<Data::Object::Try> object with the current object passed as the invocant
which means that C<try> and C<finally> callbacks will receive that as the first
argument.

=signature try

try(CodeRef | Str $method) : InstanceOf['Data::Object::Try']

=example-1 try

  # given: synopsis

  my $tryer = $example->try(fun(@args) {
    [@args]
  });

  # $tryer->result(...)

=example-2 try

  # given: synopsis

  my $tryer = $example->try(fun(@args) {
    die 'tried';
  });

  $tryer->default(fun($error) {
    return ['tried'] if $error =~ 'tried';
    return [$error];
  });

  # $tryer->result(...)

=cut

package main;

my $test = testauto(__FILE__);

my $subs = $test->standard;

$subs->synopsis(fun($tryable) {
  ok my $result = $tryable->result;
  ok $result->isa('Example');

  $result
});

$subs->example(-1, 'try', 'method', fun($tryable) {
  ok my $tryer = $tryable->result;
  my $returned = $tryer->result(1..4);
  is $returned->[1], 1;
  is $returned->[2], 2;
  is $returned->[3], 3;
  is $returned->[4], 4;

  $tryer
});

$subs->example(-2, 'try', 'method', fun($tryable) {
  ok my $tryer = $tryable->result;
  my $returned = $tryer->result(1..4);



( run in 0.454 second using v1.01-cache-2.11-cpan-39bf76dae61 )