X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=t%2Flib%2Fcgi-html.t;h=50c840816bd2666426758bd53487db857d2f84c6;hb=22d4bb9ccb8701e68f9243547d7e3a3c55f70908;hp=1e20a315fafc02235f153c726873603b5c9b0a5f;hpb=4b19af017623bfa3bb72bb164598a517f586e0d3;p=p5sagit%2Fp5-mst-13.2.git
diff --git a/t/lib/cgi-html.t b/t/lib/cgi-html.t
index 1e20a31..50c8408 100755
--- a/t/lib/cgi-html.t
+++ b/t/lib/cgi-html.t
@@ -1,14 +1,14 @@
-#!./perl
-
-# Test ability to retrieve HTTP request info
-######################### We start with some black magic to print on failure.
+#!/usr/local/bin/perl -w
BEGIN {
- chdir 't' if -d 't';
- unshift @INC, '../lib' if -d '../lib';
- require Config; import Config;
+ chdir('t') if -d 't';
+ @INC = '../lib';
}
+# Test ability to retrieve HTTP request info
+######################### We start with some black magic to print on failure.
+use lib '../blib/lib','../blib/arch';
+
BEGIN {$| = 1; print "1..24\n"; }
END {print "not ok 1\n" unless $loaded;}
use CGI (':standard','-no_debug','*h3','start_table');
@@ -17,8 +17,14 @@ print "ok 1\n";
######################### End of black magic.
-my $Is_EBCDIC = $Config{'ebcdic'} eq 'define';
-my $crlf = $CGI::CRLF;
+my $CRLF = "\015\012";
+if ($^O eq 'VMS') {
+ $CRLF = "\n"; # via web server carriage is inserted automatically
+}
+if (ord("\t") != 9) { # EBCDIC?
+ $CRLF = "\r\n";
+}
+
# util
sub test {
@@ -28,53 +34,55 @@ sub test {
}
# all the automatic tags
-test(2,h1() eq '
',"single tag");
-test(3,h1('fred') eq 'fred
',"open/close tag");
-test(4,h1('fred','agnes','maura') eq 'fred agnes maura
',"open/close tag multiple");
-test(5,h1({-align=>'CENTER'},'fred') eq 'fred
',"open/close tag with attribute");
-test(6,h1({-align=>undef},'fred') eq 'fred
',"open/close tag with orphan attribute");
+test(2,h1() eq '',"single tag");
+test(3,h1('fred') eq 'fred
',"open/close tag");
+test(4,h1('fred','agnes','maura') eq 'fred agnes maura
',"open/close tag multiple");
+test(5,h1({-align=>'CENTER'},'fred') eq 'fred
',"open/close tag with attribute");
+test(6,h1({-align=>undef},'fred') eq 'fred
',"open/close tag with orphan attribute");
test(7,h1({-align=>'CENTER'},['fred','agnes']) eq
- 'fred
agnes
',
+ 'fred
agnes
',
"distributive tag with attribute");
{
local($") = '-';
- test(8,h1('fred','agnes','maura') eq 'fred-agnes-maura
',"open/close tag \$\" interpolation");
+ test(8,h1('fred','agnes','maura') eq 'fred-agnes-maura
',"open/close tag \$\" interpolation");
}
-
-test(9,header() eq "Content-Type: text/html; charset=ISO-8859-1$crlf$crlf","header()");
-test(10,header(-type=>'image/gif') eq "Content-Type: image/gif; charset=ISO-8859-1$crlf$crlf","header()");
-test(11,header(-type=>'image/gif',-status=>'500 Sucks') eq "Status: 500 Sucks${crlf}Content-Type: image/gif; charset=ISO-8859-1$crlf$crlf","header()");
-test(12,header(-nph=>1) eq "HTTP/1.0 200 OK${crlf}Content-Type: text/html; charset=ISO-8859-1$crlf$crlf","header()");
+test(9,header() eq "Content-Type: text/html; charset=ISO-8859-1${CRLF}${CRLF}","header()");
+test(10,header(-type=>'image/gif') eq "Content-Type: image/gif${CRLF}${CRLF}","header()");
+test(11,header(-type=>'image/gif',-status=>'500 Sucks') eq "Status: 500 Sucks${CRLF}Content-Type: image/gif${CRLF}${CRLF}","header()");
+test(12,header(-nph=>1) eq "HTTP/1.0 200 OK${CRLF}Content-Type: text/html; charset=ISO-8859-1${CRLF}${CRLF}","header()");
test(13,start_html() ."\n" eq <
-Untitled Document
-
+
+Untitled Document
+
END
;
test(14,start_html(-dtd=>"-//IETF//DTD HTML 3.2//FR") ."\n" eq <
-Untitled Document
-
+
+Untitled Document
+
END
;
test(15,start_html(-Title=>'The world of foo') ."\n" eq <
-The world of foo
-
+
+The world of foo
+
END
;
-test(16,($cookie=cookie(-name=>'fred',-value=>['chocolate','chip'],-path=>'/')) eq
- 'fred=chocolate&chip; path=/',"cookie()");
-test(17,header(-Cookie=>$cookie) =~ m!^Set-Cookie: fred=chocolate&chip\; path=/${crlf}Date:.*${crlf}Content-Type: text/html$crlf$crlf!s,
- "header(-cookie)");
-test(18,start_h3 eq '');
-test(19,end_h3 eq '
');
-test(20,start_table({-border=>undef}) eq '');
-test(21,h1(escapeHTML("this is \x8bright\x9b")) eq 'this is <not> right
');
+test(16,($cookie=cookie(-name=>'fred',-value=>['chocolate','chip'],-path=>'/')) eq 'fred=chocolate&chip; path=/',"cookie()");
+my $h = header(-Cookie=>$cookie);
+test(17,$h =~ m!^Set-Cookie: fred=chocolate&chip\; path=/${CRLF}Date:.*${CRLF}Content-Type: text/html; charset=ISO-8859-1${CRLF}${CRLF}!s,
+ "header(-cookie)");
+test(18,start_h3 eq '');
+test(19,end_h3 eq '
');
+test(20,start_table({-border=>undef}) eq '');
+test(21,h1(escapeHTML("this is \x8bright\x9b")) eq 'this is <not> right
');
charset('utf-8');
-test(22,h1(escapeHTML("this is \x8bright\x9b")) eq 'this is <not> right
');
-test(23,i(p('hello there')) eq 'hello there
');
+test(22,h1(escapeHTML("this is \x8bright\x9b")) eq 'this is <not> right
');
+test(23,i(p('hello there')) eq 'hello there
');
my $q = new CGI;
-test(24,$q->h1('hi') eq 'hi
');
+test(24,$q->h1('hi') eq 'hi
');