unioffice/spreadsheet/worksheet_test.go
Vyacheslav Zgordan dd7713e1e3 Functions2 (#348)
* MATCH, IFS, MAXA, MINA
* OFFSET fixed
* ISBLANK, ISERR, ISERROR, ISEVEN ,ISFORMULA, ISNONTEXT, ISNUMBER, ISODD, ISTEXT
* ISLEAPYEAR, ISLOGICAL, ISNA, ISREF
* FIND, FINDB
* SEARCH, SEARCHB
* CONCAT, CONCATENATE
* YEAR, YEARFRAC
* CONCAT is fixed, now TRUE and FALSE are concatenated instead of 1 and 0 in case of boolean results
* NOW, TODAY, TIME, TIMEVALUE
* DATE
* DATEDIF
2019-11-20 23:21:00 +00:00

67 lines
1.8 KiB
Go

// Copyright 2017 FoxyUtils ehf. All rights reserved.
//
// Use of this source code is governed by the terms of the Affero GNU General
// Public License version 3.0 as published by the Free Software Foundation and
// appearing in the file LICENSE included in the packaging of this file. A
// commercial license can be purchased on https://unidoc.io.
package spreadsheet_test
import (
"bytes"
"encoding/xml"
"fmt"
"os"
"testing"
"github.com/unidoc/unioffice/schema/soo/sml"
"github.com/unidoc/unioffice/spreadsheet"
"github.com/unidoc/unioffice/testhelper"
"github.com/unidoc/unioffice/zippkg"
)
func TestWorksheetUnmarshal(t *testing.T) {
f, err := os.Open("testdata/worksheet.xml")
if err != nil {
t.Fatalf("error reading content types file")
}
dec := xml.NewDecoder(f)
r := sml.NewWorksheet()
if err := dec.Decode(r); err != nil {
t.Errorf("error decoding content types: %s", err)
}
got := &bytes.Buffer{}
fmt.Fprintf(got, zippkg.XMLHeader)
enc := xml.NewEncoder(zippkg.SelfClosingWriter{W: got})
if err := enc.Encode(r); err != nil {
t.Errorf("error encoding content types: %s", err)
}
testhelper.CompareGoldenXML(t, "worksheet.xml", got.Bytes())
}
// Issue #212
func TestInsertMergedCells(t *testing.T) {
wb := spreadsheet.New()
sheet := wb.AddSheet()
sheet.AddMergedCells("A1", "C1")
sheet.AddMergedCells("A2", "C2")
sheet.AddMergedCells("A3", "C3")
sheet.AddMergedCells("D1", "E3")
sheet.InsertRow(2)
// should go down a line
for i, exp := range []string{
"A1:C1", // before inserted row, no change
"A3:C3", // after inserted row, moved down
"A4:C4", // after inserted row, moved down
"D1:E4", // covers inserted row, expanded
} {
got := sheet.MergedCells()[i].Reference()
if got != exp {
t.Errorf("expected %s, got %s", exp, got)
}
}
}