1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44 package org.eclipse.jgit.patch;
45
46 import static java.lang.Integer.valueOf;
47 import static org.junit.Assert.assertEquals;
48 import static org.junit.Assert.assertSame;
49 import static org.junit.Assert.assertTrue;
50 import static org.junit.Assert.fail;
51
52 import java.io.IOException;
53 import java.io.InputStream;
54 import java.text.MessageFormat;
55
56 import org.eclipse.jgit.internal.JGitText;
57 import org.eclipse.jgit.junit.JGitTestUtil;
58 import org.junit.Test;
59
60 public class PatchCcErrorTest {
61 @Test
62 public void testError_CcTruncatedOld() throws IOException {
63 final Patch p = parseTestPatchFile();
64 assertEquals(1, p.getFiles().size());
65 assertEquals(3, p.getErrors().size());
66 {
67 final FormatError e = p.getErrors().get(0);
68 assertSame(FormatError.Severity.ERROR, e.getSeverity());
69 assertEquals(MessageFormat.format(
70 JGitText.get().truncatedHunkLinesMissingForAncestor,
71 valueOf(1), valueOf(1)), e.getMessage());
72 assertEquals(346, e.getOffset());
73 assertTrue(e.getLineText().startsWith(
74 "@@@ -55,12 -163,13 +163,15 @@@ public "));
75 }
76 {
77 final FormatError e = p.getErrors().get(1);
78 assertSame(FormatError.Severity.ERROR, e.getSeverity());
79 assertEquals(MessageFormat.format(
80 JGitText.get().truncatedHunkLinesMissingForAncestor,
81 valueOf(2), valueOf(2)), e.getMessage());
82 assertEquals(346, e.getOffset());
83 assertTrue(e.getLineText().startsWith(
84 "@@@ -55,12 -163,13 +163,15 @@@ public "));
85 }
86 {
87 final FormatError e = p.getErrors().get(2);
88 assertSame(FormatError.Severity.ERROR, e.getSeverity());
89 assertEquals("Truncated hunk, at least 3 new lines is missing", e
90 .getMessage());
91 assertEquals(346, e.getOffset());
92 assertTrue(e.getLineText().startsWith(
93 "@@@ -55,12 -163,13 +163,15 @@@ public "));
94 }
95 }
96
97 private Patch parseTestPatchFile() throws IOException {
98 final String patchFile = JGitTestUtil.getName() + ".patch";
99 final InputStream in = getClass().getResourceAsStream(patchFile);
100 if (in == null) {
101 fail("No " + patchFile + " test vector");
102 return null;
103 }
104 try {
105 final Patch p = new Patch();
106 p.parse(in);
107 return p;
108 } finally {
109 in.close();
110 }
111 }
112
113 }