Reland r374392: [lit] Extend internal diff to support -U

To avoid breaking some tests, D66574, D68664, D67643, and D68668
landed together.  However, D68664 introduced an issue now addressed by
D68839, with which these are now all relanding.

Differential Revision: https://reviews.llvm.org/D68668

llvm-svn: 374651
This commit is contained in:
Joel E. Denny 2019-10-12 11:58:03 +00:00
parent 32096a86b2
commit 92a8294f9e
4 changed files with 136 additions and 6 deletions

View File

@ -10,6 +10,7 @@ class DiffFlags():
self.ignore_all_space = False self.ignore_all_space = False
self.ignore_space_change = False self.ignore_space_change = False
self.unified_diff = False self.unified_diff = False
self.num_context_lines = 3
self.recursive_diff = False self.recursive_diff = False
self.strip_trailing_cr = False self.strip_trailing_cr = False
@ -48,7 +49,10 @@ def compareTwoBinaryFiles(flags, filepaths, filelines):
exitCode = 0 exitCode = 0
if hasattr(difflib, 'diff_bytes'): if hasattr(difflib, 'diff_bytes'):
# python 3.5 or newer # python 3.5 or newer
diffs = difflib.diff_bytes(difflib.unified_diff, filelines[0], filelines[1], filepaths[0].encode(), filepaths[1].encode()) diffs = difflib.diff_bytes(difflib.unified_diff, filelines[0],
filelines[1], filepaths[0].encode(),
filepaths[1].encode(),
n = flags.num_context_lines)
diffs = [diff.decode(errors="backslashreplace") for diff in diffs] diffs = [diff.decode(errors="backslashreplace") for diff in diffs]
else: else:
# python 2.7 # python 2.7
@ -56,7 +60,8 @@ def compareTwoBinaryFiles(flags, filepaths, filelines):
func = difflib.unified_diff func = difflib.unified_diff
else: else:
func = difflib.context_diff func = difflib.context_diff
diffs = func(filelines[0], filelines[1], filepaths[0], filepaths[1]) diffs = func(filelines[0], filelines[1], filepaths[0], filepaths[1],
n = flags.num_context_lines)
for diff in diffs: for diff in diffs:
sys.stdout.write(diff) sys.stdout.write(diff)
@ -88,7 +93,8 @@ def compareTwoTextFiles(flags, filepaths, filelines_bin, encoding):
filelines[idx]= [f(line) for line in lines] filelines[idx]= [f(line) for line in lines]
func = difflib.unified_diff if flags.unified_diff else difflib.context_diff func = difflib.unified_diff if flags.unified_diff else difflib.context_diff
for diff in func(filelines[0], filelines[1], filepaths[0], filepaths[1]): for diff in func(filelines[0], filelines[1], filepaths[0], filepaths[1],
n = flags.num_context_lines):
sys.stdout.write(diff) sys.stdout.write(diff)
exitCode = 1 exitCode = 1
return exitCode return exitCode
@ -171,7 +177,7 @@ def compareDirTrees(flags, dir_trees, base_paths=["", ""]):
def main(argv): def main(argv):
args = argv[1:] args = argv[1:]
try: try:
opts, args = getopt.gnu_getopt(args, "wbur", ["strip-trailing-cr"]) opts, args = getopt.gnu_getopt(args, "wbuU:r", ["strip-trailing-cr"])
except getopt.GetoptError as err: except getopt.GetoptError as err:
sys.stderr.write("Unsupported: 'diff': %s\n" % str(err)) sys.stderr.write("Unsupported: 'diff': %s\n" % str(err))
sys.exit(1) sys.exit(1)
@ -185,6 +191,16 @@ def main(argv):
flags.ignore_space_change = True flags.ignore_space_change = True
elif o == "-u": elif o == "-u":
flags.unified_diff = True flags.unified_diff = True
elif o.startswith("-U"):
flags.unified_diff = True
try:
flags.num_context_lines = int(a)
if flags.num_context_lines < 0:
raise ValueException
except:
sys.stderr.write("Error: invalid '-U' argument: {}\n"
.format(a))
sys.exit(1)
elif o == "-r": elif o == "-r":
flags.recursive_diff = True flags.recursive_diff = True
elif o == "--strip-trailing-cr": elif o == "--strip-trailing-cr":

View File

@ -0,0 +1,38 @@
# RUN: echo 1 > %t.foo
# RUN: echo 2 >> %t.foo
# RUN: echo 3 >> %t.foo
# RUN: echo 4 >> %t.foo
# RUN: echo 5 >> %t.foo
# RUN: echo 6 foo >> %t.foo
# RUN: echo 7 >> %t.foo
# RUN: echo 8 >> %t.foo
# RUN: echo 9 >> %t.foo
# RUN: echo 10 >> %t.foo
# RUN: echo 11 >> %t.foo
# RUN: echo 1 > %t.bar
# RUN: echo 2 >> %t.bar
# RUN: echo 3 >> %t.bar
# RUN: echo 4 >> %t.bar
# RUN: echo 5 >> %t.bar
# RUN: echo 6 bar >> %t.bar
# RUN: echo 7 >> %t.bar
# RUN: echo 8 >> %t.bar
# RUN: echo 9 >> %t.bar
# RUN: echo 10 >> %t.bar
# RUN: echo 11 >> %t.bar
# Default is 3 lines of context.
# RUN: diff -u %t.foo %t.bar && false || true
# Override default of 3 lines of context.
# RUN: diff -U 2 %t.foo %t.bar && false || true
# RUN: diff -U4 %t.foo %t.bar && false || true
# RUN: diff -U0 %t.foo %t.bar && false || true
# Check bad -U argument.
# RUN: diff -U 30.1 %t.foo %t.foo && false || true
# RUN: diff -U-1 %t.foo %t.foo && false || true
# Fail so lit will print output.
# RUN: false

