sheet_test.go 8.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154
  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 := newXlsxStyleSheet()
  26. xSheet := sheet.makeXLSXSheet(refTable, styles)
  27. c.Assert(xSheet.Dimension.Ref, Equals, "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. cell1 := row.AddCell()
  52. cell1.Value = "A cell!"
  53. style1 := NewStyle()
  54. style1.Font = *NewFont(10, "Verdana")
  55. style1.Fill = *NewFill("solid", "FFFFFFFF", "00000000")
  56. style1.Border = *NewBorder("none", "thin", "none", "thin")
  57. cell1.SetStyle(style1)
  58. // We need a second style to check that Xfs are populated correctly.
  59. cell2 := row.AddCell()
  60. cell2.Value = "Another cell!"
  61. style2 := NewStyle()
  62. style2.Font = *NewFont(10, "Verdana")
  63. style2.Fill = *NewFill("solid", "FFFFFFFF", "00000000")
  64. style2.Border = *NewBorder("none", "thin", "none", "thin")
  65. cell2.SetStyle(style2)
  66. refTable := NewSharedStringRefTable()
  67. styles := newXlsxStyleSheet()
  68. worksheet := sheet.makeXLSXSheet(refTable, styles)
  69. c.Assert(styles.Fonts.Count, Equals, 1)
  70. c.Assert(styles.Fonts.Font[0].Sz.Val, Equals, "10")
  71. c.Assert(styles.Fonts.Font[0].Name.Val, Equals, "Verdana")
  72. c.Assert(styles.Fills.Count, Equals, 1)
  73. c.Assert(styles.Fills.Fill[0].PatternFill.PatternType, Equals, "solid")
  74. c.Assert(styles.Fills.Fill[0].PatternFill.FgColor.RGB, Equals, "FFFFFFFF")
  75. c.Assert(styles.Fills.Fill[0].PatternFill.BgColor.RGB, Equals, "00000000")
  76. c.Assert(styles.Borders.Count, Equals, 1)
  77. c.Assert(styles.Borders.Border[0].Left.Style, Equals, "none")
  78. c.Assert(styles.Borders.Border[0].Right.Style, Equals, "thin")
  79. c.Assert(styles.Borders.Border[0].Top.Style, Equals, "none")
  80. c.Assert(styles.Borders.Border[0].Bottom.Style, Equals, "thin")
  81. c.Assert(styles.CellStyleXfs.Count, Equals, 1)
  82. // The 0th CellStyleXf could just be getting the zero values by default
  83. c.Assert(styles.CellStyleXfs.Xf[0].FontId, Equals, 0)
  84. c.Assert(styles.CellStyleXfs.Xf[0].FillId, Equals, 0)
  85. c.Assert(styles.CellStyleXfs.Xf[0].BorderId, Equals, 0)
  86. c.Assert(styles.CellXfs.Count, Equals, 1)
  87. c.Assert(styles.CellXfs.Xf[0].FontId, Equals, 0)
  88. c.Assert(styles.CellXfs.Xf[0].FillId, Equals, 0)
  89. c.Assert(styles.CellXfs.Xf[0].BorderId, Equals, 0)
  90. // Finally we check that the cell points to the right CellXf /
  91. // CellStyleXf.
  92. c.Assert(worksheet.SheetData.Row[0].C[0].S, Equals, 0)
  93. c.Assert(worksheet.SheetData.Row[0].C[1].S, Equals, 0)
  94. }
  95. func (s *SheetSuite) TestMarshalSheet(c *C) {
  96. file := NewFile()
  97. sheet := file.AddSheet("Sheet1")
  98. row := sheet.AddRow()
  99. cell := row.AddCell()
  100. cell.Value = "A cell!"
  101. refTable := NewSharedStringRefTable()
  102. styles := newXlsxStyleSheet()
  103. xSheet := sheet.makeXLSXSheet(refTable, styles)
  104. output := bytes.NewBufferString(xml.Header)
  105. body, err := xml.Marshal(xSheet)
  106. c.Assert(err, IsNil)
  107. c.Assert(body, NotNil)
  108. _, err = output.Write(body)
  109. c.Assert(err, IsNil)
  110. expectedXLSXSheet := `<?xml version="1.0" encoding="UTF-8"?>
  111. <worksheet xmlns="http://schemas.openxmlformats.org/spreadsheetml/2006/main"><sheetPr filterMode="false"><pageSetUpPr fitToPage="false"></pageSetUpPr></sheetPr><sheetViews><sheetView windowProtection="false" showFormulas="false" showGridLines="true" showRowColHeaders="true" showZeros="true" rightToLeft="false" tabSelected="true" showOutlineSymbols="true" defaultGridColor="true" view="normal" topLeftCell="A1" colorId="64" zoomScale="100" zoomScaleNormal="100" zoomScalePageLayoutView="100" workbookViewId="0"><selection pane="topLeft" activeCell="A1" activeCellId="0" sqref="A1"></selection></sheetView></sheetViews><sheetFormatPr defaultRowHeight="12.85"></sheetFormatPr><dimension ref="A1"></dimension><cols><col collapsed="false" hidden="false" max="1" min="1" width="9.5"></col></cols><printOptions headings="false" gridLines="false" gridLinesSet="true" horizontalCentered="false" verticalCentered="false"></printOptions><pageMargins left="0.7875" right="0.7875" top="1.05277777777778" bottom="1.05277777777778" header="0.7875" footer="0.7875"></pageMargins><pageSetup paperSize="9" scale="100" firstPageNumber="1" fitToWidth="1" fitToHeight="1" pageOrder="downThenOver" orientation="portrait" usePrinterDefaults="false" blackAndWhite="false" draft="false" cellComments="none" useFirstPageNumber="true" horizontalDpi="300" verticalDpi="300" copies="1"></pageSetup><sheetData><row r="1"><c r="A1" s="0" t="s"><v>0</v></c></row></sheetData><headerFooter differentFirst="false" differentOddEven="false"><oddHeader>&amp;C&amp;&#34;Times New Roman,Regular&#34;&amp;12&amp;A</oddHeader><oddFooter>&amp;C&amp;&#34;Times New Roman,Regular&#34;&amp;12Page &amp;P</oddFooter></headerFooter></worksheet>`
  112. c.Assert(output.String(), Equals, expectedXLSXSheet)
  113. }
  114. func (s *SheetSuite) TestMarshalSheetWithMultipleCells(c *C) {
  115. file := NewFile()
  116. sheet := file.AddSheet("Sheet1")
  117. row := sheet.AddRow()
  118. cell := row.AddCell()
  119. cell.Value = "A cell (with value 1)!"
  120. cell = row.AddCell()
  121. cell.Value = "A cell (with value 2)!"
  122. refTable := NewSharedStringRefTable()
  123. styles := newXlsxStyleSheet()
  124. xSheet := sheet.makeXLSXSheet(refTable, styles)
  125. output := bytes.NewBufferString(xml.Header)
  126. body, err := xml.Marshal(xSheet)
  127. c.Assert(err, IsNil)
  128. c.Assert(body, NotNil)
  129. _, err = output.Write(body)
  130. c.Assert(err, IsNil)
  131. expectedXLSXSheet := `<?xml version="1.0" encoding="UTF-8"?>
  132. <worksheet xmlns="http://schemas.openxmlformats.org/spreadsheetml/2006/main"><sheetPr filterMode="false"><pageSetUpPr fitToPage="false"></pageSetUpPr></sheetPr><sheetViews><sheetView windowProtection="false" showFormulas="false" showGridLines="true" showRowColHeaders="true" showZeros="true" rightToLeft="false" tabSelected="true" showOutlineSymbols="true" defaultGridColor="true" view="normal" topLeftCell="A1" colorId="64" zoomScale="100" zoomScaleNormal="100" zoomScalePageLayoutView="100" workbookViewId="0"><selection pane="topLeft" activeCell="A1" activeCellId="0" sqref="A1"></selection></sheetView></sheetViews><sheetFormatPr defaultRowHeight="12.85"></sheetFormatPr><dimension ref="A1:B1"></dimension><cols><col collapsed="false" hidden="false" max="1" min="1" width="9.5"></col><col collapsed="false" hidden="false" max="2" min="2" width="9.5"></col></cols><printOptions headings="false" gridLines="false" gridLinesSet="true" horizontalCentered="false" verticalCentered="false"></printOptions><pageMargins left="0.7875" right="0.7875" top="1.05277777777778" bottom="1.05277777777778" header="0.7875" footer="0.7875"></pageMargins><pageSetup paperSize="9" scale="100" firstPageNumber="1" fitToWidth="1" fitToHeight="1" pageOrder="downThenOver" orientation="portrait" usePrinterDefaults="false" blackAndWhite="false" draft="false" cellComments="none" useFirstPageNumber="true" horizontalDpi="300" verticalDpi="300" copies="1"></pageSetup><sheetData><row r="1"><c r="A1" s="0" t="s"><v>0</v></c><c r="B1" s="0" t="s"><v>1</v></c></row></sheetData><headerFooter differentFirst="false" differentOddEven="false"><oddHeader>&amp;C&amp;&#34;Times New Roman,Regular&#34;&amp;12&amp;A</oddHeader><oddFooter>&amp;C&amp;&#34;Times New Roman,Regular&#34;&amp;12Page &amp;P</oddFooter></headerFooter></worksheet>`
  133. c.Assert(output.String(), Equals, expectedXLSXSheet)
  134. }