From 1b4c1cc40c48dc3a581ac57762b6ae37b4b7530f Mon Sep 17 00:00:00 2001 From: David Cooper Date: Tue, 4 Apr 2017 13:25:31 -0400 Subject: [PATCH 1/2] Update testssl.sh This PR fixes two issues with HTML generation that were introduced by a commit on March 31, 2016, "[count_ciphers is now un-sed'ed, minor improvements](https://github.com/drwetter/testssl.sh/commit/a480e5f699983207651aa0a8717dc395d13e6e52)." The first is that in `std_cipherlists()`, `[[ $DEBUG -ge 1 ]] && outln " -- $1" || outln` was changed to `[[ $DEBUG -ge 1 ]] && outln " -- $1" || outln`. The result being that in the HTML output, all of the tests from `run_std_cipherlists()` appear on the same line. This PR changes the line to: ``` [[ $DEBUG -ge 1 ]] && tm_out " -- $1" outln `` so that the line break is added to the HTML output, but the debugging information is not. The second problem is that the commit on March 31 moved the call in main to `html_header()` until after the calls to `get_install_dir()`, `find_openssl_binary()`, `mybanner()`, `check4openssl_oldfarts()`, and `check_bsd_mount()`. The problem is that each of these functions may call an output function that will call `html_out()`. If `html_out()` is called before `html_header()` and the command line contains `--htmlfile `, then "htmlfile" will be written to before `html_header()` is called and then `html_header()` will warn that "htmlfile" already exists and then exit the program. If `html_out()` is called before `html_header()` and the command line contains `--html`, then anything send to `html_out()` before `html_header()` is called (such as the banner) will not appear in the HTML file. --- testssl.sh | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/testssl.sh b/testssl.sh index c9a7ff0..38f5174 100755 --- a/testssl.sh +++ b/testssl.sh @@ -2493,7 +2493,8 @@ std_cipherlists() { ;; esac tmpfile_handle $FUNCNAME.$debugname.txt - [[ $DEBUG -ge 1 ]] && tmln_out " -- $1" || tmln_out + [[ $DEBUG -ge 1 ]] && tm_out " -- $1" + outln else singlespaces=$(sed -e 's/ \+/ /g' -e 's/^ //' -e 's/ $//g' -e 's/ //g' <<< "$2") if [[ "$OPTIMAL_PROTO" == "-ssl2" ]]; then @@ -12498,6 +12499,7 @@ ip="" lets_roll init initialize_globals parse_cmd_line "$@" +html_header get_install_dir set_color_functions maketempf @@ -12510,7 +12512,6 @@ check4openssl_oldfarts check_bsd_mount json_header csv_header -html_header if "$do_display_only"; then prettyprint_local "$PATTERN2SHOW" From 7549f10c792fd4434f6a9f6fa8bc07fa696bfabc Mon Sep 17 00:00:00 2001 From: Dirk Date: Tue, 4 Apr 2017 20:23:28 +0200 Subject: [PATCH 2/2] added explanation for #692 --- testssl.sh | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/testssl.sh b/testssl.sh index 38f5174..207cfbc 100755 --- a/testssl.sh +++ b/testssl.sh @@ -12499,7 +12499,12 @@ ip="" lets_roll init initialize_globals parse_cmd_line "$@" +# html_header() needs to be called early! Otherwiseif html_out() is called before html_header() and the +# command line contains --htmlfile or --html, it'll make problems with html output, see #692. +# json_header and csv_header can be called later but for context reasons we'll leave it here html_header +json_header +csv_header get_install_dir set_color_functions maketempf @@ -12510,8 +12515,6 @@ mybanner check_proxy check4openssl_oldfarts check_bsd_mount -json_header -csv_header if "$do_display_only"; then prettyprint_local "$PATTERN2SHOW"