hush/testsuite/diff.tests
Matheus Izvekov 6f99c91e43 diff: fix flag -B, cleanups and a couple more tests V2
function                                             old     new   delta
diffreg                                             1157    1268    +111
uni_range                                             51       -     -51

Signed-off-by: Matheus Izvekov <mizvekov@gmail.com>
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
2010-01-22 04:20:16 +01:00

181 lines
3.0 KiB
Bash
Executable File

#!/bin/sh
# Copyright 2008 by Denys Vlasenko
# Licensed under GPL v2, see file LICENSE for details.
. ./testing.sh
# testing "test name" "options" "expected result" "file input" "stdin"
# diff outputs date/time in the header, which should not be analysed
# NB: sed has tab character in s command!
TRIM_TAB="sed 's/ .*//'"
testing "diff of stdin" \
"diff -u - input | $TRIM_TAB" \
"\
--- -
+++ input
@@ -1 +1,3 @@
+qwe
asd
+zxc
" \
"qwe\nasd\nzxc\n" \
"asd\n"
testing "diff of stdin, no newline in the file" \
"diff -u - input | $TRIM_TAB" \
"\
--- -
+++ input
@@ -1 +1,3 @@
+qwe
asd
+zxc
\\ No newline at end of file
" \
"qwe\nasd\nzxc" \
"asd\n"
# we also test that stdin is in fact NOT read
testing "diff of stdin, twice" \
'diff - -; echo $?; wc -c' \
"0\n5\n" \
"" \
"stdin"
testing "diff of empty file against nonempty one" \
"diff -u - input | $TRIM_TAB" \
"\
--- -
+++ input
@@ -0,0 +1 @@
+a
" \
"a\n" \
""
testing "diff -b treats EOF as whitespace" \
'diff -ub - input; echo $?' \
"0\n" \
"abc" \
"abc "
testing "diff -b treats all spaces as equal" \
'diff -ub - input; echo $?' \
"0\n" \
"a \t c\n" \
"a\t \tc\n"
testing "diff -B ignores changes whose lines are all blank" \
'diff -uB - input; echo $?' \
"0\n" \
"a\n" \
"\na\n\n"
testing "diff -B does not ignore changes whose lines are not all blank" \
"diff -uB - input | $TRIM_TAB" \
"\
--- -
+++ input
@@ -1,3 +1 @@
-
-b
-
+a
" \
"a\n" \
"\nb\n\n"
testing "diff always takes context from old file" \
"diff -ub - input | $TRIM_TAB" \
"\
--- -
+++ input
@@ -1 +1,3 @@
+abc
a c
+def
" \
"abc\na c\ndef\n" \
"a c\n"
# testing "test name" "options" "expected result" "file input" "stdin"
rm -rf diff1 diff2
mkdir diff1 diff2 diff2/subdir
echo qwe >diff1/-
echo asd >diff2/subdir/-
testing "diff diff1 diff2/subdir" \
"diff -ur diff1 diff2/subdir | $TRIM_TAB" \
"\
--- diff1/-
+++ diff2/subdir/-
@@ -1 +1 @@
-qwe
+asd
" \
"" ""
# using directory structure from prev test...
testing "diff dir dir2/file/-" \
"diff -ur diff1 diff2/subdir/- | $TRIM_TAB" \
"\
--- diff1/-
+++ diff2/subdir/-
@@ -1 +1 @@
-qwe
+asd
" \
"" ""
# using directory structure from prev test...
mkdir diff1/test
mkfifo diff2/subdir/test
testing "diff of dir and fifo" \
"diff -ur diff1 diff2/subdir | $TRIM_TAB" \
"\
--- diff1/-
+++ diff2/subdir/-
@@ -1 +1 @@
-qwe
+asd
Only in diff2/subdir: test
" \
"" ""
# using directory structure from prev test...
rmdir diff1/test
echo >diff1/test
testing "diff of file and fifo" \
"diff -ur diff1 diff2/subdir | $TRIM_TAB" \
"\
--- diff1/-
+++ diff2/subdir/-
@@ -1 +1 @@
-qwe
+asd
File diff2/subdir/test is not a regular file or directory and was skipped
" \
"" ""
# using directory structure from prev test...
mkfifo diff1/test2
testing "diff -rN does not read non-regular files" \
"diff -urN diff1 diff2/subdir | $TRIM_TAB" \
"\
--- diff1/-
+++ diff2/subdir/-
@@ -1 +1 @@
-qwe
+asd
File diff2/subdir/test is not a regular file or directory and was skipped
File diff1/test2 is not a regular file or directory and was skipped
" \
"" ""
# clean up
rm -rf diff1 diff2
exit $FAILCOUNT