From df88577ec4e5bb05893bb5ea7a76d1052d62cbd8 Mon Sep 17 00:00:00 2001 From: Dirk Wetter Date: Sat, 4 May 2019 13:51:20 +0200 Subject: [PATCH] Add basline test for IPv4 and IPv6 ... client simulations come later. One pattern for failed output added --- t/10_baseline_http.t | 72 ++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 72 insertions(+) create mode 100755 t/10_baseline_http.t diff --git a/t/10_baseline_http.t b/t/10_baseline_http.t new file mode 100755 index 0000000..b2ba7f5 --- /dev/null +++ b/t/10_baseline_http.t @@ -0,0 +1,72 @@ +#!/usr/bin/env perl + +# Just a functional test, whether there are any problems on the client side +# Probably we could also inspect the JSON for any problems for +# "id" : "scanProblem" +# "finding" : "Scan interrupted" + +use strict; +use Test::More; +use Data::Dumper; +# use JSON; + +my $tests = 0; +my $check2run ="-p -s -P --pfs -S -h -U -q --ip=one --color 0"; +my $uri=""; +my $socketout=""; +my $opensslout=""; + +# $check2run="--jsonfile tmp.json $check2run"; + + +$uri="google.com"; + +unlink "tmp.json"; +printf "\n%s\n", "Baseline unit test IPv4 via sockets --> $uri ..."; +$socketout = `./testssl.sh $check2run $uri 2>&1`; +# my $socket = json('tmp.json'); +#FIXME: This comparison is maybe not sufficient yet: +unlike($socketout, qr/(e|E)rror|\.\/testssl\.sh: line |(f|F)atal/, ""); +$tests++; + + +unlink "tmp.json"; +printf "\n%s\n", "Baseline unit test IPv4 via OpenSSL --> $uri ..."; +$opensslout = `./testssl.sh $check2run --ssl-native $uri 2>&1`; +# my $openssl = json('tmp.json'); +# This happens with Google only, so we white list a pattern here: +$opensslout =~ s/testssl.*warning: command substitution: ignored null byte in input\n//g; +#FIXME: This comparison is maybe sufficient yet: +unlike($opensslout, qr/(e|E)rror|(f|F)atal|\.\/testssl\.sh: line |Oops|s_client connect problem/, ""); +$tests++; + + +$uri="ipv6.google.com"; + +unlink "tmp.json"; +printf "\n%s\n", "Baseline unit test IPv6 via sockets --> $uri ..."; +$socketout = `./testssl.sh $check2run -6 $uri 2>&1`; +# my $socket = json('tmp.json'); +unlike($socketout, qr/(e|E)rror|\.\/testssl\.sh: line |(f|F)atal/, ""); +$tests++; + +unlink "tmp.json"; +printf "\n%s\n", "Baseline unit test IPv6 via OpenSSL --> $uri ..."; +$opensslout = `./testssl.sh --ssl-native $check2run -6 $uri 2>&1`; +# my $openssl = json('tmp.json'); +$opensslout =~ s/testssl.*warning: command substitution: ignored null byte in input\n//g; +unlike($opensslout, qr/(e|E)rror|(f|F)atal|\.\/testssl\.sh: line |Oops|s_client connect problem/, ""); +$tests++; + +done_testing($tests); +unlink "tmp.json"; + + + +sub json($) { + my $file = shift; + $file = `cat $file`; + unlink $file; + return from_json($file); +} +