The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
#! /bin/false

# $Id: TC_PreProcess.pm,v 1.4 2006/05/11 13:56:28 guido Exp $

# Data::Walk - Traverse Perl data structures.
# Copyright (C) 2005-2006 Guido Flohr <guido@imperia.net>,
# all rights reserved.

# This program is free software; you can redistribute it and/or modify it
# under the terms of the GNU Library General Public License as published
# by the Free Software Foundation; either version 2, or (at your option)
# any later version.

# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
# Library General Public License for more details.

# You should have received a copy of the GNU Library General Public
# License along with this program; if not, write to the Free Software
# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307,
# USA.

package TC_PreProcess;

use strict;

use base qw (Test::Unit::TestCase);

use Data::Walk;

sub testHash {
    my ($self) = @_;

    my %data = ('A' .. 'Z', 'a' .. 'z');

    my $preprocessor_calls = 0;
    my $preprocess = sub {
	my %container = @_;
	my @sorted;
	
	foreach my $key (sort keys %container) {
	    push @sorted, $key, $container{$key};
	}

	++$preprocessor_calls;
	return @sorted;
    };

    my $last = '';
    my $wanted = sub {
	unless (ref $_) {
	    $self->assert ($_ gt $last,
			   "Hash is not traversed in preprocess order.");
	    $last = $_;
	}
    };
    walk { wanted => $wanted, preprocess => $preprocess}, \%data;

    $self->assert ($preprocessor_calls,
		   "Preprocessing function never called.");
}

sub testArray {
    my ($self) = @_;

    my @data = ('A' .. 'Z', 'a' .. 'z');

    my $preprocessor_calls = 0;
    my $preprocess = sub {
	++$preprocessor_calls;
        return reverse sort @_;
    };

    my $last = chr (1 + ord $data[-1]);
    my $wanted = sub {
	unless (ref $_) {
	    $self->assert ($_ lt $last,
			   "Array is not traversed in preprocess order.");
	    $last = $_;
	}
    };
    walk { wanted => $wanted, preprocess => $preprocess}, \@data;

    $self->assert ($preprocessor_calls,
		   "Preprocessing function never called.");
}

sub testPreprocessHash {
    my ($self) = @_;

    my %data = ('A' .. 'Z', 'a' .. 'z');

    my $preprocessor_calls = 0;
    my $preprocess = sub {
	my %container = @_;
	my @sorted;
	
	foreach my $key (sort keys %container) {
	    push @sorted, $key, $container{$key};
	}

	++$preprocessor_calls;
	return @sorted;
    };

    my $last = '';
    my $wanted = sub {
	unless (ref $_) {
	    $self->assert ($_ gt $last,
			   "Hash is not traversed in preprocess order.");
	    $last = $_;
	}
    };
    walk { wanted => $wanted, preprocess_hash => $preprocess}, \%data;

    $self->assert ($preprocessor_calls,
		   "Preprocessing function never called.");

    my @data = ('A' .. 'Z', 'a' .. 'z');

    $preprocessor_calls = 0;
    $preprocess = sub {
	++$preprocessor_calls;
    };

    $wanted = sub {};
    walk { wanted => $wanted, preprocess_hash => $preprocess}, \@data;

    $self->assert (!$preprocessor_calls,
		   "Preprocessing function has been called for array.");
}

1;

#Local Variables:
#mode: perl
#perl-indent-level: 4
#perl-continued-statement-offset: 4
#perl-continued-brace-offset: 0
#perl-brace-offset: -4
#perl-brace-imaginary-offset: 0
#perl-label-offset: -4
#cperl-indent-level: 4
#cperl-continued-statement-offset: 2
#tab-width: 8
#End: