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

');