write_test.go 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. package xlsx
  2. import (
  3. . "gopkg.in/check.v1"
  4. )
  5. type WriteSuite struct{}
  6. var _ = Suite(&WriteSuite{})
  7. // Test if we can write a struct to a row
  8. func (r *RowSuite) TestWriteStruct(c *C) {
  9. var f *File
  10. f = NewFile()
  11. sheet := f.AddSheet("Test1")
  12. row := sheet.AddRow()
  13. type e struct {
  14. FirstName string
  15. Age int
  16. GPA float64
  17. LikesPHP bool
  18. }
  19. testStruct := e{
  20. "Eric",
  21. 20,
  22. 3.94,
  23. false,
  24. }
  25. row.WriteStruct(&testStruct, -1)
  26. c.Assert(row, NotNil)
  27. c0 := row.Cells[0].String()
  28. c1, e1 := row.Cells[1].Int()
  29. c2, e2 := row.Cells[2].Float()
  30. c3 := row.Cells[3].Bool()
  31. c.Assert(c0, Equals, "Eric")
  32. c.Assert(c1, Equals, 20)
  33. c.Assert(c2, Equals, 3.94)
  34. c.Assert(c3, Equals, false)
  35. c.Assert(e1, Equals, nil)
  36. c.Assert(e2, Equals, nil)
  37. }
  38. // Test if we can write a slice to a row
  39. func (r *RowSuite) TestWriteSlice(c *C) {
  40. var f *File
  41. f = NewFile()
  42. sheet := f.AddSheet("Test1")
  43. type strA []string
  44. type intA []int
  45. type floatA []float64
  46. type boolA []bool
  47. s0 := strA{"Eric"}
  48. row0 := sheet.AddRow()
  49. row0.WriteSlice(&s0, -1)
  50. c.Assert(row0, NotNil)
  51. c0 := row0.Cells[0].String()
  52. c.Assert(c0, Equals, "Eric")
  53. s1 := intA{10}
  54. row1 := sheet.AddRow()
  55. row1.WriteSlice(&s1, -1)
  56. c.Assert(row1, NotNil)
  57. c1, e1 := row1.Cells[0].Int()
  58. c.Assert(e1, Equals, nil)
  59. c.Assert(c1, Equals, 10)
  60. s2 := floatA{3.94}
  61. row2 := sheet.AddRow()
  62. row2.WriteSlice(&s2, -1)
  63. c.Assert(row2, NotNil)
  64. c2, e2 := row2.Cells[0].Float()
  65. c.Assert(e2, Equals, nil)
  66. c.Assert(c2, Equals, 3.94)
  67. s3 := boolA{true}
  68. row3 := sheet.AddRow()
  69. row3.WriteSlice(&s3, -1)
  70. c.Assert(row3, NotNil)
  71. c3 := row3.Cells[0].Bool()
  72. c.Assert(c3, Equals, true)
  73. }