Show More
@@ -29,25 +29,25 class BdiffTests(unittest.TestCase): | |||
|
29 | 29 | |
|
30 | 30 | def test_bdiff_basic(self): |
|
31 | 31 | cases = [ |
|
32 | ("a\nc\n\n\n\n", "a\nb\n\n\n"), | |
|
33 | ("a\nb\nc\n", "a\nc\n"), | |
|
34 | ("", ""), | |
|
35 | ("a\nb\nc", "a\nb\nc"), | |
|
36 | ("a\nb\nc\nd\n", "a\nd\n"), | |
|
37 | ("a\nb\nc\nd\n", "a\nc\ne\n"), | |
|
38 | ("a\nb\nc\n", "a\nc\n"), | |
|
39 | ("a\n", "c\na\nb\n"), | |
|
40 | ("a\n", ""), | |
|
41 | ("a\n", "b\nc\n"), | |
|
42 | ("a\n", "c\na\n"), | |
|
43 | ("", "adjfkjdjksdhfksj"), | |
|
44 | ("", "ab"), | |
|
45 | ("", "abc"), | |
|
46 | ("a", "a"), | |
|
47 | ("ab", "ab"), | |
|
48 | ("abc", "abc"), | |
|
49 | ("a\n", "a\n"), | |
|
50 | ("a\nb", "a\nb"), | |
|
32 | (b"a\nc\n\n\n\n", b"a\nb\n\n\n"), | |
|
33 | (b"a\nb\nc\n", b"a\nc\n"), | |
|
34 | (b"", b""), | |
|
35 | (b"a\nb\nc", b"a\nb\nc"), | |
|
36 | (b"a\nb\nc\nd\n", b"a\nd\n"), | |
|
37 | (b"a\nb\nc\nd\n", b"a\nc\ne\n"), | |
|
38 | (b"a\nb\nc\n", b"a\nc\n"), | |
|
39 | (b"a\n", b"c\na\nb\n"), | |
|
40 | (b"a\n", b""), | |
|
41 | (b"a\n", b"b\nc\n"), | |
|
42 | (b"a\n", b"c\na\n"), | |
|
43 | (b"", b"adjfkjdjksdhfksj"), | |
|
44 | (b"", b"ab"), | |
|
45 | (b"", b"abc"), | |
|
46 | (b"a", b"a"), | |
|
47 | (b"ab", b"ab"), | |
|
48 | (b"abc", b"abc"), | |
|
49 | (b"a\n", b"a\n"), | |
|
50 | (b"a\nb", b"a\nb"), | |
|
51 | 51 | ] |
|
52 | 52 | for a, b in cases: |
|
53 | 53 | self.assert_bdiff(a, b) |
@@ -71,42 +71,44 class BdiffTests(unittest.TestCase): | |||
|
71 | 71 | |
|
72 | 72 | def test_issue1295(self): |
|
73 | 73 | cases = [ |
|
74 | ("x\n\nx\n\nx\n\nx\n\nz\n", "x\n\nx\n\ny\n\nx\n\nx\n\nz\n", | |
|
75 | ['x\n\nx\n\n', diffreplace(6, 6, '', 'y\n\n'), 'x\n\nx\n\nz\n']), | |
|
76 | ("x\n\nx\n\nx\n\nx\n\nz\n", "x\n\nx\n\ny\n\nx\n\ny\n\nx\n\nz\n", | |
|
77 |
|
|
|
78 | diffreplace(6, 6, '', 'y\n\n'), | |
|
79 |
|
|
|
80 |
diffreplace( |
|
|
81 |
'x\n\n |
|
|
74 | (b"x\n\nx\n\nx\n\nx\n\nz\n", b"x\n\nx\n\ny\n\nx\n\nx\n\nz\n", | |
|
75 | [b'x\n\nx\n\n', | |
|
76 | diffreplace(6, 6, b'', b'y\n\n'), | |
|
77 | b'x\n\nx\n\nz\n']), | |
|
78 | (b"x\n\nx\n\nx\n\nx\n\nz\n", b"x\n\nx\n\ny\n\nx\n\ny\n\nx\n\nz\n", | |
|
79 | [b'x\n\nx\n\n', | |
|
80 | diffreplace(6, 6, b'', b'y\n\n'), | |
|
81 | b'x\n\n', | |
|
82 | diffreplace(9, 9, b'', b'y\n\n'), | |
|
83 | b'x\n\nz\n']), | |
|
82 | 84 | ] |
|
83 | 85 | for old, new, want in cases: |
|
84 | 86 | self.assertEqual(self.showdiff(old, new), want) |
|
85 | 87 | |
|
86 | 88 | def test_issue1295_varies_on_pure(self): |
|
87 | 89 | # we should pick up abbbc. rather than bc.de as the longest match |
|
88 | got = self.showdiff("a\nb\nb\nb\nc\n.\nd\ne\n.\nf\n", | |
|
89 | "a\nb\nb\na\nb\nb\nb\nc\n.\nb\nc\n.\nd\ne\nf\n") | |
|
90 | want_c = ['a\nb\nb\n', | |
|
91 | diffreplace(6, 6, '', 'a\nb\nb\nb\nc\n.\n'), | |
|
92 | 'b\nc\n.\nd\ne\n', | |
|
93 | diffreplace(16, 18, '.\n', ''), | |
|
94 | 'f\n'] | |
|
95 | want_pure = [diffreplace(0, 0, '', 'a\nb\nb\n'), | |
|
96 | 'a\nb\nb\nb\nc\n.\n', | |
|
97 | diffreplace(12, 12, '', 'b\nc\n.\n'), | |
|
98 | 'd\ne\n', | |
|
99 | diffreplace(16, 18, '.\n', ''), 'f\n'] | |
|
90 | got = self.showdiff(b"a\nb\nb\nb\nc\n.\nd\ne\n.\nf\n", | |
|
91 | b"a\nb\nb\na\nb\nb\nb\nc\n.\nb\nc\n.\nd\ne\nf\n") | |
|
92 | want_c = [b'a\nb\nb\n', | |
|
93 | diffreplace(6, 6, b'', b'a\nb\nb\nb\nc\n.\n'), | |
|
94 | b'b\nc\n.\nd\ne\n', | |
|
95 | diffreplace(16, 18, b'.\n', b''), | |
|
96 | b'f\n'] | |
|
97 | want_pure = [diffreplace(0, 0, b'', b'a\nb\nb\n'), | |
|
98 | b'a\nb\nb\nb\nc\n.\n', | |
|
99 | diffreplace(12, 12, b'', b'b\nc\n.\n'), | |
|
100 | b'd\ne\n', | |
|
101 | diffreplace(16, 18, b'.\n', b''), b'f\n'] | |
|
100 | 102 | self.assert_(got in (want_c, want_pure), |
|
101 | 103 | 'got: %r, wanted either %r or %r' % ( |
|
102 | 104 | got, want_c, want_pure)) |
|
103 | 105 | |
|
104 | 106 | def test_fixws(self): |
|
105 | 107 | cases = [ |
|
106 | (" \ta\r b\t\n", "ab\n", 1), | |
|
107 | (" \ta\r b\t\n", " a b\n", 0), | |
|
108 | ("", "", 1), | |
|
109 | ("", "", 0), | |
|
108 | (b" \ta\r b\t\n", b"ab\n", 1), | |
|
109 | (b" \ta\r b\t\n", b" a b\n", 0), | |
|
110 | (b"", b"", 1), | |
|
111 | (b"", b"", 0), | |
|
110 | 112 | ] |
|
111 | 113 | for a, b, allws in cases: |
|
112 | 114 | c = mdiff.fixws(a, allws) |
@@ -115,34 +117,34 class BdiffTests(unittest.TestCase): | |||
|
115 | 117 | |
|
116 | 118 | def test_nice_diff_for_trivial_change(self): |
|
117 | 119 | self.assertEqual(self.showdiff( |
|
118 | ''.join('<%s\n-\n' % i for i in range(5)), | |
|
119 | ''.join('>%s\n-\n' % i for i in range(5))), | |
|
120 | [diffreplace(0, 3, '<0\n', '>0\n'), | |
|
121 | '-\n', | |
|
122 | diffreplace(5, 8, '<1\n', '>1\n'), | |
|
123 | '-\n', | |
|
124 | diffreplace(10, 13, '<2\n', '>2\n'), | |
|
125 | '-\n', | |
|
126 | diffreplace(15, 18, '<3\n', '>3\n'), | |
|
127 | '-\n', | |
|
128 | diffreplace(20, 23, '<4\n', '>4\n'), | |
|
129 | '-\n']) | |
|
120 | b''.join(b'<%s\n-\n' % i for i in range(5)), | |
|
121 | b''.join(b'>%s\n-\n' % i for i in range(5))), | |
|
122 | [diffreplace(0, 3, b'<0\n', b'>0\n'), | |
|
123 | b'-\n', | |
|
124 | diffreplace(5, 8, b'<1\n', b'>1\n'), | |
|
125 | b'-\n', | |
|
126 | diffreplace(10, 13, b'<2\n', b'>2\n'), | |
|
127 | b'-\n', | |
|
128 | diffreplace(15, 18, b'<3\n', b'>3\n'), | |
|
129 | b'-\n', | |
|
130 | diffreplace(20, 23, b'<4\n', b'>4\n'), | |
|
131 | b'-\n']) | |
|
130 | 132 | |
|
131 | 133 | def test_prefer_appending(self): |
|
132 | 134 | # 1 line to 3 lines |
|
133 | self.assertEqual(self.showdiff('a\n', 'a\n' * 3), | |
|
134 | ['a\n', diffreplace(2, 2, '', 'a\na\n')]) | |
|
135 | self.assertEqual(self.showdiff(b'a\n', b'a\n' * 3), | |
|
136 | [b'a\n', diffreplace(2, 2, b'', b'a\na\n')]) | |
|
135 | 137 | # 1 line to 5 lines |
|
136 | self.assertEqual(self.showdiff('a\n', 'a\n' * 5), | |
|
137 | ['a\n', diffreplace(2, 2, '', 'a\na\na\na\n')]) | |
|
138 | self.assertEqual(self.showdiff(b'a\n', b'a\n' * 5), | |
|
139 | [b'a\n', diffreplace(2, 2, b'', b'a\na\na\na\n')]) | |
|
138 | 140 | |
|
139 | 141 | def test_prefer_removing_trailing(self): |
|
140 | 142 | # 3 lines to 1 line |
|
141 | self.assertEqual(self.showdiff('a\n' * 3, 'a\n'), | |
|
142 | ['a\n', diffreplace(2, 6, 'a\na\n', '')]) | |
|
143 | self.assertEqual(self.showdiff(b'a\n' * 3, b'a\n'), | |
|
144 | [b'a\n', diffreplace(2, 6, b'a\na\n', b'')]) | |
|
143 | 145 | # 5 lines to 1 line |
|
144 | self.assertEqual(self.showdiff('a\n' * 5, 'a\n'), | |
|
145 | ['a\n', diffreplace(2, 10, 'a\na\na\na\n', '')]) | |
|
146 | self.assertEqual(self.showdiff(b'a\n' * 5, b'a\n'), | |
|
147 | [b'a\n', diffreplace(2, 10, b'a\na\na\na\n', b'')]) | |
|
146 | 148 | |
|
147 | 149 | if __name__ == '__main__': |
|
148 | 150 | import silenttestrunner |
General Comments 0
You need to be logged in to leave comments.
Login now