2020-01-28 16:02:03 +08:00
// Copyright 2020 The Gitea Authors. All rights reserved.
// Use of this source code is governed by a MIT-style
// license that can be found in the LICENSE file.
package git
import (
"strings"
"testing"
"github.com/stretchr/testify/assert"
)
const exampleDiff = ` diff -- git a / README . md b / README . md
-- - a / README . md
++ + b / README . md
@ @ - 1 , 3 + 1 , 6 @ @
# gitea - github - migrator
+
+ Build Status
- Latest Release
Docker Pulls
+ cut off
+ cut off `
2021-02-27 18:46:14 +00:00
const breakingDiff = ` diff -- git a / aaa . sql b / aaa . sql
index d8e4c92 . .19 dc8ad 100644
-- - a / aaa . sql
++ + b / aaa . sql
@ @ - 1 , 9 + 1 , 10 @ @
-- some comment
-- - some comment 5
+ -- some coment 2
+ -- some comment 3
create or replace procedure test ( p1 varchar2 )
is
begin
-- - new comment
dbms_output . put_line ( p1 ) ;
+ -- some other comment
end ;
/
`
2020-01-28 16:02:03 +08:00
func TestCutDiffAroundLine ( t * testing . T ) {
2021-02-27 18:46:14 +00:00
result , err := CutDiffAroundLine ( strings . NewReader ( exampleDiff ) , 4 , false , 3 )
assert . NoError ( t , err )
2020-01-28 16:02:03 +08:00
resultByLine := strings . Split ( result , "\n" )
assert . Len ( t , resultByLine , 7 )
// Check if headers got transferred
assert . Equal ( t , "diff --git a/README.md b/README.md" , resultByLine [ 0 ] )
assert . Equal ( t , "--- a/README.md" , resultByLine [ 1 ] )
assert . Equal ( t , "+++ b/README.md" , resultByLine [ 2 ] )
// Check if hunk header is calculated correctly
assert . Equal ( t , "@@ -2,2 +3,2 @@" , resultByLine [ 3 ] )
// Check if line got transferred
assert . Equal ( t , "+ Build Status" , resultByLine [ 4 ] )
// Must be same result as before since old line 3 == new line 5
2021-02-27 18:46:14 +00:00
newResult , err := CutDiffAroundLine ( strings . NewReader ( exampleDiff ) , 3 , true , 3 )
assert . NoError ( t , err )
2020-01-28 16:02:03 +08:00
assert . Equal ( t , result , newResult , "Must be same result as before since old line 3 == new line 5" )
2021-02-27 18:46:14 +00:00
newResult , err = CutDiffAroundLine ( strings . NewReader ( exampleDiff ) , 6 , false , 300 )
assert . NoError ( t , err )
2020-01-28 16:02:03 +08:00
assert . Equal ( t , exampleDiff , newResult )
2021-02-27 18:46:14 +00:00
emptyResult , err := CutDiffAroundLine ( strings . NewReader ( exampleDiff ) , 6 , false , 0 )
assert . NoError ( t , err )
2020-01-28 16:02:03 +08:00
assert . Empty ( t , emptyResult )
// Line is out of scope
2021-02-27 18:46:14 +00:00
emptyResult , err = CutDiffAroundLine ( strings . NewReader ( exampleDiff ) , 434 , false , 0 )
assert . NoError ( t , err )
2020-01-28 16:02:03 +08:00
assert . Empty ( t , emptyResult )
2021-02-27 18:46:14 +00:00
// Handle minus diffs properly
minusDiff , err := CutDiffAroundLine ( strings . NewReader ( breakingDiff ) , 2 , false , 4 )
assert . NoError ( t , err )
expected := ` diff -- git a / aaa . sql b / aaa . sql
-- - a / aaa . sql
++ + b / aaa . sql
@ @ - 1 , 9 + 1 , 10 @ @
-- some comment
-- - some comment 5
+ -- some coment 2 `
assert . Equal ( t , expected , minusDiff )
// Handle minus diffs properly
minusDiff , err = CutDiffAroundLine ( strings . NewReader ( breakingDiff ) , 3 , false , 4 )
assert . NoError ( t , err )
expected = ` diff -- git a / aaa . sql b / aaa . sql
-- - a / aaa . sql
++ + b / aaa . sql
@ @ - 1 , 9 + 1 , 10 @ @
-- some comment
-- - some comment 5
+ -- some coment 2
+ -- some comment 3 `
assert . Equal ( t , expected , minusDiff )
2020-01-28 16:02:03 +08:00
}
func BenchmarkCutDiffAroundLine ( b * testing . B ) {
for n := 0 ; n < b . N ; n ++ {
CutDiffAroundLine ( strings . NewReader ( exampleDiff ) , 3 , true , 3 )
}
}
func ExampleCutDiffAroundLine ( ) {
const diff = ` diff -- git a / README . md b / README . md
-- - a / README . md
++ + b / README . md
@ @ - 1 , 3 + 1 , 6 @ @
# gitea - github - migrator
+
+ Build Status
- Latest Release
Docker Pulls
+ cut off
+ cut off `
2021-02-27 18:46:14 +00:00
result , _ := CutDiffAroundLine ( strings . NewReader ( diff ) , 4 , false , 3 )
2020-01-28 16:02:03 +08:00
println ( result )
}
func TestParseDiffHunkString ( t * testing . T ) {
leftLine , leftHunk , rightLine , rightHunk := ParseDiffHunkString ( "@@ -19,3 +19,5 @@ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER" )
assert . EqualValues ( t , 19 , leftLine )
assert . EqualValues ( t , 3 , leftHunk )
assert . EqualValues ( t , 19 , rightLine )
assert . EqualValues ( t , 5 , rightHunk )
}