aboutsummaryrefslogtreecommitdiff
path: root/tests/httpsserver.pl
diff options
context:
space:
mode:
authorDaniel Stenberg <daniel@haxx.se>2001-04-24 21:09:53 +0000
committerDaniel Stenberg <daniel@haxx.se>2001-04-24 21:09:53 +0000
commit4ddb3fbbf431c21e68a9a221324108c83cf31544 (patch)
tree4f3838ab1c6249067b2096c14abb991911621d21 /tests/httpsserver.pl
parentcc872ebc192f64aa6360853fbdbf0476d05b9178 (diff)
new tests, new server invoke system
Diffstat (limited to 'tests/httpsserver.pl')
-rw-r--r--tests/httpsserver.pl51
1 files changed, 51 insertions, 0 deletions
diff --git a/tests/httpsserver.pl b/tests/httpsserver.pl
new file mode 100644
index 000000000..1483f2bc4
--- /dev/null
+++ b/tests/httpsserver.pl
@@ -0,0 +1,51 @@
+#!/usr/bin/perl
+#
+# $Id$
+# This is the HTTPS server designed for the curl test suite.
+#
+# It is actually just a layer that runs stunnel properly.
+
+use strict;
+
+use stunnel;
+
+my $stunnel = &checkstunnel;
+
+if(!$stunnel) {
+ exit;
+}
+
+#
+# -p pemfile
+# -P pid dir
+# -d listen port
+# -r target port
+
+my $verbose=0; # set to 1 for debugging
+
+my $port = 8433; # just a default
+my $http = 8999; # http-port
+do {
+ if($ARGV[0] eq "-v") {
+ $verbose=1;
+ }
+ if($ARGV[0] eq "-w") {
+ return 0; # return success, means we have stunnel working!
+ }
+ elsif($ARGV[0] eq "-r") {
+ $http=$ARGV[1];
+ shift @ARGV;
+ }
+ elsif($ARGV[0] =~ /^(\d+)$/) {
+ $port = $1;
+ }
+} while(shift @ARGV);
+
+my $path = `pwd`;
+chomp $path;
+my $cmd = "$stunnel -p $path/data/stunnel.pem -P $path/.https.pid -d $port -r $http";
+
+if($verbose) {
+ print "$cmd\n";
+}
+system($cmd);