5 my $debug = shift @ARGV;
7 use Test::More tests => 73;
8 use Data::Dump qw/dump/;
13 #use Devel::LeakTrace::Fast;
16 use_ok('CWMP::Request');
19 my @models = ( qw/SpeedTouch-706 SpeedTouch-780/ );
21 ok( $#models + 1, 'got models' );
23 ok(my $abs_path = abs_path($0), "abs_path");
24 $abs_path =~ s!/[^/]*$!/!; #!fix-vim
32 ok( my $xml = read_file( $path ), "read_file( $path )" );
36 ok( my $trigger = $path2method->{$path}, "path2method($path)" );
38 CWMP::Request->add_trigger( name => $trigger, callback => sub {
39 my ( $self, $state ) = @_;
40 $triggers_count->{$trigger}++;
41 ok( $state, "called trigger $trigger" );
44 ok( my $state = CWMP::Request->parse( $xml ), 'parse' );
46 my $dump_path = $path;
47 $dump_path =~ s/\.xml/\.pl/;
49 write_file( $dump_path, dump( $state ) ) unless ( -e $dump_path );
51 diag "$path ? $dump_path" if $debug;
53 ok( my $hash = read_file( $dump_path ), "read_file( $dump_path )" );
54 ok ( $hash = eval "$hash", 'eval' );
56 is_deeply( $state, $hash, 'same' );
59 foreach my $model ( @models ) {
61 my $dir = "$abs_path/$model/";
62 opendir(DIR, $dir) || die "can't opendir $dir: $!";
66 $method =~ s/\.xml$//;
67 $path2method->{$path} = $method;
69 } grep { /\.xml$/ && -f "$dir/$_" } readdir(DIR);
72 diag "$model has ", $#xmls + 1, " xml tests";
76 foreach my $xml_path ( @xmls ) {
77 ok ( $xml_path, 'xml path' );
78 file_is_deeply( $xml_path );
82 diag "triggers_count = ",dump( $triggers_count ) if $debug;