mirror of
https://github.com/RGBCube/uutils-coreutils
synced 2025-08-03 22:47:46 +00:00
refactor to check for system timeout once + commented out many moved/deleted test files that make script fail
This commit is contained in:
parent
c44c3cd716
commit
6468845850
1 changed files with 33 additions and 38 deletions
|
@ -18,6 +18,20 @@ path_GNU="$(readlink -fm -- "${path_GNU:-${path_UUTILS}/../gnu}")"
|
||||||
|
|
||||||
###
|
###
|
||||||
|
|
||||||
|
# On MacOS there is no system /usr/bin/timeout
|
||||||
|
# and trying to add it to /usr/bin (with symlink of copy binary) will fail unless system integrity protection is disabled (not ideal)
|
||||||
|
# ref: https://support.apple.com/en-us/102149
|
||||||
|
# On MacOS the Homebrew coreutils could be installed and then "sudo ln -s /opt/homebrew/bin/timeout /usr/local/bin/timeout"
|
||||||
|
# Set to /usr/local/bin/timeout instead if /usr/bin/timeout is not found
|
||||||
|
SYSTEM_TIMEOUT="timeout"
|
||||||
|
if [ -x /usr/bin/timeout ] ; then
|
||||||
|
SYSTEM_TIMEOUT="/usr/bin/timeout"
|
||||||
|
elif [ -x /usr/local/bin/timeout ] ; then
|
||||||
|
SYSTEM_TIMEOUT="/usr/local/bin/timeout"
|
||||||
|
fi
|
||||||
|
|
||||||
|
###
|
||||||
|
|
||||||
if test ! -d "${path_GNU}"; then
|
if test ! -d "${path_GNU}"; then
|
||||||
echo "Could not find GNU coreutils (expected at '${path_GNU}')"
|
echo "Could not find GNU coreutils (expected at '${path_GNU}')"
|
||||||
echo "Run the following to download into the expected path:"
|
echo "Run the following to download into the expected path:"
|
||||||
|
@ -82,16 +96,7 @@ else
|
||||||
./bootstrap --skip-po
|
./bootstrap --skip-po
|
||||||
./configure --quiet --disable-gcc-warnings
|
./configure --quiet --disable-gcc-warnings
|
||||||
#Add timeout to to protect against hangs
|
#Add timeout to to protect against hangs
|
||||||
# On MacOS there is no system /usr/bin/timeout
|
sed -i 's|^"\$@|'"${SYSTEM_TIMEOUT}"' 600 "\$@|' build-aux/test-driver
|
||||||
# and trying to add it to /usr/bin (with symlink of copy binary) will fail unless system integrity protection is disabled (not ideal)
|
|
||||||
# ref: https://support.apple.com/en-us/102149
|
|
||||||
# On MacOS the Homebrew coreutils could be installed and then "sudo ln -s /opt/homebrew/bin/timeout /usr/local/bin/timeout"
|
|
||||||
# Set to /usr/local/timeout instead if /usr/bin/timeout is not found
|
|
||||||
if [ -x /usr/bin/timeout ] ; then
|
|
||||||
sed -i 's|^"\$@|/usr/bin/timeout 600 "\$@|' build-aux/test-driver
|
|
||||||
else
|
|
||||||
sed -i 's|^"\$@|/usr/local/bin/timeout 600 "\$@|' build-aux/test-driver
|
|
||||||
fi
|
|
||||||
# Change the PATH in the Makefile to test the uutils coreutils instead of the GNU coreutils
|
# Change the PATH in the Makefile to test the uutils coreutils instead of the GNU coreutils
|
||||||
sed -i "s/^[[:blank:]]*PATH=.*/ PATH='${UU_BUILD_DIR//\//\\/}\$(PATH_SEPARATOR)'\"\$\$PATH\" \\\/" Makefile
|
sed -i "s/^[[:blank:]]*PATH=.*/ PATH='${UU_BUILD_DIR//\//\\/}\$(PATH_SEPARATOR)'\"\$\$PATH\" \\\/" Makefile
|
||||||
sed -i 's| tr | /usr/bin/tr |' tests/init.sh
|
sed -i 's| tr | /usr/bin/tr |' tests/init.sh
|
||||||
|
@ -148,44 +153,32 @@ sed -i -e '/tests\/misc\/seq-precision.sh/ D' \
|
||||||
Makefile
|
Makefile
|
||||||
|
|
||||||
# printf doesn't limit the values used in its arg, so this produced ~2GB of output
|
# printf doesn't limit the values used in its arg, so this produced ~2GB of output
|
||||||
sed -i '/INT_OFLOW/ D' tests/misc/printf.sh
|
# Looks like tests/misc/printf.sh does not exist anymore - comment it out for now
|
||||||
|
#sed -i '/INT_OFLOW/ D' tests/misc/printf.sh
|
||||||
|
|
||||||
# Use the system coreutils where the test fails due to error in a util that is not the one being tested
|
# Use the system coreutils where the test fails due to error in a util that is not the one being tested
|
||||||
# TODO : tests/tail-2/ does not appear to exist
|
# TODO : tests/tail-2/ does not appear to exist
|
||||||
# and have been moved to just tests/tail/ location
|
# and have been moved to just tests/tail/ location
|
||||||
# Might need to update the section below to reflect that
|
# Might need to update the section below to reflect that
|
||||||
sed -i 's|stat|/usr/bin/stat|' tests/touch/60-seconds.sh tests/misc/sort-compress-proc.sh
|
# Also looks like tests/misc/sort-compress-proc.sh and tests/tail-2/tail-n0f.sh and tests/misc/shuf.sh and many others do not exist anymore or moved - comment it out for now
|
||||||
|
sed -i 's|stat|/usr/bin/stat|' tests/touch/60-seconds.sh #tests/misc/sort-compress-proc.sh
|
||||||
sed -i 's|ls -|/usr/bin/ls -|' tests/cp/same-file.sh tests/misc/mknod.sh tests/mv/part-symlink.sh
|
sed -i 's|ls -|/usr/bin/ls -|' tests/cp/same-file.sh tests/misc/mknod.sh tests/mv/part-symlink.sh
|
||||||
sed -i 's|chmod |/usr/bin/chmod |' tests/du/inacc-dir.sh tests/tail-2/tail-n0f.sh tests/cp/fail-perm.sh tests/mv/i-2.sh tests/misc/shuf.sh
|
sed -i 's|chmod |/usr/bin/chmod |' tests/du/inacc-dir.sh tests/cp/fail-perm.sh tests/mv/i-2.sh #tests/misc/shuf.sh #tests/tail-2/tail-n0f.sh
|
||||||
sed -i 's|sort |/usr/bin/sort |' tests/ls/hyperlink.sh tests/misc/test-N.sh
|
sed -i 's|sort |/usr/bin/sort |' tests/ls/hyperlink.sh #tests/misc/test-N.sh
|
||||||
sed -i 's|split |/usr/bin/split |' tests/misc/factor-parallel.sh
|
#sed -i 's|split |/usr/bin/split |' tests/misc/factor-parallel.sh
|
||||||
sed -i 's|id -|/usr/bin/id -|' tests/misc/runcon-no-reorder.sh
|
#sed -i 's|id -|/usr/bin/id -|' tests/misc/runcon-no-reorder.sh
|
||||||
# tests/ls/abmon-align.sh - https://github.com/uutils/coreutils/issues/3505
|
# tests/ls/abmon-align.sh - https://github.com/uutils/coreutils/issues/3505
|
||||||
sed -i 's|touch |/usr/bin/touch |' tests/cp/reflink-perm.sh tests/ls/block-size.sh tests/mv/update.sh tests/misc/ls-time.sh tests/misc/stat-nanoseconds.sh tests/misc/time-style.sh tests/misc/test-N.sh tests/ls/abmon-align.sh
|
sed -i 's|touch |/usr/bin/touch |' tests/cp/reflink-perm.sh tests/ls/block-size.sh tests/mv/update.sh tests/misc/time-style.sh tests/ls/abmon-align.sh #tests/misc/ls-time.sh tests/misc/stat-nanoseconds.sh tests/misc/test-N.sh
|
||||||
sed -i 's|ln -|/usr/bin/ln -|' tests/cp/link-deref.sh
|
sed -i 's|ln -|/usr/bin/ln -|' tests/cp/link-deref.sh
|
||||||
sed -i 's|cp |/usr/bin/cp |' tests/mv/hard-2.sh
|
sed -i 's|cp |/usr/bin/cp |' tests/mv/hard-2.sh
|
||||||
sed -i 's|paste |/usr/bin/paste |' tests/misc/od-endian.sh
|
#sed -i 's|paste |/usr/bin/paste |' tests/misc/od-endian.sh
|
||||||
# On MacOS there is no system /usr/bin/timeout
|
#sed -i 's|timeout |'"${SYSTEM_TIMEOUT}"' |' tests/tail-2/follow-stdin.sh
|
||||||
# and trying to add it to /usr/bin (with symlink of copy binary) will fail unless system integrity protection is disabled (not ideal)
|
|
||||||
# ref: https://support.apple.com/en-us/102149
|
|
||||||
# On MacOS the Homebrew coreutils could be installed and then "sudo ln -s /opt/homebrew/bin/timeout /usr/local/bin/timeout"
|
|
||||||
# Set to /usr/local/timeout instead if /usr/bin/timeout is not found
|
|
||||||
if [ -x /usr/bin/timeout ] ; then
|
|
||||||
sed -i 's|timeout |/usr/bin/timeout |' tests/tail-2/follow-stdin.sh
|
|
||||||
else
|
|
||||||
sed -i 's|timeout |/usr/local/bin/timeout |' tests/tail-2/follow-stdin.sh
|
|
||||||
fi
|
|
||||||
|
|
||||||
|
|
||||||
# Add specific timeout to tests that currently hang to limit time spent waiting
|
# Add specific timeout to tests that currently hang to limit time spent waiting
|
||||||
# TODO : tests/misc/seq-precision.sh tests/misc/seq-long-double.sh do not appear to exist
|
# TODO : tests/misc/seq-precision.sh tests/misc/seq-long-double.sh do not appear to exist
|
||||||
# and have been moved to tests/seq/ location
|
# and have been moved to tests/seq/ location
|
||||||
# Might need to update the section below to reflect that
|
# Might need to update the section below to reflect that, but comment it out for now
|
||||||
if [ -x /usr/bin/timeout ] ; then
|
#sed -i 's|\(^\s*\)seq \$|\1'"${SYSTEM_TIMEOUT}"' 0.1 seq \$|' tests/misc/seq-precision.sh tests/misc/seq-long-double.sh
|
||||||
sed -i 's|\(^\s*\)seq \$|\1/usr/bin/timeout 0.1 seq \$|' tests/misc/seq-precision.sh tests/misc/seq-long-double.sh
|
|
||||||
else
|
|
||||||
sed -i 's|\(^\s*\)seq \$|\1/usr/local/bin/timeout 0.1 seq \$|' tests/misc/seq-precision.sh tests/misc/seq-long-double.sh
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Remove dup of /usr/bin/ (and /usr/local/bin) when executed several times
|
# Remove dup of /usr/bin/ (and /usr/local/bin) when executed several times
|
||||||
grep -rlE '/usr/bin/\s?/usr/bin' init.cfg tests/* | xargs --no-run-if-empty sed -Ei 's|/usr/bin/\s?/usr/bin/|/usr/bin/|g'
|
grep -rlE '/usr/bin/\s?/usr/bin' init.cfg tests/* | xargs --no-run-if-empty sed -Ei 's|/usr/bin/\s?/usr/bin/|/usr/bin/|g'
|
||||||
|
@ -214,7 +207,7 @@ sed -i -e "s|rm: cannot remove 'rel': Permission denied|rm: cannot remove 'rel':
|
||||||
# TODO : tests/tail-2/ does not appear to exist
|
# TODO : tests/tail-2/ does not appear to exist
|
||||||
# and have been moved to just tests/tail/ location
|
# and have been moved to just tests/tail/ location
|
||||||
# Might need to update the section below to reflect that
|
# Might need to update the section below to reflect that
|
||||||
sed -i -e "s|---dis ||g" tests/tail-2/overlay-headers.sh
|
#sed -i -e "s|---dis ||g" tests/tail-2/overlay-headers.sh
|
||||||
|
|
||||||
test -f "${UU_BUILD_DIR}/getlimits" || cp src/getlimits "${UU_BUILD_DIR}"
|
test -f "${UU_BUILD_DIR}/getlimits" || cp src/getlimits "${UU_BUILD_DIR}"
|
||||||
|
|
||||||
|
@ -271,11 +264,13 @@ sed -i -e "s/Try 'mv --help' for more information/For more information, try '--h
|
||||||
|
|
||||||
# GNU doesn't support width > INT_MAX
|
# GNU doesn't support width > INT_MAX
|
||||||
# disable these test cases
|
# disable these test cases
|
||||||
sed -i -E "s|^([^#]*2_31.*)$|#\1|g" tests/misc/printf-cov.pl
|
# TODO: moved or deleted tests/misc/printf-cov.pl
|
||||||
|
#sed -i -E "s|^([^#]*2_31.*)$|#\1|g" tests/misc/printf-cov.pl
|
||||||
|
|
||||||
sed -i -e "s/du: invalid -t argument/du: invalid --threshold argument/" -e "s/du: option requires an argument/error: a value is required for '--threshold <SIZE>' but none was supplied/" -e "/Try 'du --help' for more information./d" tests/du/threshold.sh
|
sed -i -e "s/du: invalid -t argument/du: invalid --threshold argument/" -e "s/du: option requires an argument/error: a value is required for '--threshold <SIZE>' but none was supplied/" -e "/Try 'du --help' for more information./d" tests/du/threshold.sh
|
||||||
|
|
||||||
# disable two kind of tests:
|
# disable two kind of tests:
|
||||||
# "hostid BEFORE --help" doesn't fail for GNU. we fail. we are probably doing better
|
# "hostid BEFORE --help" doesn't fail for GNU. we fail. we are probably doing better
|
||||||
# "hostid BEFORE --help AFTER " same for this
|
# "hostid BEFORE --help AFTER " same for this
|
||||||
sed -i -e "s/env \$prog \$BEFORE \$opt > out2/env \$prog \$BEFORE \$opt > out2 #/" -e "s/env \$prog \$BEFORE \$opt AFTER > out3/env \$prog \$BEFORE \$opt AFTER > out3 #/" -e "s/compare exp out2/compare exp out2 #/" -e "s/compare exp out3/compare exp out3 #/" tests/misc/help-version-getopt.sh
|
# TODO moved or deleted tests/misc/help-version-getopt.sh
|
||||||
|
#sed -i -e "s/env \$prog \$BEFORE \$opt > out2/env \$prog \$BEFORE \$opt > out2 #/" -e "s/env \$prog \$BEFORE \$opt AFTER > out3/env \$prog \$BEFORE \$opt AFTER > out3 #/" -e "s/compare exp out2/compare exp out2 #/" -e "s/compare exp out3/compare exp out3 #/" tests/misc/help-version-getopt.sh
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue