Compare commits
	
		
			3 Commits
		
	
	
		
			master
			...
			remote-tes
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 61315d377e | ||
|  | 7daa85cd32 | ||
|  | 90b2f93de6 | 
							
								
								
									
										88
									
								
								urchin
									
									
									
									
									
								
							
							
						
						
									
										88
									
								
								urchin
									
									
									
									
									
								
							| @@ -149,14 +149,23 @@ fi | |||||||
| stdout_file() { | stdout_file() { | ||||||
|   the_test="${1}" |   the_test="${1}" | ||||||
|   the_shell="${2}" |   the_shell="${2}" | ||||||
|  |   host="${3}" | ||||||
|  |  | ||||||
|  |   if test -n "${host}"; then | ||||||
|  |     # This assumes the tests ran on a remote and have been copied. | ||||||
|  |     x="${urchin_tmp}/remote/${host}/stdout${the_test}" | ||||||
|  |   else | ||||||
|  |     # This can be run during the tests. | ||||||
|  |     x="${urchin_tmp}/stdout$(fullpath "$the_test")" | ||||||
|  |     mkdir -p "${x}" | ||||||
|  |   fi | ||||||
|  |  | ||||||
|   x="${urchin_tmp}/stdout$(fullpath "$the_test")" |  | ||||||
|   mkdir -p "${x}" |  | ||||||
|   case "${urchin_md5}" in |   case "${urchin_md5}" in | ||||||
|     md5sum) y=$(echo "${the_shell}" | md5sum | cut -d\  -f1) ;; |     md5sum) y=$(echo "${the_shell}" | md5sum | cut -d\  -f1) ;; | ||||||
|     md5) y=$(echo "${the_shell}" | md5 | sed 's/.* //') ;; |     md5) y=$(echo "${the_shell}" | md5 | sed 's/.* //') ;; | ||||||
|     *) echo md5 command is not configured >&2; urchin_exit 1;; |     *) echo md5 command is not configured >&2; urchin_exit 1;; | ||||||
|   esac |   esac | ||||||
|  |  | ||||||
|   echo "${x}/${y}" |   echo "${x}/${y}" | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -353,16 +362,23 @@ report_outcome() { | |||||||
|   start="${4}" |   start="${4}" | ||||||
|   finish="${5}" |   finish="${5}" | ||||||
|  |  | ||||||
|  |   host="${6}" | ||||||
|  |   if test -n "${host}"; then | ||||||
|  |     onhost=" on ${host}" | ||||||
|  |   fi | ||||||
|  |  | ||||||
|   escaped_root="$(fullpath "${root}" | sed 's/\//\\\//g')" |   escaped_root="$(fullpath "${root}" | sed 's/\//\\\//g')" | ||||||
|   elapsed=$(($finish - $start)) |   elapsed=$(($finish - $start)) | ||||||
|  |  | ||||||
|   if "${tap_format}"; then |  | ||||||
|     printf \#\  |  | ||||||
|   fi |  | ||||||
|   if "${print_margins}" || "${tap_format}"; then |   if "${print_margins}" || "${tap_format}"; then | ||||||
|     echo Running tests at $(date +%Y-%m-%dT%H:%M:%S) |     if $tap_format; then printf \#\ ; fi | ||||||
|  |     echo Ran tests at $(date +%Y-%m-%dT%H:%M:%S) with the following shells: | ||||||
|  |     if $tap_format; then printf \#\ ; fi | ||||||
|  |     cat "${shell_list}" | tr '\n' \  | ||||||
|  |     echo | ||||||
|   fi |   fi | ||||||
|  |  | ||||||
|  |  | ||||||
|   for number in n oks skips not_oks; do |   for number in n oks skips not_oks; do | ||||||
|     eval "${number}=0" |     eval "${number}=0" | ||||||
|   done |   done | ||||||
| @@ -402,13 +418,13 @@ report_outcome() { | |||||||
|       fi |       fi | ||||||
|  |  | ||||||
|       if test -z "${the_shell}"; then |       if test -z "${the_shell}"; then | ||||||
|         the_shell='File is not executable.' |         the_shell='File is not executable' | ||||||
|       fi |       fi | ||||||
|       echo "${not}ok $n - ${path} (${the_shell}) ${skip}" |       echo "${not}ok $n - ${path} (${the_shell}${onhost}) ${skip}" | ||||||
|       if { test "${result}" = not_ok && "${print_not_ok_stdout}"; } || |       if { test "${result}" = not_ok && "${print_not_ok_stdout}"; } || | ||||||
|          { test "${result}" = ok && "${print_ok_stdout}"; }; then |          { test "${result}" = ok && "${print_ok_stdout}"; }; then | ||||||
|         echo '# ------------ Begin output ------------' |         echo '# ------------ Begin output ------------' | ||||||
|         sed 's/^/# /' "$(stdout_file "${abspath}" "${the_shell}")" |         sed 's/^/# /' "$(stdout_file "${abspath}" "${the_shell}" "${host}")" | ||||||
|         echo '# ------------ End output ------------' |         echo '# ------------ End output ------------' | ||||||
|       fi |       fi | ||||||
|       echo "# Previous test took ${file_elapsed} seconds." |       echo "# Previous test took ${file_elapsed} seconds." | ||||||
| @@ -431,7 +447,7 @@ report_outcome() { | |||||||
|             else |             else | ||||||
|               printf "${success_mark} " |               printf "${success_mark} " | ||||||
|             fi |             fi | ||||||
|             echo "${the_shell} ("${file_elapsed}" $(plural second $file_elapsed))" |             echo "${the_shell}${onhost} (${file_elapsed} $(plural second $file_elapsed))" | ||||||
|           fi |           fi | ||||||
|         ;; |         ;; | ||||||
|         not_ok) |         not_ok) | ||||||
| @@ -442,23 +458,23 @@ report_outcome() { | |||||||
|             else |             else | ||||||
|               printf "${fail_mark} " |               printf "${fail_mark} " | ||||||
|             fi |             fi | ||||||
|             echo "${the_shell} ("${file_elapsed}" $(plural second $file_elapsed))" |             echo "${the_shell}${onhost} (${file_elapsed} $(plural second $file_elapsed))" | ||||||
|           fi |           fi | ||||||
|         ;; |         ;; | ||||||
|         skip) |         skip) | ||||||
|           if "${print_ok}"; then |           if "${print_ok}"; then | ||||||
|             header |             header | ||||||
|             if test -z "${the_shell}"; then |             if test -z "${the_shell}"; then | ||||||
|               echo '  (File is not executable.)' |               echo "  (File is not executable${onhost}.)" | ||||||
|             else |             else | ||||||
|               echo "  ${the_shell} ("${file_elapsed}" $(plural second $file_elapsed))" |               echo "  ${the_shell}${onhost} (${file_elapsed} $(plural second $file_elapsed))" | ||||||
|             fi |             fi | ||||||
|           fi |           fi | ||||||
|         ;; |         ;; | ||||||
|       esac |       esac | ||||||
|       if { test "${result}" = not_ok && "${print_not_ok_stdout}"; } || |       if { test "${result}" = not_ok && "${print_not_ok_stdout}"; } || | ||||||
|          { test "${result}" = ok && "${print_ok_stdout}"; }; then |          { test "${result}" = ok && "${print_ok_stdout}"; }; then | ||||||
|         sed 's/^/  | /' "$(stdout_file "${abspath}" "${the_shell}")" |         sed 's/^/  | /' "$(stdout_file "${abspath}" "${the_shell}" "${host}")" | ||||||
|       fi |       fi | ||||||
|     fi |     fi | ||||||
|  |  | ||||||
| @@ -588,10 +604,13 @@ validate_strings() { | |||||||
| } | } | ||||||
|  |  | ||||||
| main() { | main() { | ||||||
|  |   argv="$@" | ||||||
|  |  | ||||||
|   cycle_shell=true |   cycle_shell=true | ||||||
|   shell_list="${urchin_tmp}"/shell_list |   shell_list="${urchin_tmp}"/shell_list | ||||||
|   test_arg_list="${urchin_tmp}"/test_list |   test_arg_list="${urchin_tmp}"/test_list | ||||||
|   > "${test_arg_list}" |   > "${test_arg_list}" | ||||||
|  |   remotes_list="${urchin_tmp}"/remotes | ||||||
|   run_in_series=false |   run_in_series=false | ||||||
|   force=false |   force=false | ||||||
|   exit_on_not_ok=false |   exit_on_not_ok=false | ||||||
| @@ -697,15 +716,6 @@ main() { | |||||||
|     fi |     fi | ||||||
|   fi |   fi | ||||||
|  |  | ||||||
|   if $print_margins; then |  | ||||||
|     if $tap_format; then |  | ||||||
|       printf '# ' |  | ||||||
|     fi |  | ||||||
|     printf 'Cycling with the following shells: ' |  | ||||||
|     cat "${shell_list}" | tr '\n' \  |  | ||||||
|     echo |  | ||||||
|   fi |  | ||||||
|  |  | ||||||
|   if test -n "${urchin_timeout}"; then |   if test -n "${urchin_timeout}"; then | ||||||
|     # Choose the timeout command |     # Choose the timeout command | ||||||
|     if timeout -t 0 true 2> /dev/null; then |     if timeout -t 0 true 2> /dev/null; then | ||||||
| @@ -741,9 +751,35 @@ main() { | |||||||
|     urchin_exit 1 |     urchin_exit 1 | ||||||
|   fi |   fi | ||||||
|      |      | ||||||
|   report_outcome "${root}" "${tap_format}" "${urchin_tmp}"/log "${start}" \ |   if test -n "${RUNNING_ON_REMOTE}"; then | ||||||
|     "${finish}" |     echo "${urchin_tmp}" | ||||||
|   urchin_exit "${?}" |   elif test -f "${remotes_list}"; then | ||||||
|  |     while read remote; do | ||||||
|  |       remote_main $remote "${argv}" | ||||||
|  |     done < "${remotes_list}" | ||||||
|  |   else | ||||||
|  |     report_outcome "${root}" "${tap_format}" "${urchin_tmp}"/log \ | ||||||
|  |       "${start}" "${finish}" | ||||||
|  |     urchin_exit "${?}" | ||||||
|  |   fi | ||||||
|  | } | ||||||
|  |  | ||||||
|  | remote_main() { | ||||||
|  |   hostname="${1}"; shift | ||||||
|  |   flags="${1}"; shift | ||||||
|  |   urchin_dir=.urchin-cross-shell-test | ||||||
|  |  | ||||||
|  |   rsync --archive -e "ssh ${flags}" | ||||||
|  |     ../urchin ../tests "${hostname}":"${urchin_dir}" || | ||||||
|  |     scp -r ${flags} ../urchin ../tests "${hostname}":"${urchin_dir}" | ||||||
|  |  | ||||||
|  |   remote_tmp="$(ssh "${hostname}" ${flags} "cd ${urchin_dir} && ./urchin $@")" | ||||||
|  |  | ||||||
|  |   remotedir="${hostname}":"${remote_tmp}" | ||||||
|  |   localdir="${urchin_tmp}/remote/${host}" | ||||||
|  |   rsync --archive -e "ssh ${flags}" "${remotedir}" "${localdir}" || | ||||||
|  |     scp -r ${flags} "${remotedir}" | ||||||
|  |    | ||||||
| } | } | ||||||
|  |  | ||||||
| test -n "${TESTING_URCHIN_INTERNALS}" || main "$@" | test -n "${TESTING_URCHIN_INTERNALS}" || main "$@" | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user