sheet_test.go 2.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  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. xSheet:= sheet.makeXLSXSheet(refTable)
  26. c.Assert(xSheet.Dimension.Ref, Equals, "A1:A1")
  27. c.Assert(xSheet.SheetData.Row, HasLen, 1)
  28. xRow := xSheet.SheetData.Row[0]
  29. c.Assert(xRow.R, Equals, 1)
  30. c.Assert(xRow.Spans, Equals, "")
  31. c.Assert(xRow.C, HasLen, 1)
  32. xC := xRow.C[0]
  33. c.Assert(xC.R, Equals, "A1")
  34. c.Assert(xC.S, Equals, 0)
  35. c.Assert(xC.T, Equals, "s") // Shared string type
  36. c.Assert(xC.V, Equals, "0") // reference to shared string
  37. xSST := refTable.makeXLSXSST()
  38. c.Assert(xSST.Count, Equals, 1)
  39. c.Assert(xSST.UniqueCount, Equals, 1)
  40. c.Assert(xSST.SI, HasLen, 1)
  41. xSI := xSST.SI[0]
  42. c.Assert(xSI.T, Equals, "A cell!")
  43. }
  44. func (s *SheetSuite) TestMarshalSheet(c *C) {
  45. file := NewFile()
  46. sheet := file.AddSheet("Sheet1")
  47. row := sheet.AddRow()
  48. cell := row.AddCell()
  49. cell.Value = "A cell!"
  50. refTable := NewSharedStringRefTable()
  51. xSheet:= sheet.makeXLSXSheet(refTable)
  52. output := bytes.NewBufferString(xml.Header)
  53. body, err := xml.MarshalIndent(xSheet, " ", " ")
  54. c.Assert(err, IsNil)
  55. c.Assert(body, NotNil)
  56. _, err = output.Write(body)
  57. c.Assert(err, IsNil)
  58. expectedXLSXSheet := `<?xml version="1.0" encoding="UTF-8"?>
  59. <worksheet xmlns="http://schemas.openxmlformats.org/spreadsheetml/2006/main">
  60. <dimension ref="A1:A1"></dimension>
  61. <sheetData>
  62. <row r="1">
  63. <c r="A1" t="s">
  64. <v>0</v>
  65. </c>
  66. </row>
  67. </sheetData>
  68. </worksheet>`
  69. c.Assert(output.String(), Equals, expectedXLSXSheet)
  70. }