mirror of
				https://github.com/mnauw/git-remote-hg.git
				synced 2025-10-26 06:06:06 +01:00 
			
		
		
		
	Merge commit 'bad0a3e5e5dd8352b3ea67d6efa8584ebde5311e' into felipec
This commit is contained in:
		
							
								
								
									
										31
									
								
								.github/workflows/ci.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										31
									
								
								.github/workflows/ci.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,7 +1,7 @@ | |||||||
| name: CI | name: CI | ||||||
|  |  | ||||||
|  | # on: [push] | ||||||
| on: | on: | ||||||
|   # push: |  | ||||||
|   # save cycles; disable on push, enable manual trigger |   # save cycles; disable on push, enable manual trigger | ||||||
|   workflow_dispatch: |   workflow_dispatch: | ||||||
|  |  | ||||||
| @@ -10,13 +10,13 @@ jobs: | |||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|     strategy: |     strategy: | ||||||
|       matrix: |       matrix: | ||||||
|         hg: [ '6.0', '6.1', '6.2', '6.3', '6.4', '6.5', '6.6', '6.7', '6.8', '6.9' ] |         hg: [ '6.0', '6.1', '6.2', '6.3', '6.4', '6.5', '6.6', '6.7', '6.8', '6.9', '7.0' ] | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v3 |       - uses: actions/checkout@v4 | ||||||
|       - uses: actions/setup-python@v4 |       - uses: actions/setup-python@v5 | ||||||
|         with: |         with: | ||||||
|           python-version: '3.10' |           python-version: '3.11' | ||||||
|       - uses: actions/cache@v3 |       - uses: actions/cache@v4 | ||||||
|         id: cache-pip |         id: cache-pip | ||||||
|         with: |         with: | ||||||
|           path: ~/.cache/pip |           path: ~/.cache/pip | ||||||
| @@ -24,4 +24,21 @@ jobs: | |||||||
|       - name: Install hg |       - name: Install hg | ||||||
|         run: |         run: | ||||||
|           pip install mercurial==${{ matrix.hg }} |           pip install mercurial==${{ matrix.hg }} | ||||||
|       - run: make test |       - run: prove -j4 | ||||||
|  |   test-windows: | ||||||
|  |     runs-on: windows-latest | ||||||
|  |     steps: | ||||||
|  |       - uses: actions/checkout@v4 | ||||||
|  |       - uses: actions/setup-python@v5 | ||||||
|  |         with: | ||||||
|  |           python-version: '3.11' | ||||||
|  |       - uses: actions/cache@v4 | ||||||
|  |         id: cache-pip | ||||||
|  |         with: | ||||||
|  |           path: ~/appdata/local/pip/cache | ||||||
|  |           key: pip-windows | ||||||
|  |       - name: Install hg | ||||||
|  |         run: | ||||||
|  |           pip install mercurial | ||||||
|  |       - name: Run all tests | ||||||
|  |         run: prove -j4 --exec bash.exe | ||||||
|   | |||||||
							
								
								
									
										2
									
								
								t/bidi.t
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								t/bidi.t
									
									
									
									
									
								
							| @@ -8,7 +8,7 @@ | |||||||
