use Test::More tests => 10; use strict; use HTTP::Proxy::BodyFilter::simple; my ( $filter, $sub ); # error checking eval { $filter = HTTP::Proxy::BodyFilter::simple->new() }; like( $@, qr/^Constructor called without argument/, "Need at least one arg" ); eval { $filter = HTTP::Proxy::BodyFilter::simple->new("foo") }; like( $@, qr/^Single parameter must be a CODE reference/, "Single coderef" ); eval { $filter = HTTP::Proxy::BodyFilter::simple->new( filter => "foo" ) }; like( $@, qr/^Parameter to filter must be a CODE reference/, "Need coderef" ); eval { $filter = HTTP::Proxy::BodyFilter::simple->new( typo => sub { } ); }; like( $@, qr/Unkown method typo/, "Incorrect method name" ); for (qw( filter begin end )) { eval { $filter = HTTP::Proxy::BodyFilter::simple->new( $_ => sub { } ); }; is( $@, '', "Accept $_" ); } $sub = sub { my ( $self, $dataref, $message, $protocol, $buffer ) = @_; $$dataref =~ s/foo/bar/g; }; $filter = HTTP::Proxy::BodyFilter::simple->new($sub); is( $filter->can('filter'), $sub, "filter() runs the correct filter" ); # test the filter for ( [ "\nfoo\n", "", "\nbar\n", "" ], ) { $filter = $_, next if ref $_ eq 'HTTP::Proxy::BodyFilter::simple'; my ( $data, $buffer ) = @$_[ 0, 1 ]; $filter->filter( \$data, undef, undef, ( defined $buffer ? \$buffer : undef ) ); is( $data, $_->[2], "Correct data" ); is( $buffer, $_->[3], "Correct buffer" ); }