Skip to content

HTTPS clone URL

Subversion checkout URL

You can clone with
or
.
Download ZIP
Fetching contributors…

Cannot retrieve contributors at this time

76 lines (55 sloc) 2.256 kB
use v6;
use Test;
=begin description
This test tests the C<reduce> builtin.
Reference:
L<"http://groups.google.com/groups?selm=420DB295.3000902%40conway.org">
=end description
plan 16;
# L<S32::Containers/List/=item reduce>
{
my @array = <5 -3 7 0 1 -9>;
my $sum = 5 + -3 + 7 + 0 + 1 + -9; # laziness :)
is((reduce { $^a + $^b }, 0, @array), $sum, "basic reduce works (1)");
#?rakudo skip 'named args'
is((reduce { $^a + $^b }, 0, :values(@array)), $sum, "basic reduce works (2)");
#?rakudo skip 'closure as non-final argument'
is((reduce { $^a + $^b }: 100, @array), 100 + $sum, "basic reduce works (3)");
#?rakudo skip 'method fallback to sub unimpl'
is(({ $^a * $^b }.reduce: 1,2,3,4,5), 120, "basic reduce works (4)");
}
# Reduce with n-ary functions
{
my @array = <1 2 3 4 5 6 7 8>, Any;
my $result = (((1 + 2 * 3) + 4 * 5) + 6 * 7) + 8 * Any;
#?rakudo todo 'n-ary reduce'
is (@array.reduce: { $^a + $^b * $^c }), $result, "n-ary reduce() works";
}
{
#?pugs 2 todo 'bug'
is( 42.reduce( {$^a+$^b} ), 42, "method form of reduce works on numbers");
is( 'str'.reduce( {$^a+$^b} ), 'str', "method form of reduce works on strings");
is ((42,).reduce: { $^a + $^b }), 42, "method form of reduce should work on arrays";
}
{
my $hash = {a => {b => {c => 42}}};
my @reftypes;
sub foo (Hash $hash, Str $key) {
push @reftypes, $hash.WHAT;
$hash.{$key};
}
is((reduce(&foo, $hash, <a b c>)), 42, 'reduce(&foo) (foo ~~ .{}) works three levels deep');
#?rakudo 3 todo 'unknown'
isa_ok(@reftypes[0], Hash, "first application of reduced hash subscript passed in a Hash");
isa_ok(@reftypes[1], Hash, "second application of reduced hash subscript passed in a Hash");
isa_ok(@reftypes[2], Hash, "third application of reduced hash subscript passed in a Hash");
}
#?rakudo todo 'Reduce of one element list. See #61610'
is( (1).list.reduce({$^a * $^b}), 0, "Reduce of one element list produces correct result");
eval_lives_ok( 'reduce -> $a, $b, $c? { $a + $b * ($c//1) }, 1, 2', 'Use proper arity calculation');
{
is( ((1..10).list.reduce: &infix:<+>), 55, '.reduce: &infix:<+> works' );
is( ((1..4).list.reduce: &infix:<*>), 24, '.reduce: &infix:<*> works' );
}
done;
# vim: ft=perl6
Jump to Line
Something went wrong with that request. Please try again.