View File

@ -8,7 +8,7 @@
# #
# END. # END.
# CHECK: Failing Tests (30) # CHECK: Failing Tests (31)
# CHECK: Failing Tests (1) # CHECK: Failing Tests (1)
# CHECK: Failing Tests (2) # CHECK: Failing Tests (2)
# CHECK: error: argument --max-failures: requires positive integer, but found '0' # CHECK: error: argument --max-failures: requires positive integer, but found '0'

View File

@ -331,6 +331,82 @@
# CHECK: PASS: shtest-shell :: diff-r.txt # CHECK: PASS: shtest-shell :: diff-r.txt
# CHECK: FAIL: shtest-shell :: diff-unified.txt
# CHECK: *** TEST 'shtest-shell :: diff-unified.txt' FAILED ***
# CHECK: $ "diff" "-u" "{{[^"]*}}.foo" "{{[^"]*}}.bar"
# CHECK: # command output:
# CHECK: @@ {{.*}} @@
# CHECK-NEXT: 3
# CHECK-NEXT: 4
# CHECK-NEXT: 5
# CHECK-NEXT: -6 foo
# CHECK-NEXT: +6 bar
# CHECK-NEXT: 7
# CHECK-NEXT: 8
# CHECK-NEXT: 9
# CHECK-EMPTY:
# CHECK-NEXT: error: command failed with exit status: 1
# CHECK-NEXT: $ "true"
# CHECK: $ "diff" "-U" "2" "{{[^"]*}}.foo" "{{[^"]*}}.bar"
# CHECK: # command output:
# CHECK: @@ {{.*}} @@
# CHECK-NEXT: 4
# CHECK-NEXT: 5
# CHECK-NEXT: -6 foo
# CHECK-NEXT: +6 bar
# CHECK-NEXT: 7
# CHECK-NEXT: 8
# CHECK-EMPTY:
# CHECK-NEXT: error: command failed with exit status: 1
# CHECK-NEXT: $ "true"
# CHECK: $ "diff" "-U4" "{{[^"]*}}.foo" "{{[^"]*}}.bar"
# CHECK: # command output:
# CHECK: @@ {{.*}} @@
# CHECK-NEXT: 2
# CHECK-NEXT: 3
# CHECK-NEXT: 4
# CHECK-NEXT: 5
# CHECK-NEXT: -6 foo
# CHECK-NEXT: +6 bar
# CHECK-NEXT: 7
# CHECK-NEXT: 8
# CHECK-NEXT: 9
# CHECK-NEXT: 10
# CHECK-EMPTY:
# CHECK-NEXT: error: command failed with exit status: 1
# CHECK-NEXT: $ "true"
# CHECK: $ "diff" "-U0" "{{[^"]*}}.foo" "{{[^"]*}}.bar"
# CHECK: # command output:
# CHECK: @@ {{.*}} @@
# CHECK-NEXT: -6 foo
# CHECK-NEXT: +6 bar
# CHECK-EMPTY:
# CHECK-NEXT: error: command failed with exit status: 1
# CHECK-NEXT: $ "true"
# CHECK: $ "diff" "-U" "30.1" "{{[^"]*}}" "{{[^"]*}}"
# CHECK: # command stderr:
# CHECK: Error: invalid '-U' argument: 30.1
# CHECK: error: command failed with exit status: 1
# CHECK: $ "true"
# CHECK: $ "diff" "-U-1" "{{[^"]*}}" "{{[^"]*}}"
# CHECK: # command stderr:
# CHECK: Error: invalid '-U' argument: -1
# CHECK: error: command failed with exit status: 1
# CHECK: $ "true"
# CHECK: $ "false"
# CHECK: ***
# CHECK: FAIL: shtest-shell :: error-0.txt # CHECK: FAIL: shtest-shell :: error-0.txt
# CHECK: *** TEST 'shtest-shell :: error-0.txt' FAILED *** # CHECK: *** TEST 'shtest-shell :: error-0.txt' FAILED ***
# CHECK: $ "not-a-real-command" # CHECK: $ "not-a-real-command"
@ -410,4 +486,4 @@
# CHECK: PASS: shtest-shell :: sequencing-0.txt # CHECK: PASS: shtest-shell :: sequencing-0.txt
# CHECK: XFAIL: shtest-shell :: sequencing-1.txt # CHECK: XFAIL: shtest-shell :: sequencing-1.txt
# CHECK: PASS: shtest-shell :: valid-shell.txt # CHECK: PASS: shtest-shell :: valid-shell.txt
# CHECK: Failing Tests (30) # CHECK: Failing Tests (31)