|  |  | ||||||
| test_description='Test bidirectionality of remote-hg' | test_description='Test bidirectionality of remote-hg' | ||||||
|  |  | ||||||
| . ./test-lib.sh | . "$(dirname "$0")"/test-lib.sh | ||||||
|  |  | ||||||
| # clone to a git repo | # clone to a git repo | ||||||
| git_clone () { | git_clone () { | ||||||
|   | |||||||
| @@ -10,7 +10,7 @@ | |||||||
|  |  | ||||||
| test_description='Test remote-hg output compared to hg-git' | test_description='Test remote-hg output compared to hg-git' | ||||||
|  |  | ||||||
| . ./test-lib.sh | . "$(dirname "$0")"/test-lib.sh | ||||||
|  |  | ||||||
| export EXPECTED_DIR="$SHARNESS_TEST_DIRECTORY/expected" | export EXPECTED_DIR="$SHARNESS_TEST_DIRECTORY/expected" | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										2
									
								
								t/main.t
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								t/main.t
									
									
									
									
									
								
							| @@ -8,7 +8,7 @@ | |||||||
|  |  | ||||||
| test_description='Test remote-hg' | test_description='Test remote-hg' | ||||||
|  |  | ||||||
| . ./test-lib.sh | . "$(dirname "$0")"/test-lib.sh | ||||||
|  |  | ||||||
| if test "$CAPABILITY_PUSH" = "t" | if test "$CAPABILITY_PUSH" = "t" | ||||||
| then | then | ||||||
|   | |||||||
							
								
								
									
										613
									
								
								t/sharness.sh
									
									
									
									
									
								
							
							
						
						
									
										613
									
								
								t/sharness.sh
									
									
									
									
									
								
							| @@ -1,8 +1,9 @@ | |||||||
| #!/bin/sh | # Sharness test framework. | ||||||
| # | # | ||||||
| # Copyright (c) 2011-2012 Mathias Lafeldt | # Copyright (c) 2011-2012 Mathias Lafeldt | ||||||
| # Copyright (c) 2005-2012 Git project | # Copyright (c) 2005-2012 Git project | ||||||
| # Copyright (c) 2005-2012 Junio C Hamano | # Copyright (c) 2005-2012 Junio C Hamano | ||||||
|  | # Copyright (c) 2019-2023 Felipe Contreras | ||||||
| # | # | ||||||
| # This program is free software: you can redistribute it and/or modify | # This program is free software: you can redistribute it and/or modify | ||||||
| # it under the terms of the GNU General Public License as published by | # it under the terms of the GNU General Public License as published by | ||||||
| @@ -17,42 +18,52 @@ | |||||||
| # You should have received a copy of the GNU General Public License | # You should have received a copy of the GNU General Public License | ||||||
| # along with this program.  If not, see http://www.gnu.org/licenses/ . | # along with this program.  If not, see http://www.gnu.org/licenses/ . | ||||||
|  |  | ||||||
|  | if test -n "${ZSH_VERSION-}" | ||||||
|  | then | ||||||
|  | 	# shellcheck disable=SC2296 | ||||||
|  | 	SHARNESS_SOURCE=${(%):-%x} | ||||||
|  | 	emulate sh -o POSIX_ARGZERO | ||||||
|  | else | ||||||
|  | 	# shellcheck disable=SC3028 | ||||||
|  | 	SHARNESS_SOURCE=${BASH_SOURCE-$0} | ||||||
|  | fi | ||||||
|  |  | ||||||
| # Public: Current version of Sharness. | # Public: Current version of Sharness. | ||||||
| SHARNESS_VERSION="1.1.0" | SHARNESS_VERSION="1.2.1" | ||||||
| export SHARNESS_VERSION | export SHARNESS_VERSION | ||||||
|  |  | ||||||
| # Public: The file extension for tests.  By default, it is set to "t". |  | ||||||
| : "${SHARNESS_TEST_EXTENSION:=t}" | : "${SHARNESS_TEST_EXTENSION:=t}" | ||||||
|  | # Public: The file extension for tests.  By default, it is set to "t". | ||||||
| export SHARNESS_TEST_EXTENSION | export SHARNESS_TEST_EXTENSION | ||||||
|  |  | ||||||
| # Public: Root directory containing tests. Tests can override this variable, | : "${SHARNESS_TEST_DIRECTORY:=$(dirname "$0")}" | ||||||
| # e.g. for testing Sharness itself. |  | ||||||
| if test -z "$SHARNESS_TEST_DIRECTORY" |  | ||||||
| then |  | ||||||
| 	SHARNESS_TEST_DIRECTORY=$(pwd) |  | ||||||
| else |  | ||||||
| # ensure that SHARNESS_TEST_DIRECTORY is an absolute path so that it | # ensure that SHARNESS_TEST_DIRECTORY is an absolute path so that it | ||||||
| # is valid even if the current working directory is changed | # is valid even if the current working directory is changed | ||||||
| SHARNESS_TEST_DIRECTORY=$(cd "$SHARNESS_TEST_DIRECTORY" && pwd) || exit 1 | SHARNESS_TEST_DIRECTORY=$(cd "$SHARNESS_TEST_DIRECTORY" && pwd) || exit 1 | ||||||
| fi | # Public: Root directory containing tests. Tests can override this variable, | ||||||
|  | # e.g. for testing Sharness itself. | ||||||
| export SHARNESS_TEST_DIRECTORY | export SHARNESS_TEST_DIRECTORY | ||||||
|  |  | ||||||
| if test -z "$SHARNESS_TEST_OUTPUT_DIRECTORY" | : "${SHARNESS_TEST_SRCDIR:=$(cd "$(dirname "$SHARNESS_SOURCE")" && pwd)}" | ||||||
| then | # Public: Source directory of test code and sharness library. | ||||||
| 	# Similarly, override this to store the test-results subdir | # This directory may be different from the directory in which tests are | ||||||
| 	# elsewhere | # being run. | ||||||
| 	SHARNESS_TEST_OUTPUT_DIRECTORY=$SHARNESS_TEST_DIRECTORY | export SHARNESS_TEST_SRCDIR | ||||||
| fi |  | ||||||
|  | : "${SHARNESS_TEST_OUTDIR:=$SHARNESS_TEST_DIRECTORY}" | ||||||
|  | # Public: Directory where the output of the tests should be stored (i.e. | ||||||
|  | # trash directories). | ||||||
|  | export SHARNESS_TEST_OUTDIR | ||||||
|  |  | ||||||
| #  Reset TERM to original terminal if found, otherwise save original TERM | #  Reset TERM to original terminal if found, otherwise save original TERM | ||||||
| [ "x" = "x$SHARNESS_ORIG_TERM" ] && | [ -z "$SHARNESS_ORIG_TERM" ] && | ||||||
| 		SHARNESS_ORIG_TERM="$TERM" || | 		SHARNESS_ORIG_TERM="$TERM" || | ||||||
| 		TERM="$SHARNESS_ORIG_TERM" | 		TERM="$SHARNESS_ORIG_TERM" | ||||||
| # Public: The unsanitized TERM under which sharness is originally run | # Public: The unsanitized TERM under which sharness is originally run | ||||||
| export SHARNESS_ORIG_TERM | export SHARNESS_ORIG_TERM | ||||||
|  |  | ||||||
| # Export SHELL_PATH | # Export SHELL_PATH | ||||||
| : "${SHELL_PATH:=$SHELL}" | : "${SHELL_PATH:=/bin/sh}" | ||||||
| export SHELL_PATH | export SHELL_PATH | ||||||
|  |  | ||||||
| # if --tee was passed, write the output not only to the terminal, but | # if --tee was passed, write the output not only to the terminal, but | ||||||
| @@ -62,8 +73,8 @@ done,*) | |||||||
| 	# do not redirect again | 	# do not redirect again | ||||||
| 	;; | 	;; | ||||||
| *' --tee '*|*' --verbose-log '*) | *' --tee '*|*' --verbose-log '*) | ||||||
| 	mkdir -p "$SHARNESS_TEST_OUTPUT_DIRECTORY/test-results" | 	mkdir -p "$SHARNESS_TEST_OUTDIR/test-results" | ||||||
| 	BASE="$SHARNESS_TEST_OUTPUT_DIRECTORY/test-results/$(basename "$0" ".$SHARNESS_TEST_EXTENSION")" | 	BASE="$SHARNESS_TEST_OUTDIR/test-results/$(basename "$0" ".$SHARNESS_TEST_EXTENSION")" | ||||||
|  |  | ||||||
| 	# Make this filename available to the sub-process in case it is using | 	# Make this filename available to the sub-process in case it is using | ||||||
| 	# --verbose-log. | 	# --verbose-log. | ||||||
| @@ -128,6 +139,9 @@ while test "$#" -ne 0; do | |||||||
| 	--root=*) | 	--root=*) | ||||||
| 		root=$(expr "z$1" : 'z[^=]*=\(.*\)') | 		root=$(expr "z$1" : 'z[^=]*=\(.*\)') | ||||||
| 		shift ;; | 		shift ;; | ||||||
|  | 	-x) | ||||||
|  | 		trace=t | ||||||
|  | 		shift ;; | ||||||
| 	--verbose-log) | 	--verbose-log) | ||||||
| 		verbose_log=t | 		verbose_log=t | ||||||
| 		shift ;; | 		shift ;; | ||||||
| @@ -177,6 +191,40 @@ else | |||||||
| 	} | 	} | ||||||
| fi | fi | ||||||
|  |  | ||||||
|  | : "${test_untraceable:=}" | ||||||
|  | # Public: When set to a non-empty value, the current test will not be | ||||||
|  | # traced, unless it's run with a Bash version supporting | ||||||
|  | # BASH_XTRACEFD, i.e. v4.1 or later. | ||||||
|  | export test_untraceable | ||||||
|  |  | ||||||
|  | if test -n "$trace" && test -n "$test_untraceable" | ||||||
|  | then | ||||||
|  | 	# '-x' tracing requested, but this test script can't be reliably | ||||||
|  | 	# traced, unless it is run with a Bash version supporting | ||||||
|  | 	# BASH_XTRACEFD (introduced in Bash v4.1). | ||||||
|  | 	# | ||||||
|  | 	# Perform this version check _after_ the test script was | ||||||
|  | 	# potentially re-executed with $TEST_SHELL_PATH for '--tee' or | ||||||
|  | 	# '--verbose-log', so the right shell is checked and the | ||||||
|  | 	# warning is issued only once. | ||||||
|  | 	if test -n "$BASH_VERSION" && eval ' | ||||||
|  | 	     test ${BASH_VERSINFO[0]} -gt 4 || { | ||||||
|  | 	       test ${BASH_VERSINFO[0]} -eq 4 && | ||||||
|  | 	       test ${BASH_VERSINFO[1]} -ge 1 | ||||||
|  | 	     } | ||||||
|  | 	   ' | ||||||
|  | 	then | ||||||
|  | 		: Executed by a Bash version supporting BASH_XTRACEFD.  Good. | ||||||
|  | 	else | ||||||
|  | 		echo >&2 "warning: ignoring -x; '$0' is untraceable without BASH_XTRACEFD" | ||||||
|  | 		trace= | ||||||
|  | 	fi | ||||||
|  | fi | ||||||
|  | if test -n "$trace" && test -z "$verbose_log" | ||||||
|  | then | ||||||
|  | 	verbose=t | ||||||
|  | fi | ||||||
|  |  | ||||||
| TERM=dumb | TERM=dumb | ||||||
| export TERM | export TERM | ||||||
|  |  | ||||||
| @@ -209,11 +257,22 @@ else | |||||||
| 	exec 4>/dev/null 3>/dev/null | 	exec 4>/dev/null 3>/dev/null | ||||||
| fi | fi | ||||||
|  |  | ||||||
| test_failure=0 | # Send any "-x" output directly to stderr to avoid polluting tests | ||||||
| test_count=0 | # which capture stderr. We can do this unconditionally since it | ||||||
| test_fixed=0 | # has no effect if tracing isn't turned on. | ||||||
| test_broken=0 | # | ||||||
| test_success=0 | # Note that this sets up the trace fd as soon as we assign the variable, so it | ||||||
|  | # must come after the creation of descriptor 4 above. Likewise, we must never | ||||||
|  | # unset this, as it has the side effect of closing descriptor 4, which we | ||||||
|  | # use to show verbose tests to the user. | ||||||
|  | # | ||||||
|  | # Note also that we don't need or want to export it. The tracing is local to | ||||||
|  | # this shell, and we would not want to influence any shells we exec. | ||||||
|  | BASH_XTRACEFD=4 | ||||||
|  |  | ||||||
|  | # Public: The current test number, starting at 0. | ||||||
|  | SHARNESS_TEST_NB=0 | ||||||
|  | export SHARNESS_TEST_NB | ||||||
|  |  | ||||||
| die() { | die() { | ||||||
| 	code=$? | 	code=$? | ||||||
| @@ -228,105 +287,30 @@ die() { | |||||||
| EXIT_OK= | EXIT_OK= | ||||||
| trap 'die' EXIT | trap 'die' EXIT | ||||||
|  |  | ||||||
| # Public: Define that a test prerequisite is available. | test_prereq= | ||||||
| # |  | ||||||
| # The prerequisite can later be checked explicitly using test_have_prereq or |  | ||||||
| # implicitly by specifying the prerequisite name in calls to test_expect_success |  | ||||||
| # or test_expect_failure. |  | ||||||
| # |  | ||||||
| # $1 - Name of prerequisite (a simple word, in all capital letters by convention) |  | ||||||
| # |  | ||||||
| # Examples |  | ||||||
| # |  | ||||||
| #   # Set PYTHON prerequisite if interpreter is available. |  | ||||||
| #   command -v python >/dev/null && test_set_prereq PYTHON |  | ||||||
| # |  | ||||||
| #   # Set prerequisite depending on some variable. |  | ||||||
| #   test -z "$NO_GETTEXT" && test_set_prereq GETTEXT |  | ||||||
| # |  | ||||||
| # Returns nothing. |  | ||||||
| test_set_prereq() { |  | ||||||
| 	satisfied_prereq="$satisfied_prereq$1 " |  | ||||||
| } |  | ||||||
| satisfied_prereq=" " |  | ||||||
|  |  | ||||||
| # Public: Check if one or more test prerequisites are defined. |  | ||||||
| # |  | ||||||
| # The prerequisites must have previously been set with test_set_prereq. |  | ||||||
| # The most common use of this is to skip all the tests if some essential |  | ||||||
| # prerequisite is missing. |  | ||||||
| # |  | ||||||
| # $1 - Comma-separated list of test prerequisites. |  | ||||||
| # |  | ||||||
| # Examples |  | ||||||
| # |  | ||||||
| #   # Skip all remaining tests if prerequisite is not set. |  | ||||||
| #   if ! test_have_prereq PERL; then |  | ||||||
| #       skip_all='skipping perl interface tests, perl not available' |  | ||||||
| #       test_done |  | ||||||
| #   fi |  | ||||||
| # |  | ||||||
| # Returns 0 if all prerequisites are defined or 1 otherwise. |  | ||||||
| test_have_prereq() { |  | ||||||
| 	# prerequisites can be concatenated with ',' |  | ||||||
| 	save_IFS=$IFS |  | ||||||
| 	IFS=, |  | ||||||
| 	set -- $@ |  | ||||||
| 	IFS=$save_IFS |  | ||||||
|  |  | ||||||
| 	total_prereq=0 |  | ||||||
| 	ok_prereq=0 |  | ||||||
| missing_prereq= | missing_prereq= | ||||||
|  |  | ||||||
| 	for prerequisite; do | test_failure=0 | ||||||
| 		case "$prerequisite" in | test_fixed=0 | ||||||
| 		!*) | test_broken=0 | ||||||
| 			negative_prereq=t | test_success=0 | ||||||
| 			prerequisite=${prerequisite#!} |  | ||||||
| 			;; |  | ||||||
| 		*) |  | ||||||
| 			negative_prereq= |  | ||||||
| 		esac |  | ||||||
|  |  | ||||||
| 		total_prereq=$((total_prereq + 1)) | if test -e "$SHARNESS_TEST_SRCDIR/lib-sharness/functions.sh" | ||||||
| 		case "$satisfied_prereq" in | then | ||||||
| 		*" $prerequisite "*) | 	. "$SHARNESS_TEST_SRCDIR/lib-sharness/functions.sh" | ||||||
| 			satisfied_this_prereq=t |  | ||||||
| 			;; |  | ||||||
| 		*) |  | ||||||
| 			satisfied_this_prereq= |  | ||||||
| 		esac |  | ||||||
|  |  | ||||||
| 		case "$satisfied_this_prereq,$negative_prereq" in |  | ||||||
| 		t,|,t) |  | ||||||
| 			ok_prereq=$((ok_prereq + 1)) |  | ||||||
| 			;; |  | ||||||
| 		*) |  | ||||||
| 			# Keep a list of missing prerequisites; restore |  | ||||||
| 			# the negative marker if necessary. |  | ||||||
| 			prerequisite=${negative_prereq:+!}$prerequisite |  | ||||||
| 			if test -z "$missing_prereq"; then |  | ||||||
| 				missing_prereq=$prerequisite |  | ||||||
| 			else |  | ||||||
| 				missing_prereq="$prerequisite,$missing_prereq" |  | ||||||
| fi | fi | ||||||
| 		esac |  | ||||||
| 	done |  | ||||||
|  |  | ||||||
| 	test $total_prereq = $ok_prereq |  | ||||||
| } |  | ||||||
|  |  | ||||||
| # You are not expected to call test_ok_ and test_failure_ directly, use | # You are not expected to call test_ok_ and test_failure_ directly, use | ||||||
| # the text_expect_* functions instead. | # the text_expect_* functions instead. | ||||||
|  |  | ||||||
| test_ok_() { | test_ok_() { | ||||||
| 	test_success=$((test_success + 1)) | 	test_success=$((test_success + 1)) | ||||||
| 	say_color "" "ok $test_count - $*" | 	say_color "" "ok $SHARNESS_TEST_NB - $*" | ||||||
| } | } | ||||||
|  |  | ||||||
| test_failure_() { | test_failure_() { | ||||||
| 	test_failure=$((test_failure + 1)) | 	test_failure=$((test_failure + 1)) | ||||||
| 	say_color error "not ok $test_count - $1" | 	say_color error "not ok $SHARNESS_TEST_NB - $1" | ||||||
| 	shift | 	shift | ||||||
| 	echo "$@" | sed -e 's/^/#	/' | 	echo "$@" | sed -e 's/^/#	/' | ||||||
| 	test "$immediate" = "" || { EXIT_OK=t; exit 1; } | 	test "$immediate" = "" || { EXIT_OK=t; exit 1; } | ||||||
| @@ -334,53 +318,76 @@ test_failure_() { | |||||||
|  |  | ||||||
| test_known_broken_ok_() { | test_known_broken_ok_() { | ||||||
| 	test_fixed=$((test_fixed + 1)) | 	test_fixed=$((test_fixed + 1)) | ||||||
| 	say_color error "ok $test_count - $* # TODO known breakage vanished" | 	say_color error "ok $SHARNESS_TEST_NB - $* # TODO known breakage vanished" | ||||||
| } | } | ||||||
|  |  | ||||||
| test_known_broken_failure_() { | test_known_broken_failure_() { | ||||||
| 	test_broken=$((test_broken + 1)) | 	test_broken=$((test_broken + 1)) | ||||||
| 	say_color warn "not ok $test_count - $* # TODO known breakage" | 	say_color warn "not ok $SHARNESS_TEST_NB - $* # TODO known breakage" | ||||||
| } | } | ||||||
|  |  | ||||||
| # Public: Execute commands in debug mode. | want_trace () { | ||||||
| # | 	test "$trace" = t && { | ||||||
| # Takes a single argument and evaluates it only when the test script is started | 		test "$verbose" = t || test "$verbose_log" = t | ||||||
| # with --debug. This is primarily meant for use during the development of test | 	} | ||||||
| # scripts. |  | ||||||
| # |  | ||||||
| # $1 - Commands to be executed. |  | ||||||
| # |  | ||||||
| # Examples |  | ||||||
| # |  | ||||||
| #   test_debug "cat some_log_file" |  | ||||||
| # |  | ||||||
| # Returns the exit code of the last command executed in debug mode or 0 |  | ||||||
| #   otherwise. |  | ||||||
| test_debug() { |  | ||||||
| 	test "$debug" = "" || eval "$1" |  | ||||||
| } | } | ||||||
|  |  | ||||||
| # Public: Stop execution and start a shell. | # This is a separate function because some tests use | ||||||
|  | # "return" to end a test_expect_success block early | ||||||
|  | # (and we want to make sure we run any cleanup like | ||||||
|  | # "set +x"). | ||||||
|  | test_eval_inner_ () { | ||||||
|  | 	# Do not add anything extra (including LF) after '$*' | ||||||
|  | 	eval " | ||||||
|  | 		want_trace && set -x | ||||||
|  | 		$*" | ||||||
|  | } | ||||||
|  |  | ||||||
|  | test_eval_x_ () { | ||||||
|  | 	# If "-x" tracing is in effect, then we want to avoid polluting stderr | ||||||
|  | 	# with non-test commands. But once in "set -x" mode, we cannot prevent | ||||||
|  | 	# the shell from printing the "set +x" to turn it off (nor the saving | ||||||
|  | 	# of $? before that). But we can make sure that the output goes to | ||||||
|  | 	# /dev/null. | ||||||
| 	# | 	# | ||||||
| # This is useful for debugging tests and only makes sense together with "-v". | 	# There are a few subtleties here: | ||||||
| # Be sure to remove all invocations of this command before submitting. | 	# | ||||||
| test_pause() { | 	#   - we have to redirect descriptor 4 in addition to 2, to cover | ||||||
| 	if test "$verbose" = t; then | 	#     BASH_XTRACEFD | ||||||
| 		"$SHELL_PATH" <&6 >&3 2>&4 | 	# | ||||||
| 	else | 	#   - the actual eval has to come before the redirection block (since | ||||||
| 		error >&5 "test_pause requires --verbose" | 	#     it needs to see descriptor 4 to set up its stderr) | ||||||
|  | 	# | ||||||
|  | 	#   - likewise, any error message we print must be outside the block to | ||||||
|  | 	#     access descriptor 4 | ||||||
|  | 	# | ||||||
|  | 	#   - checking $? has to come immediately after the eval, but it must | ||||||
|  | 	#     be _inside_ the block to avoid polluting the "set -x" output | ||||||
|  | 	# | ||||||
|  |  | ||||||
|  | 	test_eval_inner_ "$@" </dev/null >&3 2>&4 | ||||||
|  | 	{ | ||||||
|  | 		test_eval_ret_=$? | ||||||
|  | 		if want_trace | ||||||
|  | 		then | ||||||
|  | 			set +x | ||||||
| 		fi | 		fi | ||||||
|  | 	} 2>/dev/null 4>&2 | ||||||
|  |  | ||||||
|  | 	if test "$test_eval_ret_" != 0 && want_trace | ||||||
|  | 	then | ||||||
|  | 		say_color error >&4 "error: last command exited with \$?=$test_eval_ret_" | ||||||
|  | 	fi | ||||||
|  | 	return $test_eval_ret_ | ||||||
| } | } | ||||||
|  |  | ||||||
| test_eval_() { | test_eval_() { | ||||||
| 	# This is a separate function because some tests use |  | ||||||
| 	# "return" to end a test_expect_success block early. |  | ||||||
| 	case ",$test_prereq," in | 	case ",$test_prereq," in | ||||||
| 	*,INTERACTIVE,*) | 	*,INTERACTIVE,*) | ||||||
| 		eval "$*" | 		eval "$*" | ||||||
| 		;; | 		;; | ||||||
| 	*) | 	*) | ||||||
| 		eval </dev/null >&3 2>&4 "$*" | 		test_eval_x_ "$@" | ||||||
| 		;; | 		;; | ||||||
| 	esac | 	esac | ||||||
| } | } | ||||||
| @@ -392,13 +399,22 @@ test_run_() { | |||||||
| 	eval_ret=$? | 	eval_ret=$? | ||||||
|  |  | ||||||
| 	if test "$chain_lint" = "t"; then | 	if test "$chain_lint" = "t"; then | ||||||
|  | 		# turn off tracing for this test-eval, as it simply creates | ||||||
|  | 		# confusing noise in the "-x" output | ||||||
|  | 		trace_tmp=$trace | ||||||
|  | 		trace= | ||||||
|  | 		# 117 is magic because it is unlikely to match the exit | ||||||
|  | 		# code of other programs | ||||||
| 		test_eval_ "(exit 117) && $1" | 		test_eval_ "(exit 117) && $1" | ||||||
| 		if test "$?" != 117; then | 		if test "$?" != 117; then | ||||||
| 			error "bug in the test script: broken &&-chain: $1" | 			error "bug in the test script: broken &&-chain: $1" | ||||||
| 		fi | 		fi | ||||||
|  | 		trace=$trace_tmp | ||||||
| 	fi | 	fi | ||||||
|  |  | ||||||
| 	if test -z "$immediate" || test $eval_ret = 0 || test -n "$expecting_failure"; then | 	if test -z "$immediate" || test $eval_ret = 0 || | ||||||
|  | 	   test -n "$expecting_failure" && test "$test_cleanup" != ":" | ||||||
|  | 	then | ||||||
| 		test_eval_ "$test_cleanup" | 		test_eval_ "$test_cleanup" | ||||||
| 	fi | 	fi | ||||||
| 	if test "$verbose" = "t" && test -n "$HARNESS_ACTIVE"; then | 	if test "$verbose" = "t" && test -n "$HARNESS_ACTIVE"; then | ||||||
| @@ -408,10 +424,11 @@ test_run_() { | |||||||
| } | } | ||||||
|  |  | ||||||
| test_skip_() { | test_skip_() { | ||||||
| 	test_count=$((test_count + 1)) | 	SHARNESS_TEST_NB=$((SHARNESS_TEST_NB + 1)) | ||||||
| 	to_skip= | 	to_skip= | ||||||
| 	for skp in $SKIP_TESTS; do | 	for skp in $SKIP_TESTS; do | ||||||
| 		case $this_test.$test_count in | 		# shellcheck disable=SC2254 | ||||||
|  | 		case $this_test.$SHARNESS_TEST_NB in | ||||||
| 		$skp) | 		$skp) | ||||||
| 			to_skip=t | 			to_skip=t | ||||||
| 			break | 			break | ||||||
| @@ -428,7 +445,7 @@ test_skip_() { | |||||||
| 		fi | 		fi | ||||||
|  |  | ||||||
| 		say_color skip >&3 "skipping test: $*" | 		say_color skip >&3 "skipping test: $*" | ||||||
| 		say_color skip "ok $test_count # skip $1 (missing $missing_prereq${of_prereq})" | 		say_color skip "ok $SHARNESS_TEST_NB # skip $1 (missing $missing_prereq${of_prereq})" | ||||||
| 		: true | 		: true | ||||||
| 		;; | 		;; | ||||||
| 	*) | 	*) | ||||||
| @@ -437,6 +454,13 @@ test_skip_() { | |||||||
| 	esac | 	esac | ||||||
| } | } | ||||||
|  |  | ||||||
|  | remove_trash_() { | ||||||
|  | 	test -d "$remove_trash" && ( | ||||||
|  | 		cd "$(dirname "$remove_trash")" && | ||||||
|  | 			rm -rf "$(basename "$remove_trash")" | ||||||
|  | 	) | ||||||
|  | } | ||||||
|  |  | ||||||
| # Public: Run test commands and expect them to succeed. | # Public: Run test commands and expect them to succeed. | ||||||
| # | # | ||||||
| # When the test passed, an "ok" message is printed and the number of successful | # When the test passed, an "ok" message is printed and the number of successful | ||||||
| @@ -563,246 +587,6 @@ test_expect_unstable() { | |||||||
| 	echo >&3 "" | 	echo >&3 "" | ||||||
| } | } | ||||||
|  |  | ||||||
| # Public: Run command and ensure that it fails in a controlled way. |  | ||||||
| # |  | ||||||
| # Use it instead of "! <command>". For example, when <command> dies due to a |  | ||||||
| # segfault, test_must_fail diagnoses it as an error, while "! <command>" would |  | ||||||
| # mistakenly be treated as just another expected failure. |  | ||||||
| # |  | ||||||
| # This is one of the prefix functions to be used inside test_expect_success or |  | ||||||
| # test_expect_failure. |  | ||||||
| # |  | ||||||
| # $1.. - Command to be executed. |  | ||||||
| # |  | ||||||
| # Examples |  | ||||||
| # |  | ||||||
| #   test_expect_success 'complain and die' ' |  | ||||||
| #       do something && |  | ||||||
| #       do something else && |  | ||||||
| #       test_must_fail git checkout ../outerspace |  | ||||||
| #   ' |  | ||||||
| # |  | ||||||
| # Returns 1 if the command succeeded (exit code 0). |  | ||||||
| # Returns 1 if the command died by signal (exit codes 130-192) |  | ||||||
| # Returns 1 if the command could not be found (exit code 127). |  | ||||||
| # Returns 0 otherwise. |  | ||||||
| test_must_fail() { |  | ||||||
| 	"$@" |  | ||||||
| 	exit_code=$? |  | ||||||
| 	if test $exit_code = 0; then |  | ||||||
| 		echo >&2 "test_must_fail: command succeeded: $*" |  | ||||||
| 		return 1 |  | ||||||
| 	elif test $exit_code -gt 129 -a $exit_code -le 192; then |  | ||||||
| 		echo >&2 "test_must_fail: died by signal: $*" |  | ||||||
| 		return 1 |  | ||||||
| 	elif test $exit_code = 127; then |  | ||||||
| 		echo >&2 "test_must_fail: command not found: $*" |  | ||||||
| 		return 1 |  | ||||||
| 	fi |  | ||||||
| 	return 0 |  | ||||||
| } |  | ||||||
|  |  | ||||||
| # Public: Run command and ensure that it succeeds or fails in a controlled way. |  | ||||||
| # |  | ||||||
| # Similar to test_must_fail, but tolerates success too. Use it instead of |  | ||||||
| # "<command> || :" to catch failures caused by a segfault, for instance. |  | ||||||
| # |  | ||||||
| # This is one of the prefix functions to be used inside test_expect_success or |  | ||||||
| # test_expect_failure. |  | ||||||
| # |  | ||||||
| # $1.. - Command to be executed. |  | ||||||
| # |  | ||||||
| # Examples |  | ||||||
| # |  | ||||||
| #   test_expect_success 'some command works without configuration' ' |  | ||||||
| #       test_might_fail git config --unset all.configuration && |  | ||||||
| #       do something |  | ||||||
| #   ' |  | ||||||
| # |  | ||||||
| # Returns 1 if the command died by signal (exit codes 130-192) |  | ||||||
| # Returns 1 if the command could not be found (exit code 127). |  | ||||||
| # Returns 0 otherwise. |  | ||||||
| test_might_fail() { |  | ||||||
| 	"$@" |  | ||||||
| 	exit_code=$? |  | ||||||
| 	if test $exit_code -gt 129 -a $exit_code -le 192; then |  | ||||||
| 		echo >&2 "test_might_fail: died by signal: $*" |  | ||||||
| 		return 1 |  | ||||||
| 	elif test $exit_code = 127; then |  | ||||||
| 		echo >&2 "test_might_fail: command not found: $*" |  | ||||||
| 		return 1 |  | ||||||
| 	fi |  | ||||||
| 	return 0 |  | ||||||
| } |  | ||||||
|  |  | ||||||
| # Public: Run command and ensure it exits with a given exit code. |  | ||||||
| # |  | ||||||
| # This is one of the prefix functions to be used inside test_expect_success or |  | ||||||
| # test_expect_failure. |  | ||||||
| # |  | ||||||
| # $1   - Expected exit code. |  | ||||||
| # $2.. - Command to be executed. |  | ||||||
| # |  | ||||||
| # Examples |  | ||||||
| # |  | ||||||
| #   test_expect_success 'Merge with d/f conflicts' ' |  | ||||||
| #       test_expect_code 1 git merge "merge msg" B master |  | ||||||
| #   ' |  | ||||||
| # |  | ||||||
| # Returns 0 if the expected exit code is returned or 1 otherwise. |  | ||||||
| test_expect_code() { |  | ||||||
| 	want_code=$1 |  | ||||||
| 	shift |  | ||||||
| 	"$@" |  | ||||||
| 	exit_code=$? |  | ||||||
| 	if test "$exit_code" = "$want_code"; then |  | ||||||
| 		return 0 |  | ||||||
| 	fi |  | ||||||
|  |  | ||||||
| 	echo >&2 "test_expect_code: command exited with $exit_code, we wanted $want_code $*" |  | ||||||
| 	return 1 |  | ||||||
| } |  | ||||||
|  |  | ||||||
| # Public: Compare two files to see if expected output matches actual output. |  | ||||||
| # |  | ||||||
| # The TEST_CMP variable defines the command used for the comparison; it |  | ||||||
| # defaults to "diff -u". Only when the test script was started with --verbose, |  | ||||||
| # will the command's output, the diff, be printed to the standard output. |  | ||||||
| # |  | ||||||
| # This is one of the prefix functions to be used inside test_expect_success or |  | ||||||
| # test_expect_failure. |  | ||||||
| # |  | ||||||
| # $1 - Path to file with expected output. |  | ||||||
| # $2 - Path to file with actual output. |  | ||||||
| # |  | ||||||
| # Examples |  | ||||||
| # |  | ||||||
| #   test_expect_success 'foo works' ' |  | ||||||
| #       echo expected >expected && |  | ||||||
| #       foo >actual && |  | ||||||
| #       test_cmp expected actual |  | ||||||
| #   ' |  | ||||||
| # |  | ||||||
| # Returns the exit code of the command set by TEST_CMP. |  | ||||||
| test_cmp() { |  | ||||||
| 	${TEST_CMP:-diff -u} "$@" |  | ||||||
| } |  | ||||||
|  |  | ||||||
| # Public: portably print a sequence of numbers. |  | ||||||
| # |  | ||||||
| # seq is not in POSIX and GNU seq might not be available everywhere, |  | ||||||
| # so it is nice to have a seq implementation, even a very simple one. |  | ||||||
| # |  | ||||||
| # $1 - Starting number. |  | ||||||
| # $2 - Ending number. |  | ||||||
| # |  | ||||||
| # Examples |  | ||||||
| # |  | ||||||
| #   test_expect_success 'foo works 10 times' ' |  | ||||||
| #       for i in $(test_seq 1 10) |  | ||||||
| #       do |  | ||||||
| #           foo || return |  | ||||||
| #       done |  | ||||||
| #   ' |  | ||||||
| # |  | ||||||
| # Returns 0 if all the specified numbers can be displayed. |  | ||||||
| test_seq() { |  | ||||||
| 	i="$1" |  | ||||||
| 	j="$2" |  | ||||||
| 	while test "$i" -le "$j" |  | ||||||
| 	do |  | ||||||
| 		echo "$i" || return |  | ||||||
| 		i=$(("$i" + 1)) |  | ||||||
| 	done |  | ||||||
| } |  | ||||||
|  |  | ||||||
| # Public: Check if the file expected to be empty is indeed empty, and barfs |  | ||||||
| # otherwise. |  | ||||||
| # |  | ||||||
| # $1 - File to check for emptiness. |  | ||||||
| # |  | ||||||
| # Returns 0 if file is empty, 1 otherwise. |  | ||||||
| test_must_be_empty() { |  | ||||||
| 	if test -s "$1" |  | ||||||
| 	then |  | ||||||
| 		echo "'$1' is not empty, it contains:" |  | ||||||
| 		cat "$1" |  | ||||||
| 		return 1 |  | ||||||
| 	fi |  | ||||||
| } |  | ||||||
|  |  | ||||||
| # debugging-friendly alternatives to "test [-f|-d|-e]" |  | ||||||
| # The commands test the existence or non-existence of $1. $2 can be |  | ||||||
| # given to provide a more precise diagnosis. |  | ||||||
| test_path_is_file () { |  | ||||||
| 	if ! test -f "$1" |  | ||||||
| 	then |  | ||||||
| 		echo "File $1 doesn't exist. $2" |  | ||||||
| 		false |  | ||||||
| 	fi |  | ||||||
| } |  | ||||||
|  |  | ||||||
| test_path_is_dir () { |  | ||||||
| 	if ! test -d "$1" |  | ||||||
| 	then |  | ||||||
| 		echo "Directory $1 doesn't exist. $2" |  | ||||||
| 		false |  | ||||||
| 	fi |  | ||||||
| } |  | ||||||
|  |  | ||||||
| # Check if the directory exists and is empty as expected, barf otherwise. |  | ||||||
| test_dir_is_empty () { |  | ||||||
| 	test_path_is_dir "$1" && |  | ||||||
| 	if test -n "$(find "$1" -mindepth 1 -maxdepth 1)" |  | ||||||
| 	then |  | ||||||
| 		echo "Directory '$1' is not empty, it contains:" |  | ||||||
| 		ls -la "$1" |  | ||||||
| 		return 1 |  | ||||||
| 	fi |  | ||||||
| } |  | ||||||
|  |  | ||||||
| # Public: Schedule cleanup commands to be run unconditionally at the end of a |  | ||||||
| # test. |  | ||||||
| # |  | ||||||
| # If some cleanup command fails, the test will not pass. With --immediate, no |  | ||||||
| # cleanup is done to help diagnose what went wrong. |  | ||||||
| # |  | ||||||
| # This is one of the prefix functions to be used inside test_expect_success or |  | ||||||
| # test_expect_failure. |  | ||||||
| # |  | ||||||
| # $1.. - Commands to prepend to the list of cleanup commands. |  | ||||||
| # |  | ||||||
| # Examples |  | ||||||
| # |  | ||||||
| #   test_expect_success 'test core.capslock' ' |  | ||||||
| #       git config core.capslock true && |  | ||||||
| #       test_when_finished "git config --unset core.capslock" && |  | ||||||
| #       do_something |  | ||||||
| #   ' |  | ||||||
| # |  | ||||||
| # Returns the exit code of the last cleanup command executed. |  | ||||||
| test_when_finished() { |  | ||||||
| 	test_cleanup="{ $* |  | ||||||
| 		} && (exit \"\$eval_ret\"); eval_ret=\$?; $test_cleanup" |  | ||||||
| } |  | ||||||
|  |  | ||||||
| # Public: Schedule cleanup commands to be run unconditionally when all tests |  | ||||||
| # have run. |  | ||||||
| # |  | ||||||
| # This can be used to clean up things like test databases. It is not needed to |  | ||||||
| # clean up temporary files, as test_done already does that. |  | ||||||
| # |  | ||||||
| # Examples: |  | ||||||
| # |  | ||||||
| #   cleanup mysql -e "DROP DATABASE mytest" |  | ||||||
| # |  | ||||||
| # Returns the exit code of the last cleanup command executed. |  | ||||||
| final_cleanup= |  | ||||||
| cleanup() { |  | ||||||
| 	final_cleanup="{ $* |  | ||||||
| 		} && (exit \"\$eval_ret\"); eval_ret=\$?; $final_cleanup" |  | ||||||
| } |  | ||||||
|  |  | ||||||
| # Public: Summarize test results and exit with an appropriate error code. | # Public: Summarize test results and exit with an appropriate error code. | ||||||
| # | # | ||||||
| # Must be called at the end of each test script. | # Must be called at the end of each test script. | ||||||
| @@ -823,16 +607,17 @@ cleanup() { | |||||||
| #   fi | #   fi | ||||||
| # | # | ||||||
| # Returns 0 if all tests passed or 1 if there was a failure. | # Returns 0 if all tests passed or 1 if there was a failure. | ||||||
|  | # shellcheck disable=SC2154,SC2034 | ||||||
| test_done() { | test_done() { | ||||||
| 	EXIT_OK=t | 	EXIT_OK=t | ||||||
|  |  | ||||||
| 	if test -z "$HARNESS_ACTIVE"; then | 	if test -z "$HARNESS_ACTIVE"; then | ||||||
| 		test_results_dir="$SHARNESS_TEST_OUTPUT_DIRECTORY/test-results" | 		test_results_dir="$SHARNESS_TEST_OUTDIR/test-results" | ||||||
| 		mkdir -p "$test_results_dir" | 		mkdir -p "$test_results_dir" | ||||||
| 		test_results_path="$test_results_dir/$this_test.$$.counts" | 		test_results_path="$test_results_dir/$this_test.$$.counts" | ||||||
|  |  | ||||||
| 		cat >>"$test_results_path" <<-EOF | 		cat >>"$test_results_path" <<-EOF | ||||||
| 		total $test_count | 		total $SHARNESS_TEST_NB | ||||||
| 		success $test_success | 		success $test_success | ||||||
| 		fixed $test_fixed | 		fixed $test_fixed | ||||||
| 		broken $test_broken | 		broken $test_broken | ||||||
| @@ -848,54 +633,43 @@ test_done() { | |||||||
| 		say_color warn "# still have $test_broken known breakage(s)" | 		say_color warn "# still have $test_broken known breakage(s)" | ||||||
| 	fi | 	fi | ||||||
| 	if test "$test_broken" != 0 || test "$test_fixed" != 0; then | 	if test "$test_broken" != 0 || test "$test_fixed" != 0; then | ||||||
| 		test_remaining=$((test_count - test_broken - test_fixed)) | 		test_remaining=$((SHARNESS_TEST_NB - test_broken - test_fixed)) | ||||||
| 		msg="remaining $test_remaining test(s)" | 		msg="remaining $test_remaining test(s)" | ||||||
| 	else | 	else | ||||||
| 		test_remaining=$test_count | 		test_remaining=$SHARNESS_TEST_NB | ||||||
| 		msg="$test_count test(s)" | 		msg="$SHARNESS_TEST_NB test(s)" | ||||||
| 	fi | 	fi | ||||||
|  |  | ||||||
| 	case "$test_failure" in | 	case "$test_failure" in | ||||||
| 	0) | 	0) | ||||||
| 		# Maybe print SKIP message | 		# Maybe print SKIP message | ||||||
| 		if test -n "$skip_all" && test $test_count -gt 0; then | 		check_skip_all_ | ||||||
| 			error "Can't use skip_all after running some tests" | 		if test "$test_remaining" -gt 0; then | ||||||
| 		fi |  | ||||||
| 		[ -z "$skip_all" ] || skip_all=" # SKIP $skip_all" |  | ||||||
|  |  | ||||||
| 		if test $test_remaining -gt 0; then |  | ||||||
| 			say_color pass "# passed all $msg" | 			say_color pass "# passed all $msg" | ||||||
| 		fi | 		fi | ||||||
| 		say "1..$test_count$skip_all" | 		say "1..$SHARNESS_TEST_NB$skip_all" | ||||||
|  |  | ||||||
| 		test_eval_ "$final_cleanup" | 		test_eval_ "$final_cleanup" | ||||||
|  |  | ||||||
| 		test -d "$remove_trash" && | 		remove_trash_ | ||||||
| 		cd "$(dirname "$remove_trash")" && |  | ||||||
| 		rm -rf "$(basename "$remove_trash")" |  | ||||||
|  |  | ||||||
| 		exit 0 ;; | 		exit 0 ;; | ||||||
|  |  | ||||||
| 	*) | 	*) | ||||||
| 		say_color error "# failed $test_failure among $msg" | 		say_color error "# failed $test_failure among $msg" | ||||||
| 		say "1..$test_count" | 		say "1..$SHARNESS_TEST_NB" | ||||||
|  |  | ||||||
| 		exit 1 ;; | 		exit 1 ;; | ||||||
|  |  | ||||||
| 	esac | 	esac | ||||||
| } | } | ||||||
|  |  | ||||||
| # Public: Source directory of test code and sharness library. | : "${SHARNESS_BUILD_DIRECTORY:="$SHARNESS_TEST_DIRECTORY/.."}" | ||||||
| # This directory may be different from the directory in which tests are |  | ||||||
| # being run. |  | ||||||
| : "${SHARNESS_TEST_SRCDIR:=$(cd "$(dirname "$0")" && pwd)}" |  | ||||||
| export SHARNESS_TEST_SRCDIR |  | ||||||
|  |  | ||||||
| # Public: Build directory that will be added to PATH. By default, it is set to | # Public: Build directory that will be added to PATH. By default, it is set to | ||||||
| # the parent directory of SHARNESS_TEST_DIRECTORY. | # the parent directory of SHARNESS_TEST_DIRECTORY. | ||||||
| : "${SHARNESS_BUILD_DIRECTORY:="$SHARNESS_TEST_DIRECTORY/.."}" | export SHARNESS_BUILD_DIRECTORY | ||||||
| PATH="$SHARNESS_BUILD_DIRECTORY:$PATH" | PATH="$SHARNESS_BUILD_DIRECTORY:$PATH" | ||||||
| export PATH SHARNESS_BUILD_DIRECTORY | export PATH | ||||||
|  |  | ||||||
| # Public: Path to test script currently executed. | # Public: Path to test script currently executed. | ||||||
| SHARNESS_TEST_FILE="$0" | SHARNESS_TEST_FILE="$0" | ||||||
| @@ -906,7 +680,7 @@ SHARNESS_TRASH_DIRECTORY="trash directory.$(basename "$SHARNESS_TEST_FILE" ".$SH | |||||||
| test -n "$root" && SHARNESS_TRASH_DIRECTORY="$root/$SHARNESS_TRASH_DIRECTORY" | test -n "$root" && SHARNESS_TRASH_DIRECTORY="$root/$SHARNESS_TRASH_DIRECTORY" | ||||||
| case "$SHARNESS_TRASH_DIRECTORY" in | case "$SHARNESS_TRASH_DIRECTORY" in | ||||||
| /*) ;; # absolute path is good | /*) ;; # absolute path is good | ||||||
|  *) SHARNESS_TRASH_DIRECTORY="$SHARNESS_TEST_OUTPUT_DIRECTORY/$SHARNESS_TRASH_DIRECTORY" ;; |  *) SHARNESS_TRASH_DIRECTORY="$SHARNESS_TEST_OUTDIR/$SHARNESS_TRASH_DIRECTORY" ;; | ||||||
| esac | esac | ||||||
| test "$debug" = "t" || remove_trash="$SHARNESS_TRASH_DIRECTORY" | test "$debug" = "t" || remove_trash="$SHARNESS_TRASH_DIRECTORY" | ||||||
| rm -rf "$SHARNESS_TRASH_DIRECTORY" || { | rm -rf "$SHARNESS_TRASH_DIRECTORY" || { | ||||||
| @@ -917,11 +691,11 @@ rm -rf "$SHARNESS_TRASH_DIRECTORY" || { | |||||||
|  |  | ||||||
|  |  | ||||||
| # | # | ||||||
| #  Load any extensions in $srcdir/sharness.d/*.sh | #  Load any extensions in $testdir/sharness.d/*.sh | ||||||
| # | # | ||||||
| if test -d "${SHARNESS_TEST_SRCDIR}/sharness.d" | if test -d "${SHARNESS_TEST_DIRECTORY}/sharness.d" | ||||||
| then | then | ||||||
| 	for file in "${SHARNESS_TEST_SRCDIR}"/sharness.d/*.sh | 	for file in "${SHARNESS_TEST_DIRECTORY}"/sharness.d/*.sh | ||||||
| 	do | 	do | ||||||
| 		# Ensure glob was not an empty match: | 		# Ensure glob was not an empty match: | ||||||
| 		test -e "${file}" || break | 		test -e "${file}" || break | ||||||
| @@ -930,6 +704,7 @@ then | |||||||
| 		then | 		then | ||||||
| 			echo >&5 "sharness: loading extensions from ${file}" | 			echo >&5 "sharness: loading extensions from ${file}" | ||||||
| 		fi | 		fi | ||||||
|  | 		# shellcheck disable=SC1090 | ||||||
| 		. "${file}" | 		. "${file}" | ||||||
| 		if test $? != 0 | 		if test $? != 0 | ||||||
| 		then | 		then | ||||||
| @@ -946,14 +721,28 @@ export SHARNESS_TRASH_DIRECTORY | |||||||
| HOME="$SHARNESS_TRASH_DIRECTORY" | HOME="$SHARNESS_TRASH_DIRECTORY" | ||||||
| export HOME | export HOME | ||||||
|  |  | ||||||
|  | # shellcheck disable=SC3028 | ||||||
|  | if [ "$OSTYPE" = msys ]; then | ||||||
|  | 	USERPROFILE="$SHARNESS_TRASH_DIRECTORY" | ||||||
|  | 	export USERPROFILE | ||||||
|  | fi | ||||||
|  |  | ||||||
| mkdir -p "$SHARNESS_TRASH_DIRECTORY" || exit 1 | mkdir -p "$SHARNESS_TRASH_DIRECTORY" || exit 1 | ||||||
| # Use -P to resolve symlinks in our working directory so that the cwd | # Use -P to resolve symlinks in our working directory so that the cwd | ||||||
| # in subprocesses like git equals our $PWD (for pathname comparisons). | # in subprocesses like git equals our $PWD (for pathname comparisons). | ||||||
| cd -P "$SHARNESS_TRASH_DIRECTORY" || exit 1 | cd -P "$SHARNESS_TRASH_DIRECTORY" || exit 1 | ||||||
|  |  | ||||||
|  | check_skip_all_() { | ||||||
|  | 	if test -n "$skip_all" && test $SHARNESS_TEST_NB -gt 0; then | ||||||
|  | 		error "Can't use skip_all after running some tests" | ||||||
|  | 	fi | ||||||
|  | 	[ -z "$skip_all" ] || skip_all=" # SKIP $skip_all" | ||||||
|  | } | ||||||
|  |  | ||||||
| this_test=${SHARNESS_TEST_FILE##*/} | this_test=${SHARNESS_TEST_FILE##*/} | ||||||
| this_test=${this_test%.$SHARNESS_TEST_EXTENSION} | this_test=${this_test%".$SHARNESS_TEST_EXTENSION"} | ||||||
| for skp in $SKIP_TESTS; do | for skp in $SKIP_TESTS; do | ||||||
|  | 	# shellcheck disable=SC2254 | ||||||
| 	case "$this_test" in | 	case "$this_test" in | ||||||
| 	$skp) | 	$skp) | ||||||
| 		say_color info >&3 "skipping test $this_test altogether" | 		say_color info >&3 "skipping test $this_test altogether" | ||||||
|   | |||||||
| @@ -72,7 +72,65 @@ git config --global protocol.file.allow always | |||||||
|  |  | ||||||
| unset XDG_CONFIG_HOME | unset XDG_CONFIG_HOME | ||||||
|  |  | ||||||
| if [[ $(uname -s) = MSYS* ]]; then | test_set_prereq() { | ||||||
|  | 	satisfied_prereq="$satisfied_prereq$1 " | ||||||
|  | } | ||||||
|  | satisfied_prereq=" " | ||||||
|  |  | ||||||
|  | case "$(uname -s)" in | ||||||
|  | MSYS*|MINGW*) | ||||||
| 	test_set_prereq WIN | 	test_set_prereq WIN | ||||||
| 	export TEST_CMP='diff --strip-trailing-cr -u' | 	export TEST_CMP='diff --strip-trailing-cr -u' | ||||||
|  | 	;; | ||||||
|  | esac | ||||||
|  |  | ||||||
|  | test_cmp() { | ||||||
|  | 	${TEST_CMP:-diff -u} "$@" | ||||||
|  | } | ||||||
|  |  | ||||||
|  | test_when_finished() { | ||||||
|  | 	test_cleanup="{ $* | ||||||
|  | 		} && (exit \"\$eval_ret\"); eval_ret=\$?; $test_cleanup" | ||||||
|  | } | ||||||
|  |  | ||||||
|  | test_expect_code() { | ||||||
|  | 	want_code=$1 | ||||||
|  | 	shift | ||||||
|  | 	"$@" | ||||||
|  | 	exit_code=$? | ||||||
|  | 	if test "$exit_code" = "$want_code"; then | ||||||
|  | 		return 0 | ||||||
| 	fi | 	fi | ||||||
|  |  | ||||||
|  | 	echo >&2 "test_expect_code: command exited with $exit_code, we wanted $want_code $*" | ||||||
|  | 	return 1 | ||||||
|  | } | ||||||
|  |  | ||||||
|  | test_have_prereq() { | ||||||
|  | 	prerequisite=$1 | ||||||
|  |  | ||||||
|  | 	case "$prerequisite" in | ||||||
|  | 	!*) | ||||||
|  | 		negative_prereq=t | ||||||
|  | 		prerequisite=${prerequisite#!} | ||||||
|  | 		;; | ||||||
|  | 	*) | ||||||
|  | 		negative_prereq= | ||||||
|  | 	esac | ||||||
|  |  | ||||||
|  | 	case "$satisfied_prereq" in | ||||||
|  | 	*" $prerequisite "*) | ||||||
|  | 		satisfied_this_prereq=t | ||||||
|  | 		;; | ||||||
|  | 	*) | ||||||
|  | 		satisfied_this_prereq= | ||||||
|  | 	esac | ||||||
|  |  | ||||||
|  | 	case "$satisfied_this_prereq,$negative_prereq" in | ||||||
|  | 	t,|,t) | ||||||
|  | 		return 0 | ||||||
|  | 		;; | ||||||
|  | 	esac | ||||||
|  |  | ||||||
|  | 	return 1 | ||||||
|  | } | ||||||
|   | |||||||
| @@ -44,3 +44,4 @@ | |||||||
| 6.7 | 6.7 | ||||||
| 6.8 | 6.8 | ||||||
| 6.9 | 6.9 | ||||||
|  | 7.0 | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user