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
|
||||||
|
|||||||
621
t/sharness.sh
621
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
|
||||||
|
|
||||||
|
: "${SHARNESS_TEST_DIRECTORY:=$(dirname "$0")}"
|
||||||
|
# ensure that SHARNESS_TEST_DIRECTORY is an absolute path so that it
|
||||||
|
# is valid even if the current working directory is changed
|
||||||
|
SHARNESS_TEST_DIRECTORY=$(cd "$SHARNESS_TEST_DIRECTORY" && pwd) || exit 1
|
||||||
# Public: Root directory containing tests. Tests can override this variable,
|
# Public: Root directory containing tests. Tests can override this variable,
|
||||||
# e.g. for testing Sharness itself.
|
# 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
|
|
||||||
# is valid even if the current working directory is changed
|
|
||||||
SHARNESS_TEST_DIRECTORY=$(cd "$SHARNESS_TEST_DIRECTORY" && pwd) || exit 1
|
|
||||||
fi
|
|
||||||
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=
|
||||||
#
|
missing_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.
|
test_failure=0
|
||||||
#
|
test_fixed=0
|
||||||
# The prerequisites must have previously been set with test_set_prereq.
|
test_broken=0
|
||||||
# The most common use of this is to skip all the tests if some essential
|
test_success=0
|
||||||
# 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
|
if test -e "$SHARNESS_TEST_SRCDIR/lib-sharness/functions.sh"
|
||||||
ok_prereq=0
|
then
|
||||||
missing_prereq=
|
. "$SHARNESS_TEST_SRCDIR/lib-sharness/functions.sh"
|
||||||
|
fi
|
||||||
for prerequisite; do
|
|
||||||
case "$prerequisite" in
|
|
||||||
!*)
|
|
||||||
negative_prereq=t
|
|
||||||
prerequisite=${prerequisite#!}
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
negative_prereq=
|
|
||||||
esac
|
|
||||||
|
|
||||||
total_prereq=$((total_prereq + 1))
|
|
||||||
case "$satisfied_prereq" in
|
|
||||||
*" $prerequisite "*)
|
|
||||||
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
|
|
||||||
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
|
||||||
# This is useful for debugging tests and only makes sense together with "-v".
|
# (and we want to make sure we run any cleanup like
|
||||||
# Be sure to remove all invocations of this command before submitting.
|
# "set +x").
|
||||||
test_pause() {
|
test_eval_inner_ () {
|
||||||
if test "$verbose" = t; then
|
# Do not add anything extra (including LF) after '$*'
|
||||||
"$SHELL_PATH" <&6 >&3 2>&4
|
eval "
|
||||||
else
|
want_trace && set -x
|
||||||
error >&5 "test_pause requires --verbose"
|
$*"
|
||||||
|
}
|
||||||
|
|
||||||
|
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.
|
||||||
|
#
|
||||||
|
# There are a few subtleties here:
|
||||||
|
#
|
||||||
|
# - we have to redirect descriptor 4 in addition to 2, to cover
|
||||||
|
# BASH_XTRACEFD
|
||||||
|
#
|
||||||
|
# - the actual eval has to come before the redirection block (since
|
||||||
|
# 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
|
||||||
|
} 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
|
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'
|
||||||
fi
|
;;
|
||||||
|
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
|
||||||
|
|
||||||
|
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