##// END OF EJS Templates
tests: drop files from exclusion list in test-check-module-imports.t...
tests: drop files from exclusion list in test-check-module-imports.t Now, these files has no style issue at checking with import-checker.py. BTW, tests/test-imports-checker.t is still excluded, because almost all code fragments in it has intentional importing style violation. Using NO_CHECK_EOF instead of EOF as heredoc limit mark can make import-checker.py ignore such fragments. But keeping these fragments checkable seems still useful: for example, test-imports-checker.t can be used to test whether import-checker.py can detect erroneous code fragment in test script as expected.

File last commit:

r33613:a2b55ee6 stable
r40243:f9e3044d default
Show More
pdiff
69 lines | 1.9 KiB | text/plain | TextLexer
FUJIWARA Katsunori
tests: use portable diff script via extdiff extension...
r28052 #!/bin/sh
# Script to get stable diff output on any platform.
#
# Output of this script is almost equivalent to GNU diff with "-Nru".
#
# Use this script as "hg pdiff" via extdiff extension with preparation
# below in test scripts:
#
# $ cat >> $HGRCPATH <<EOF
# > [extdiff]
# > pdiff = sh "$RUNTESTDIR/pdiff"
# > EOF
filediff(){
# USAGE: filediff file1 file2 [header]
# compare with /dev/null if file doesn't exist (as "-N" option)
file1="$1"
if test ! -f "$file1"; then
file1=/dev/null
fi
file2="$2"
if test ! -f "$file2"; then
file2=/dev/null
fi
Danek Duvall
tests: Solaris cmp complains about empty files, even with -s...
r28337 if cmp -s "$file1" "$file2" 2> /dev/null; then
FUJIWARA Katsunori
tests: use portable diff script via extdiff extension...
r28052 # Return immediately, because comparison isn't needed. This
# also avoids redundant message of diff like "No differences
# encountered" (on Solaris)
return
fi
if test -n "$3"; then
# show header only in recursive case
echo "$3"
fi
# replace "/dev/null" by corresponded filename (as "-N" option)
diff -u "$file1" "$file2" |
sed "s@^--- /dev/null\(.*\)\$@--- $1\1@" |
sed "s@^\+\+\+ /dev/null\(.*\)\$@+++ $2\1@"
FUJIWARA Katsunori
tests: make pdiff return appropriate exit code at comparison of files...
r33613
# in this case, files differ from each other
return 1
FUJIWARA Katsunori
tests: use portable diff script via extdiff extension...
r28052 }
if test -d "$1" -o -d "$2"; then
# ensure comparison in dictionary order
(
if test -d "$1"; then (cd "$1" && find . -type f); fi
if test -d "$2"; then (cd "$2" && find . -type f); fi
) |
sed 's@^\./@@g' | sort | uniq |
while read file; do
filediff "$1/$file" "$2/$file" "diff -Nru $1/$file $2/$file"
done
FUJIWARA Katsunori
tests: make pdiff return appropriate exit code at comparison of files...
r33613
# TODO: there is no portable way for current while-read based
# implementation to return 1 at detecting changes.
#
# On bash and dash, assignment to variable inside while-block
# doesn't affect outside, because inside while-block is executed
# in sub-shell. BTW, it affects outside while-block on ksh (as sh
# on Solaris).
FUJIWARA Katsunori
tests: use portable diff script via extdiff extension...
r28052 else
filediff "$1" "$2"
fi