Page Menu
Home
c4science
Search
Configure Global Search
Log In
Files
F98061639
DifferentialHunkParserTestCase.php
No One
Temporary
Actions
Download File
Edit File
Delete File
View Transforms
Subscribe
Mute Notifications
Award Token
Subscribers
None
File Metadata
Details
File Info
Storage
Attached
Created
Thu, Jan 9, 05:15
Size
7 KB
Mime Type
text/x-php
Expires
Sat, Jan 11, 05:15 (1 d, 23 h)
Engine
blob
Format
Raw Data
Handle
23490347
Attached To
rPH Phabricator
DifferentialHunkParserTestCase.php
View Options
<?php
final
class
DifferentialHunkParserTestCase
extends
PhabricatorTestCase
{
private
function
createComment
()
{
$comment
=
new
DifferentialInlineComment
();
return
$comment
;
}
// $line: 1 based
// $length: 0 based (0 meaning 1 line)
private
function
createNewComment
(
$line
,
$length
)
{
$comment
=
$this
->
createComment
();
$comment
->
setIsNewFile
(
true
);
$comment
->
setLineNumber
(
$line
);
$comment
->
setLineLength
(
$length
);
return
$comment
;
}
// $line: 1 based
// $length: 0 based (0 meaning 1 line)
private
function
createOldComment
(
$line
,
$length
)
{
$comment
=
$this
->
createComment
();
$comment
->
setIsNewFile
(
false
);
$comment
->
setLineNumber
(
$line
);
$comment
->
setLineLength
(
$length
);
return
$comment
;
}
private
function
createHunk
(
$oldOffset
,
$oldLen
,
$newOffset
,
$newLen
,
$changes
)
{
$hunk
=
new
DifferentialHunk
();
$hunk
->
setOldOffset
(
$oldOffset
);
$hunk
->
setOldLen
(
$oldLen
);
$hunk
->
setNewOffset
(
$newOffset
);
$hunk
->
setNewLen
(
$newLen
);
$hunk
->
setChanges
(
$changes
);
return
$hunk
;
}
// Returns a change that consists of a single hunk, starting at line 1.
private
function
createSingleChange
(
$old_lines
,
$new_lines
,
$changes
)
{
return
array
(
0
=>
$this
->
createHunk
(
1
,
$old_lines
,
1
,
$new_lines
,
$changes
),
);
}
private
function
createHunksFromFile
(
$name
)
{
$data
=
Filesystem
::
readFile
(
dirname
(
__FILE__
).
'/data/'
.
$name
);
$parser
=
new
ArcanistDiffParser
();
$changes
=
$parser
->
parseDiff
(
$data
);
if
(
count
(
$changes
)
!==
1
)
{
throw
new
Exception
(
"Expected 1 changeset for '{$name}'!"
);
}
$diff
=
DifferentialDiff
::
newFromRawChanges
(
$changes
);
return
head
(
$diff
->
getChangesets
())->
getHunks
();
}
public
function
testOneLineOldComment
()
{
$parser
=
new
DifferentialHunkParser
();
$hunks
=
$this
->
createSingleChange
(
1
,
0
,
"-a"
);
$context
=
$parser
->
makeContextDiff
(
$hunks
,
$this
->
createOldComment
(
1
,
0
),
0
);
$this
->
assertEqual
(
"@@ -1,1 @@
\n
-a"
,
$context
);
}
public
function
testOneLineNewComment
()
{
$parser
=
new
DifferentialHunkParser
();
$hunks
=
$this
->
createSingleChange
(
0
,
1
,
"+a"
);
$context
=
$parser
->
makeContextDiff
(
$hunks
,
$this
->
createNewComment
(
1
,
0
),
0
);
$this
->
assertEqual
(
"@@ +1,1 @@
\n
+a"
,
$context
);
}
public
function
testCannotFindContext
()
{
$parser
=
new
DifferentialHunkParser
();
$hunks
=
$this
->
createSingleChange
(
0
,
1
,
"+a"
);
$context
=
$parser
->
makeContextDiff
(
$hunks
,
$this
->
createNewComment
(
2
,
0
),
0
);
$this
->
assertEqual
(
""
,
$context
);
}
public
function
testOverlapFromStartOfHunk
()
{
$parser
=
new
DifferentialHunkParser
();
$hunks
=
array
(
0
=>
$this
->
createHunk
(
23
,
2
,
42
,
2
,
" 1
\n
2"
),
);
$context
=
$parser
->
makeContextDiff
(
$hunks
,
$this
->
createNewComment
(
41
,
1
),
0
);
$this
->
assertEqual
(
"@@ -23,1 +42,1 @@
\n
1"
,
$context
);
}
public
function
testOverlapAfterEndOfHunk
()
{
$parser
=
new
DifferentialHunkParser
();
$hunks
=
array
(
0
=>
$this
->
createHunk
(
23
,
2
,
42
,
2
,
" 1
\n
2"
),
);
$context
=
$parser
->
makeContextDiff
(
$hunks
,
$this
->
createNewComment
(
43
,
1
),
0
);
$this
->
assertEqual
(
"@@ -24,1 +43,1 @@
\n
2"
,
$context
);
}
public
function
testInclusionOfNewFileInOldCommentFromStart
()
{
$parser
=
new
DifferentialHunkParser
();
$hunks
=
$this
->
createSingleChange
(
2
,
3
,
"+n1
\n
"
.
" e1/2
\n
"
.
"-o2
\n
"
.
"+n3
\n
"
);
$context
=
$parser
->
makeContextDiff
(
$hunks
,
$this
->
createOldComment
(
1
,
1
),
0
);
$this
->
assertEqual
(
"@@ -1,2 +2,1 @@
\n
"
.
" e1/2
\n
"
.
"-o2"
,
$context
);
}
public
function
testInclusionOfOldFileInNewCommentFromStart
()
{
$parser
=
new
DifferentialHunkParser
();
$hunks
=
$this
->
createSingleChange
(
2
,
2
,
"-o1
\n
"
.
" e2/1
\n
"
.
"-o3
\n
"
.
"+n2
\n
"
);
$context
=
$parser
->
makeContextDiff
(
$hunks
,
$this
->
createNewComment
(
1
,
1
),
0
);
$this
->
assertEqual
(
"@@ -2,1 +1,2 @@
\n
"
.
" e2/1
\n
"
.
"+n2"
,
$context
);
}
public
function
testNoNewlineAtEndOfFile
()
{
$parser
=
new
DifferentialHunkParser
();
$hunks
=
$this
->
createSingleChange
(
0
,
1
,
"+a
\n
"
.
"
\\
No newline at end of file"
);
// Note that this only works with additional context.
$context
=
$parser
->
makeContextDiff
(
$hunks
,
$this
->
createNewComment
(
2
,
0
),
1
);
$this
->
assertEqual
(
"@@ +1,1 @@
\n
"
.
"+a
\n
"
.
"
\\
No newline at end of file"
,
$context
);
}
public
function
testMultiLineNewComment
()
{
$parser
=
new
DifferentialHunkParser
();
$hunks
=
$this
->
createSingleChange
(
7
,
7
,
" e1
\n
"
.
" e2
\n
"
.
"-o3
\n
"
.
"-o4
\n
"
.
"+n3
\n
"
.
" e5/4
\n
"
.
" e6/5
\n
"
.
"+n6
\n
"
.
" e7
\n
"
);
$context
=
$parser
->
makeContextDiff
(
$hunks
,
$this
->
createNewComment
(
2
,
4
),
0
);
$this
->
assertEqual
(
"@@ -2,5 +2,5 @@
\n
"
.
" e2
\n
"
.
"-o3
\n
"
.
"-o4
\n
"
.
"+n3
\n
"
.
" e5/4
\n
"
.
" e6/5
\n
"
.
"+n6"
,
$context
);
}
public
function
testMultiLineOldComment
()
{
$parser
=
new
DifferentialHunkParser
();
$hunks
=
$this
->
createSingleChange
(
7
,
7
,
" e1
\n
"
.
" e2
\n
"
.
"-o3
\n
"
.
"-o4
\n
"
.
"+n3
\n
"
.
" e5/4
\n
"
.
" e6/5
\n
"
.
"+n6
\n
"
.
" e7
\n
"
);
$context
=
$parser
->
makeContextDiff
(
$hunks
,
$this
->
createOldComment
(
2
,
4
),
0
);
$this
->
assertEqual
(
"@@ -2,5 +2,4 @@
\n
"
.
" e2
\n
"
.
"-o3
\n
"
.
"-o4
\n
"
.
"+n3
\n
"
.
" e5/4
\n
"
.
" e6/5"
,
$context
);
}
public
function
testInclusionOfNewFileInOldCommentFromStartWithContext
()
{
$parser
=
new
DifferentialHunkParser
();
$hunks
=
$this
->
createSingleChange
(
2
,
3
,
"+n1
\n
"
.
" e1/2
\n
"
.
"-o2
\n
"
.
"+n3
\n
"
);
$context
=
$parser
->
makeContextDiff
(
$hunks
,
$this
->
createOldComment
(
1
,
1
),
1
);
$this
->
assertEqual
(
"@@ -1,2 +1,2 @@
\n
"
.
"+n1
\n
"
.
" e1/2
\n
"
.
"-o2"
,
$context
);
}
public
function
testInclusionOfOldFileInNewCommentFromStartWithContext
()
{
$parser
=
new
DifferentialHunkParser
();
$hunks
=
$this
->
createSingleChange
(
2
,
2
,
"-o1
\n
"
.
" e2/1
\n
"
.
"-o3
\n
"
.
"+n2
\n
"
);
$context
=
$parser
->
makeContextDiff
(
$hunks
,
$this
->
createNewComment
(
1
,
1
),
1
);
$this
->
assertEqual
(
"@@ -1,3 +1,2 @@
\n
"
.
"-o1
\n
"
.
" e2/1
\n
"
.
"-o3
\n
"
.
"+n2"
,
$context
);
}
public
function
testMissingContext
()
{
$tests
=
array
(
'missing_context.diff'
=>
array
(
4
=>
true
,
),
'missing_context_2.diff'
=>
array
(
5
=>
true
,
),
'missing_context_3.diff'
=>
array
(
4
=>
true
,
13
=>
true
,
),
);
foreach
(
$tests
as
$name
=>
$expect
)
{
$hunks
=
$this
->
createHunksFromFile
(
$name
);
$parser
=
new
DifferentialHunkParser
();
$actual
=
$parser
->
getHunkStartLines
(
$hunks
);
$this
->
assertEqual
(
$expect
,
$actual
,
$name
);
}
}
}
Event Timeline
Log In to Comment