diff options
author | Cris Bailiff <c.bailiff@awayweb.com> | 2001-09-20 09:48:52 +0000 |
---|---|---|
committer | Cris Bailiff <c.bailiff@awayweb.com> | 2001-09-20 09:48:52 +0000 |
commit | 611fbfa917846e1cf1ebd3e9f965cd857f67081c (patch) | |
tree | 6d764973590b8c24cc03d5eee3470c6144e16340 /perl/Curl_easy/t/03body-callback.t | |
parent | ecfacfb33492ab13a12c5b4e0eb0b06385f1de9b (diff) |
Commit Curl_easy v1.1.8 - constants updated for libcurl 7.9 - tests modularised
Diffstat (limited to 'perl/Curl_easy/t/03body-callback.t')
-rw-r--r-- | perl/Curl_easy/t/03body-callback.t | 105 |
1 files changed, 105 insertions, 0 deletions
diff --git a/perl/Curl_easy/t/03body-callback.t b/perl/Curl_easy/t/03body-callback.t new file mode 100644 index 000000000..94786f507 --- /dev/null +++ b/perl/Curl_easy/t/03body-callback.t @@ -0,0 +1,105 @@ +# Test script for Perl extension Curl::easy. +# Check out the file README for more info. + +# Before `make install' is performed this script should be runnable with +# `make t/thisfile.t'. After `make install' it should work as `perl thisfile.t' + +######################### We start with some black magic to print on failure. + +# Change 1..1 below to 1..last_test_to_print . +use strict; + +BEGIN { $| = 1; print "1..9\n"; } +END {print "not ok 1\n" unless $::loaded;} +use Curl::easy; + +$::loaded = 1; +print "ok 1\n"; + +######################### End of black magic. + +# Insert your test code below (better if it prints "ok 13" +# (correspondingly "not ok 13") depending on the success of chunk 13 +# of the test code): + +my $count=1; + +# Read URL to get +my $defurl = "http://localhost/cgi-bin/printenv"; +my $url; +if (defined ($ENV{CURL_TEST_URL})) { + $url=$ENV{CURL_TEST_URL}; +} else { +$url = ""; +print "Please enter an URL to fetch [$defurl]: "; +$url = <STDIN>; +if ($url =~ /^\s*\n/) { + $url = $defurl; +} +} + +# Init the curl session +my $curl = Curl::easy::init(); +if ($curl == 0) { + print "not "; +} +print "ok ".++$count."\n"; + +Curl::easy::setopt($curl, CURLOPT_NOPROGRESS, 1); +Curl::easy::setopt($curl, CURLOPT_MUTE, 1); +Curl::easy::setopt($curl, CURLOPT_FOLLOWLOCATION, 1); +Curl::easy::setopt($curl, CURLOPT_TIMEOUT, 30); + +open HEAD, ">head.out"; +Curl::easy::setopt($curl, CURLOPT_WRITEHEADER, *HEAD); +print "ok ".++$count."\n"; + +open BODY, ">body.out"; +Curl::easy::setopt($curl, CURLOPT_FILE,*BODY); +print "ok ".++$count."\n"; + +my $errbuf; +Curl::easy::setopt($curl, CURLOPT_ERRORBUFFER, "errbuf"); +print "ok ".++$count."\n"; + +Curl::easy::setopt($curl, CURLOPT_URL, $url); + +print "ok ".++$count."\n"; + +# The header callback will only be called if your libcurl has the +# CURLOPT_HEADERFUNCTION supported, otherwise your headers +# go to CURLOPT_WRITEFUNCTION instead... +# + +my $header_called=0; +sub header_callback { print STDERR "header callback called\n"; $header_called=1; return length($_[0])}; + +# test for sub reference and head callback +Curl::easy::setopt($curl, CURLOPT_HEADERFUNCTION, \&header_callback); + +my $body_called=0; +sub body_callback { + my ($chunk,$handle)=@_; + print STDERR "body callback called with ",length($chunk)," bytes\n"; + print STDERR "data=$chunk\n"; + $body_called++; + return length($chunk); # OK +} + + +# test for ref to sub and body callback +my $body_ref=\&body_callback; +Curl::easy::setopt($curl, CURLOPT_WRITEFUNCTION, $body_ref); + +if (Curl::easy::perform($curl) != 0) { + print "not "; +}; +print "ok ".++$count."\n"; + + +print STDERR "next test will fail on libcurl < 7.7.2\n"; +print STDERR "not " if (!$header_called); # ok if you have a libcurl <7.7.2 +print "ok ".++$count."\n"; + +print "not " if (!$body_called); +print "ok ".++$count."\n"; |