sheet_test.go 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. package xlsx
  2. import (
  3. "bytes"
  4. "encoding/xml"
  5. . "gopkg.in/check.v1"
  6. )
  7. type SheetSuite struct{}
  8. var _ = Suite(&SheetSuite{})
  9. // Test we can add a Row to a Sheet
  10. func (s *SheetSuite) TestAddRow(c *C) {
  11. var f *File
  12. f = NewFile()
  13. sheet := f.AddSheet("MySheet")
  14. row := sheet.AddRow()
  15. c.Assert(row, NotNil)
  16. c.Assert(len(sheet.Rows), Equals, 1)
  17. }
  18. func (s *SheetSuite) TestMakeXLSXSheetFromRows(c *C) {
  19. file := NewFile()
  20. sheet := file.AddSheet("Sheet1")
  21. row := sheet.AddRow()
  22. cell := row.AddCell()
  23. cell.Value = "A cell!"
  24. refTable := NewSharedStringRefTable()
  25. styles := &xlsxStyles{}
  26. xSheet := sheet.makeXLSXSheet(refTable, styles)
  27. c.Assert(xSheet.Dimension.Ref, Equals, "A1:A1")
  28. c.Assert(xSheet.SheetData.Row, HasLen, 1)
  29. xRow := xSheet.SheetData.Row[0]
  30. c.Assert(xRow.R, Equals, 1)
  31. c.Assert(xRow.Spans, Equals, "")
  32. c.Assert(xRow.C, HasLen, 1)
  33. xC := xRow.C[0]
  34. c.Assert(xC.R, Equals, "A1")
  35. c.Assert(xC.S, Equals, 0)
  36. c.Assert(xC.T, Equals, "s") // Shared string type
  37. c.Assert(xC.V, Equals, "0") // reference to shared string
  38. xSST := refTable.makeXLSXSST()
  39. c.Assert(xSST.Count, Equals, 1)
  40. c.Assert(xSST.UniqueCount, Equals, 1)
  41. c.Assert(xSST.SI, HasLen, 1)
  42. xSI := xSST.SI[0]
  43. c.Assert(xSI.T, Equals, "A cell!")
  44. }
  45. // When we create the xlsxSheet we also populate the xlsxStyles struct
  46. // with style information.
  47. func (s *SheetSuite) TestMakeXLSXSheetAlsoPopulatesXLSXSTyles(c *C) {
  48. file := NewFile()
  49. sheet := file.AddSheet("Sheet1")
  50. row := sheet.AddRow()
  51. cell := row.AddCell()
  52. cell.Value = "A cell!"
  53. style := *NewStyle()
  54. style.Font = *NewFont(10, "Verdana")
  55. style.Fill = *NewFill("solid", "FFFFFFFF", "00000000")
  56. style.Border = *NewBorder("none", "thin", "none", "thin")
  57. cell.SetStyle(style)
  58. refTable := NewSharedStringRefTable()
  59. styles := &xlsxStyles{}
  60. _ = sheet.makeXLSXSheet(refTable, styles)
  61. c.Assert(len(styles.Fonts), Equals, 1)
  62. // YOU ARE HERE
  63. c.Assert(styles.Fonts[0].Sz.Val, Equals, "10")
  64. c.Assert(styles.Fonts[0].Name.Val, Equals, "Verdana")
  65. c.Assert(len(styles.Fills), Equals, 1)
  66. c.Assert(styles.Fills[0].PatternFill.PatternType, Equals, "solid")
  67. c.Assert(styles.Fills[0].PatternFill.FgColor.RGB, Equals, "FFFFFFFF")
  68. c.Assert(styles.Fills[0].PatternFill.BgColor.RGB, Equals, "00000000")
  69. c.Assert(len(styles.Borders), Equals, 1)
  70. c.Assert(styles.Borders[0].Left.Style, Equals, "none")
  71. c.Assert(styles.Borders[0].Right.Style, Equals, "thin")
  72. c.Assert(styles.Borders[0].Top.Style, Equals, "none")
  73. c.Assert(styles.Borders[0].Bottom.Style, Equals, "thin")
  74. }
  75. func (s *SheetSuite) TestMarshalSheet(c *C) {
  76. file := NewFile()
  77. sheet := file.AddSheet("Sheet1")
  78. row := sheet.AddRow()
  79. cell := row.AddCell()
  80. cell.Value = "A cell!"
  81. refTable := NewSharedStringRefTable()
  82. styles := &xlsxStyles{}
  83. xSheet := sheet.makeXLSXSheet(refTable, styles)
  84. output := bytes.NewBufferString(xml.Header)
  85. body, err := xml.MarshalIndent(xSheet, " ", " ")
  86. c.Assert(err, IsNil)
  87. c.Assert(body, NotNil)
  88. _, err = output.Write(body)
  89. c.Assert(err, IsNil)
  90. expectedXLSXSheet := `<?xml version="1.0" encoding="UTF-8"?>
  91. <worksheet xmlns="http://schemas.openxmlformats.org/spreadsheetml/2006/main">
  92. <dimension ref="A1:A1"></dimension>
  93. <cols></cols>
  94. <sheetData>
  95. <row r="1">
  96. <c r="A1" t="s">
  97. <v>0</v>
  98. </c>
  99. </row>
  100. </sheetData>
  101. </worksheet>`
  102. c.Assert(output.String(), Equals, expectedXLSXSheet)
  103. }