2010-06-04 05:12:19 -04:00
|
|
|
#!/usr/bin/env perl
|
2009-09-06 16:04:22 -04:00
|
|
|
|
|
|
|
use strict;
|
|
|
|
use warnings;
|
|
|
|
|
|
|
|
use FTPTest;
|
|
|
|
|
|
|
|
# This file exercises a problem in Wget, where if an error was
|
|
|
|
# encountered in ftp.c:getftp before the actual file download
|
|
|
|
# had started, Wget would believe that it had already downloaded the
|
|
|
|
# full contents of the file, and would send a corresponding (erroneous)
|
|
|
|
# REST value.
|
|
|
|
|
|
|
|
###############################################################################
|
|
|
|
|
|
|
|
# From bug report. :)
|
|
|
|
my $afile = <<EOF;
|
|
|
|
I've included log output (using the -d switch) from when this happens
|
|
|
|
below. You'll see that for the retry wget sends a REST command to
|
|
|
|
reset the start position before starting the RETR command. I'm
|
|
|
|
confused about the argument to REST: 51132. It's the full length in
|
|
|
|
bytes of the file to be retrieved. The RETR then shows the entire
|
|
|
|
contents of the file being skipped, and wget announces that it
|
|
|
|
successfully retrieved and saved 0 bytes.
|
|
|
|
EOF
|
|
|
|
|
|
|
|
$afile =~ s/\n/\r\n/g;
|
|
|
|
|
|
|
|
|
|
|
|
# code, msg, headers, content
|
|
|
|
my %urls = (
|
|
|
|
'/afile.txt' => {
|
|
|
|
content => $afile,
|
|
|
|
},
|
|
|
|
);
|
|
|
|
|
|
|
|
my $cmdline = $WgetTest::WGETPATH . " -S ftp://localhost:{{port}}/afile.txt";
|
|
|
|
|
|
|
|
my $expected_error_code = 0;
|
|
|
|
|
|
|
|
my %expected_downloaded_files = (
|
|
|
|
'afile.txt' => {
|
|
|
|
content => $afile,
|
|
|
|
},
|
|
|
|
);
|
|
|
|
|
|
|
|
###############################################################################
|
|
|
|
|
|
|
|
my $the_test = FTPTest->new (name => "Test-ftp-pasv-fail",
|
|
|
|
server_behavior => {fail_on_pasv => 1},
|
2009-09-21 23:39:44 -04:00
|
|
|
input => \%urls,
|
|
|
|
cmdline => $cmdline,
|
|
|
|
errcode => $expected_error_code,
|
2009-09-06 16:04:22 -04:00
|
|
|
output => \%expected_downloaded_files);
|
|
|
|
exit $the_test->run();
|
|
|
|
|
|
|
|
# vim: et ts=4 sw=4
|