You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
55 lines
1013 B
55 lines
1013 B
6 years ago
|
package excelize
|
||
|
|
||
|
import (
|
||
|
"path/filepath"
|
||
|
"testing"
|
||
|
|
||
|
"github.com/stretchr/testify/assert"
|
||
|
)
|
||
|
|
||
|
func TestGetMergeCells(t *testing.T) {
|
||
|
wants := []struct {
|
||
|
value string
|
||
|
start string
|
||
|
end string
|
||
|
}{{
|
||
|
value: "A1",
|
||
|
start: "A1",
|
||
|
end: "B1",
|
||
|
}, {
|
||
|
value: "A2",
|
||
|
start: "A2",
|
||
|
end: "A3",
|
||
|
}, {
|
||
|
value: "A4",
|
||
|
start: "A4",
|
||
|
end: "B5",
|
||
|
}, {
|
||
|
value: "A7",
|
||
|
start: "A7",
|
||
|
end: "C10",
|
||
|
}}
|
||
|
|
||
|
f, err := OpenFile(filepath.Join("test", "MergeCell.xlsx"))
|
||
|
if !assert.NoError(t, err) {
|
||
|
t.FailNow()
|
||
|
}
|
||
|
sheet1 := f.GetSheetName(1)
|
||
|
|
||
|
mergeCells, err := f.GetMergeCells(sheet1)
|
||
|
if !assert.Len(t, mergeCells, len(wants)) {
|
||
|
t.FailNow()
|
||
|
}
|
||
|
assert.NoError(t, err)
|
||
|
|
||
|
for i, m := range mergeCells {
|
||
|
assert.Equal(t, wants[i].value, m.GetCellValue())
|
||
|
assert.Equal(t, wants[i].start, m.GetStartAxis())
|
||
|
assert.Equal(t, wants[i].end, m.GetEndAxis())
|
||
|
}
|
||
|
|
||
|
// Test get merged cells on not exists worksheet.
|
||
|
_, err = f.GetMergeCells("SheetN")
|
||
|
assert.EqualError(t, err, "sheet SheetN is not exist")
|
||
|
}
|