forked from tealeg/xlsx
-
Notifications
You must be signed in to change notification settings - Fork 0
/
sharedstrings_test.go
74 lines (68 loc) · 2.58 KB
/
sharedstrings_test.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
package xlsx
import (
"bytes"
"encoding/xml"
"testing"
)
// Test we can correctly convert a xlsxSST into a reference table using xlsx.MakeSharedStringRefTable().
func TestMakeSharedStringRefTable(t *testing.T) {
var sharedstringsXML = bytes.NewBufferString(`<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<sst xmlns="http://schemas.openxmlformats.org/spreadsheetml/2006/main" count="4" uniqueCount="4"><si><t>Foo</t></si><si><t>Bar</t></si><si><t xml:space="preserve">Baz </t></si><si><t>Quuk</t></si></sst>`)
sst := new(xlsxSST)
error := xml.NewDecoder(sharedstringsXML).Decode(sst)
if error != nil {
t.Error(error.Error())
return
}
reftable := MakeSharedStringRefTable(sst)
if len(reftable) == 0 {
t.Error("Reftable is zero length.")
return
}
if reftable[0] != "Foo" {
t.Error("RefTable lookup failed, expected reftable[0] == 'Foo'")
}
if reftable[1] != "Bar" {
t.Error("RefTable lookup failed, expected reftable[1] == 'Bar'")
}
}
// Test we can correctly resolve a numeric reference in the reference table to a string value using xlsx.ResolveSharedString().
func TestResolveSharedString(t *testing.T) {
var sharedstringsXML = bytes.NewBufferString(`<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<sst xmlns="http://schemas.openxmlformats.org/spreadsheetml/2006/main" count="4" uniqueCount="4"><si><t>Foo</t></si><si><t>Bar</t></si><si><t xml:space="preserve">Baz </t></si><si><t>Quuk</t></si></sst>`)
sst := new(xlsxSST)
error := xml.NewDecoder(sharedstringsXML).Decode(sst)
if error != nil {
t.Error(error.Error())
return
}
reftable := MakeSharedStringRefTable(sst)
if ResolveSharedString(reftable, 0) != "Foo" {
t.Error("Expected ResolveSharedString(reftable, 0) == 'Foo'")
}
}
// Test we can correctly unmarshal an the sharedstrings.xml file into
// an xlsx.xlsxSST struct and it's associated children.
func TestUnmarshallSharedStrings(t *testing.T) {
var sharedstringsXML = bytes.NewBufferString(`<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<sst xmlns="http://schemas.openxmlformats.org/spreadsheetml/2006/main" count="4" uniqueCount="4"><si><t>Foo</t></si><si><t>Bar</t></si><si><t xml:space="preserve">Baz </t></si><si><t>Quuk</t></si></sst>`)
sst := new(xlsxSST)
error := xml.NewDecoder(sharedstringsXML).Decode(sst)
if error != nil {
t.Error(error.Error())
return
}
if sst.Count != "4" {
t.Error(`sst.Count != "4"`)
}
if sst.UniqueCount != "4" {
t.Error(`sst.UniqueCount != 4`)
}
if len(sst.SI) == 0 {
t.Error("Expected 4 sst.SI but found none")
}
si := sst.SI[0]
if si.T != "Foo" {
t.Error("Expected s.T.Data == 'Foo'")
}
}