mirror of
https://github.com/moparisthebest/wget
synced 2024-07-03 16:38:41 -04:00
Test for IDN, based on meta-specified encoding.
This commit is contained in:
parent
ab0b0a4090
commit
171c71e09c
@ -3,9 +3,9 @@
|
|||||||
* HTTPServer.pm (run): Allow distinguishing between hostnames,
|
* HTTPServer.pm (run): Allow distinguishing between hostnames,
|
||||||
when used as a proxy.
|
when used as a proxy.
|
||||||
|
|
||||||
* Test-idn-headers.px: Added.
|
* Test-idn-headers.px, Test-idn-meta.px: Added.
|
||||||
|
|
||||||
* run-px: Added Test-idn-headers.px.
|
* run-px: Added Test-idn-headers.px, Test-idn-meta.px.
|
||||||
|
|
||||||
* Test-proxy-auth-basic.px: Use the full URL, rather than just the
|
* Test-proxy-auth-basic.px: Use the full URL, rather than just the
|
||||||
path (made necessary by the accompanying change to HTTPServer.pm).
|
path (made necessary by the accompanying change to HTTPServer.pm).
|
||||||
|
66
tests/Test-idn-meta.px
Executable file
66
tests/Test-idn-meta.px
Executable file
@ -0,0 +1,66 @@
|
|||||||
|
#!/usr/bin/perl -w
|
||||||
|
|
||||||
|
use strict;
|
||||||
|
|
||||||
|
use HTTPTest;
|
||||||
|
|
||||||
|
# " Kon'nichiwa <dot> Japan
|
||||||
|
my $euc_jp_hostname = "\272\243\306\374\244\317.\306\374\313\334";
|
||||||
|
my $punycoded_hostname = 'xn--v9ju72g90p.xn--wgv71a';
|
||||||
|
|
||||||
|
###############################################################################
|
||||||
|
|
||||||
|
my $starter_file = <<EOF;
|
||||||
|
<meta http-equiv="Content-Type" content="text/html; charset=EUC-JP" />
|
||||||
|
<a href="http://$euc_jp_hostname/">The link</a>
|
||||||
|
EOF
|
||||||
|
|
||||||
|
my $result_file = <<EOF;
|
||||||
|
Found me!
|
||||||
|
EOF
|
||||||
|
|
||||||
|
# code, msg, headers, content
|
||||||
|
my %urls = (
|
||||||
|
'http://start-here.com/start.html' => {
|
||||||
|
code => "200",
|
||||||
|
msg => "You want fries with that?",
|
||||||
|
headers => {
|
||||||
|
'Content-Type' => 'text/html; charset=UTF-8',
|
||||||
|
},
|
||||||
|
content => $starter_file,
|
||||||
|
},
|
||||||
|
"http://$punycoded_hostname/index.html" => {
|
||||||
|
code => "200",
|
||||||
|
msg => "Yes, please",
|
||||||
|
headers => {
|
||||||
|
'Content-Type' => 'text/plain',
|
||||||
|
},
|
||||||
|
content => $result_file,
|
||||||
|
},
|
||||||
|
);
|
||||||
|
|
||||||
|
my $cmdline = $WgetTest::WGETPATH . " --debug --iri -rH"
|
||||||
|
. " -e http_proxy=localhost:{{port}} http://start-here.com/start.html";
|
||||||
|
|
||||||
|
my $expected_error_code = 0;
|
||||||
|
|
||||||
|
my %expected_downloaded_files = (
|
||||||
|
'start-here.com/start.html' => {
|
||||||
|
content => $starter_file,
|
||||||
|
},
|
||||||
|
"$punycoded_hostname/index.html" => {
|
||||||
|
content => $result_file,
|
||||||
|
},
|
||||||
|
);
|
||||||
|
|
||||||
|
###############################################################################
|
||||||
|
|
||||||
|
my $the_test = HTTPTest->new (name => "Test-iri-meta",
|
||||||
|
input => \%urls,
|
||||||
|
cmdline => $cmdline,
|
||||||
|
errcode => $expected_error_code,
|
||||||
|
output => \%expected_downloaded_files);
|
||||||
|
exit $the_test->run();
|
||||||
|
|
||||||
|
# vim: et ts=4 sw=4
|
||||||
|
|
@ -24,6 +24,7 @@ my @tests = (
|
|||||||
'Test-HTTP-Content-Disposition-2.px',
|
'Test-HTTP-Content-Disposition-2.px',
|
||||||
'Test-HTTP-Content-Disposition.px',
|
'Test-HTTP-Content-Disposition.px',
|
||||||
'Test-idn-headers.px',
|
'Test-idn-headers.px',
|
||||||
|
'Test-idn-meta.px',
|
||||||
'Test-iri.px',
|
'Test-iri.px',
|
||||||
'Test-iri-disabled.px',
|
'Test-iri-disabled.px',
|
||||||
'Test-iri-forced-remote.px',
|
'Test-iri-forced-remote.px',
|
||||||
|
Loading…
Reference in New Issue
Block a user