# but earlier versions of File::CheckTree did not do this either
# split a line like "/foo -r || die"
- # so that $file is "/foo", $test is "-rwx || die"
- ($file, $test) = split(' ', $check, 2); # special whitespace split
+ # so that $file is "/foo", $test is "-r || die"
+ # (making special allowance for quoted filenames).
+ if ($check =~ m/^\s*"([^"]+)"\s+(.*?)\s*$/ or
+ $check =~ m/^\s*'([^']+)'\s+(.*?)\s*$/ or
+ $check =~ m/^\s*(\S+?)\s+(\S.*?)\s*$/)
+ {
+ ($file, $test) = ($1,$2);
+ }
+ else {
+ die "Malformed line: '$check'";
+ };
# change a $test like "!-ug || die" to "!-Z || die",
# capturing the bundled tests (e.g. "ug") in $2
eval $this;
# re-raise an exception caused by a "... || die" test
- if ($@) {
+ if (my $err = $@) {
# in case of any cd directives, return from whence we came
if ($starting_dir ne cwd) {
chdir($starting_dir) || die "$starting_dir: $!";
}
- die $@ if $@;
+ die $err;
}
}
use Test;
-BEGIN { plan tests => 6 }
+BEGIN { plan tests => 8 }
use strict;
# indented comment, followed blank line (w/o whitespace):
README -f
- $path_to_README -e || warn
+ '$path_to_README' -e || warn
};
};
+ print STDERR $_ for @warnings;
if ( !$@ && !@warnings && defined($num_warnings) && $num_warnings == 0 ) {
ok(1);
}
ok(0);
}
}
+
+#### TEST 7 -- Quoted file names ####
+{
+ my $num_warnings;
+ eval {
+ $num_warnings = validate q{
+ "a file with whitespace" !-ef
+ 'a file with whitespace' !-ef
+ };
+ };
+
+ if ( !$@ ) {
+ # No errors mean we compile correctly
+ ok(1);
+ } else {
+ ok(0);
+ print STDERR $@;
+ };
+}
+
+#### TEST 8 -- Malformed query ####
+{
+ my $num_warnings;
+ eval {
+ $num_warnings = validate q{
+ a file with whitespace !-ef
+ };
+ };
+
+ if ( $@ =~ /syntax error/) {
+ # We got a syntax error for a malformed file query
+ ok(1);
+ } else {
+ ok(0);
+ };
+}