mirror of https://github.com/gogits/gogs.git
Faraz Fazli
9 years ago
9 changed files with 759 additions and 974 deletions
@ -1,70 +1,70 @@ |
|||||||
package models |
package models |
||||||
|
|
||||||
import ( |
import ( |
||||||
dmp "github.com/sergi/go-diff/diffmatchpatch" |
dmp "github.com/sergi/go-diff/diffmatchpatch" |
||||||
"html/template" |
"html/template" |
||||||
"testing" |
"testing" |
||||||
) |
) |
||||||
|
|
||||||
func assertEqual(t *testing.T, s1 string, s2 template.HTML) { |
func assertEqual(t *testing.T, s1 string, s2 template.HTML) { |
||||||
if s1 != string(s2) { |
if s1 != string(s2) { |
||||||
t.Errorf("%s should be equal %s", s2, s1) |
t.Errorf("%s should be equal %s", s2, s1) |
||||||
} |
} |
||||||
} |
} |
||||||
|
|
||||||
func assertLineEqual(t *testing.T, d1 *DiffLine, d2 *DiffLine) { |
func assertLineEqual(t *testing.T, d1 *DiffLine, d2 *DiffLine) { |
||||||
if d1 != d2 { |
if d1 != d2 { |
||||||
t.Errorf("%v should be equal %v", d1, d2) |
t.Errorf("%v should be equal %v", d1, d2) |
||||||
} |
} |
||||||
} |
} |
||||||
|
|
||||||
func TestDiffToHTML(t *testing.T) { |
func TestDiffToHTML(t *testing.T) { |
||||||
assertEqual(t, "foo <span class=\"added-code\">bar</span> biz", diffToHTML([]dmp.Diff{ |
assertEqual(t, "foo <span class=\"added-code\">bar</span> biz", diffToHTML([]dmp.Diff{ |
||||||
dmp.Diff{dmp.DiffEqual, "foo "}, |
{dmp.DiffEqual, "foo "}, |
||||||
dmp.Diff{dmp.DiffInsert, "bar"}, |
{dmp.DiffInsert, "bar"}, |
||||||
dmp.Diff{dmp.DiffDelete, " baz"}, |
{dmp.DiffDelete, " baz"}, |
||||||
dmp.Diff{dmp.DiffEqual, " biz"}, |
{dmp.DiffEqual, " biz"}, |
||||||
}, DIFF_LINE_ADD)) |
}, DIFF_LINE_ADD)) |
||||||
|
|
||||||
assertEqual(t, "foo <span class=\"removed-code\">bar</span> biz", diffToHTML([]dmp.Diff{ |
assertEqual(t, "foo <span class=\"removed-code\">bar</span> biz", diffToHTML([]dmp.Diff{ |
||||||
dmp.Diff{dmp.DiffEqual, "foo "}, |
{dmp.DiffEqual, "foo "}, |
||||||
dmp.Diff{dmp.DiffDelete, "bar"}, |
{dmp.DiffDelete, "bar"}, |
||||||
dmp.Diff{dmp.DiffInsert, " baz"}, |
{dmp.DiffInsert, " baz"}, |
||||||
dmp.Diff{dmp.DiffEqual, " biz"}, |
{dmp.DiffEqual, " biz"}, |
||||||
}, DIFF_LINE_DEL)) |
}, DIFF_LINE_DEL)) |
||||||
} |
} |
||||||
|
|
||||||
// test if GetLine is return the correct lines
|
// test if GetLine is return the correct lines
|
||||||
func TestGetLine(t *testing.T) { |
func TestGetLine(t *testing.T) { |
||||||
ds := DiffSection{Lines: []*DiffLine{ |
ds := DiffSection{Lines: []*DiffLine{ |
||||||
&DiffLine{LeftIdx: 28, RightIdx: 28, Type: DIFF_LINE_PLAIN}, |
{LeftIdx: 28, RightIdx: 28, Type: DIFF_LINE_PLAIN}, |
||||||
&DiffLine{LeftIdx: 29, RightIdx: 29, Type: DIFF_LINE_PLAIN}, |
{LeftIdx: 29, RightIdx: 29, Type: DIFF_LINE_PLAIN}, |
||||||
&DiffLine{LeftIdx: 30, RightIdx: 30, Type: DIFF_LINE_PLAIN}, |
{LeftIdx: 30, RightIdx: 30, Type: DIFF_LINE_PLAIN}, |
||||||
&DiffLine{LeftIdx: 31, RightIdx: 0, Type: DIFF_LINE_DEL}, |
{LeftIdx: 31, RightIdx: 0, Type: DIFF_LINE_DEL}, |
||||||
&DiffLine{LeftIdx: 0, RightIdx: 31, Type: DIFF_LINE_ADD}, |
{LeftIdx: 0, RightIdx: 31, Type: DIFF_LINE_ADD}, |
||||||
&DiffLine{LeftIdx: 0, RightIdx: 32, Type: DIFF_LINE_ADD}, |
{LeftIdx: 0, RightIdx: 32, Type: DIFF_LINE_ADD}, |
||||||
&DiffLine{LeftIdx: 32, RightIdx: 33, Type: DIFF_LINE_PLAIN}, |
{LeftIdx: 32, RightIdx: 33, Type: DIFF_LINE_PLAIN}, |
||||||
&DiffLine{LeftIdx: 33, RightIdx: 0, Type: DIFF_LINE_DEL}, |
{LeftIdx: 33, RightIdx: 0, Type: DIFF_LINE_DEL}, |
||||||
&DiffLine{LeftIdx: 34, RightIdx: 0, Type: DIFF_LINE_DEL}, |
{LeftIdx: 34, RightIdx: 0, Type: DIFF_LINE_DEL}, |
||||||
&DiffLine{LeftIdx: 35, RightIdx: 0, Type: DIFF_LINE_DEL}, |
{LeftIdx: 35, RightIdx: 0, Type: DIFF_LINE_DEL}, |
||||||
&DiffLine{LeftIdx: 36, RightIdx: 0, Type: DIFF_LINE_DEL}, |
{LeftIdx: 36, RightIdx: 0, Type: DIFF_LINE_DEL}, |
||||||
&DiffLine{LeftIdx: 0, RightIdx: 34, Type: DIFF_LINE_ADD}, |
{LeftIdx: 0, RightIdx: 34, Type: DIFF_LINE_ADD}, |
||||||
&DiffLine{LeftIdx: 0, RightIdx: 35, Type: DIFF_LINE_ADD}, |
{LeftIdx: 0, RightIdx: 35, Type: DIFF_LINE_ADD}, |
||||||
&DiffLine{LeftIdx: 0, RightIdx: 36, Type: DIFF_LINE_ADD}, |
{LeftIdx: 0, RightIdx: 36, Type: DIFF_LINE_ADD}, |
||||||
&DiffLine{LeftIdx: 0, RightIdx: 37, Type: DIFF_LINE_ADD}, |
{LeftIdx: 0, RightIdx: 37, Type: DIFF_LINE_ADD}, |
||||||
&DiffLine{LeftIdx: 37, RightIdx: 38, Type: DIFF_LINE_PLAIN}, |
{LeftIdx: 37, RightIdx: 38, Type: DIFF_LINE_PLAIN}, |
||||||
&DiffLine{LeftIdx: 38, RightIdx: 39, Type: DIFF_LINE_PLAIN}, |
{LeftIdx: 38, RightIdx: 39, Type: DIFF_LINE_PLAIN}, |
||||||
}} |
}} |
||||||
|
|
||||||
assertLineEqual(t, ds.GetLine(DIFF_LINE_ADD, 31), ds.Lines[4]) |
assertLineEqual(t, ds.GetLine(DIFF_LINE_ADD, 31), ds.Lines[4]) |
||||||
assertLineEqual(t, ds.GetLine(DIFF_LINE_DEL, 31), ds.Lines[3]) |
assertLineEqual(t, ds.GetLine(DIFF_LINE_DEL, 31), ds.Lines[3]) |
||||||
|
|
||||||
assertLineEqual(t, ds.GetLine(DIFF_LINE_ADD, 33), ds.Lines[11]) |
assertLineEqual(t, ds.GetLine(DIFF_LINE_ADD, 33), ds.Lines[11]) |
||||||
assertLineEqual(t, ds.GetLine(DIFF_LINE_ADD, 34), ds.Lines[12]) |
assertLineEqual(t, ds.GetLine(DIFF_LINE_ADD, 34), ds.Lines[12]) |
||||||
assertLineEqual(t, ds.GetLine(DIFF_LINE_ADD, 35), ds.Lines[13]) |
assertLineEqual(t, ds.GetLine(DIFF_LINE_ADD, 35), ds.Lines[13]) |
||||||
assertLineEqual(t, ds.GetLine(DIFF_LINE_ADD, 36), ds.Lines[14]) |
assertLineEqual(t, ds.GetLine(DIFF_LINE_ADD, 36), ds.Lines[14]) |
||||||
assertLineEqual(t, ds.GetLine(DIFF_LINE_DEL, 34), ds.Lines[7]) |
assertLineEqual(t, ds.GetLine(DIFF_LINE_DEL, 34), ds.Lines[7]) |
||||||
assertLineEqual(t, ds.GetLine(DIFF_LINE_DEL, 35), ds.Lines[8]) |
assertLineEqual(t, ds.GetLine(DIFF_LINE_DEL, 35), ds.Lines[8]) |
||||||
assertLineEqual(t, ds.GetLine(DIFF_LINE_DEL, 36), ds.Lines[9]) |
assertLineEqual(t, ds.GetLine(DIFF_LINE_DEL, 36), ds.Lines[9]) |
||||||
assertLineEqual(t, ds.GetLine(DIFF_LINE_DEL, 37), ds.Lines[10]) |
assertLineEqual(t, ds.GetLine(DIFF_LINE_DEL, 37), ds.Lines[10]) |
||||||
} |
} |
||||||
|
Loading…
Reference in new issue