my $debug = shift @ARGV;
-use Test::More tests => 53;
+use Test::More tests => 73;
use Data::Dump qw/dump/;
use Cwd qw/abs_path/;
use File::Slurp;
use blib;
+# XML::Rules doesn't like it!
+#use Devel::LeakTrace::Fast;
+
BEGIN {
use_ok('CWMP::Request');
}
ok(my $abs_path = abs_path($0), "abs_path");
$abs_path =~ s!/[^/]*$!/!; #!fix-vim
+my $path2method;
+my $triggers_count;
+
sub file_is_deeply {
my ( $path ) = @_;
diag $xml if $debug;
+ ok( my $trigger = $path2method->{$path}, "path2method($path)" );
+
+ CWMP::Request->add_trigger( name => $trigger, callback => sub {
+ my ( $self, $state ) = @_;
+ $triggers_count->{$trigger}++;
+ ok( $state, "called trigger $trigger" );
+ });
+
ok( my $state = CWMP::Request->parse( $xml ), 'parse' );
my $dump_path = $path;
my $dir = "$abs_path/$model/";
opendir(DIR, $dir) || die "can't opendir $dir: $!";
- my @xmls = map { "$dir/$_" } grep { /\.xml$/ && -f "$dir/$_" } readdir(DIR);
+ my @xmls = map {
+ my $path = "$dir/$_";
+ my $method = $_;
+ $method =~ s/\.xml$//;
+ $path2method->{$path} = $method;
+ $path;
+ } grep { /\.xml$/ && -f "$dir/$_" } readdir(DIR);
closedir DIR;
diag "$model has ", $#xmls + 1, " xml tests";
}
}
+diag "triggers_count = ",dump( $triggers_count ) if $debug;
+