datetime.go 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. package basic
  2. import (
  3. "fmt"
  4. "testing"
  5. "time"
  6. . "git.wecise.com/wecise/odbserver/odb"
  7. "git.wecise.com/wecise/odbserver/odb/test"
  8. "gitee.com/wecisecode/util/logger"
  9. "github.com/stretchr/testify/assert"
  10. "github.com/stretchr/testify/require"
  11. )
  12. type DatetimeTests struct {
  13. Test *testing.T
  14. g *Gutil
  15. }
  16. func DateTimeTest(t *testing.T) {
  17. g := test.TestG()
  18. t.Run("InitG", func(t *testing.T) {
  19. test := &DatetimeTests{Test: t, g: g}
  20. test.InitG()
  21. })
  22. t.Run("Class", func(t *testing.T) {
  23. test := &DatetimeTests{Test: t, g: g}
  24. test.Class()
  25. })
  26. t.Run("Data", func(t *testing.T) {
  27. test := &DatetimeTests{Test: t, g: g}
  28. test.Data()
  29. })
  30. time.Sleep(time.Duration(1) * time.Second)
  31. t.Run("Valid", func(t *testing.T) {
  32. test := &DatetimeTests{Test: t, g: g}
  33. test.Valid()
  34. })
  35. t.Run("Search", func(t *testing.T) {
  36. test := &DatetimeTests{Test: t, g: g}
  37. test.Search()
  38. })
  39. }
  40. func (t *DatetimeTests) InitG() {
  41. require.NotNil(t.Test, t.g)
  42. }
  43. func (t *DatetimeTests) Class() {
  44. _, _, err := t.g.Query(`
  45. create class if not exists /test/datetime (
  46. v_varchar varchar,
  47. v_timestamp timestamp,
  48. v_date date,
  49. indexes(v_varchar, v_timestamp, v_date),
  50. keys(v_varchar)
  51. );`)
  52. if err != nil {
  53. logger.Errorf("%v", err)
  54. }
  55. require.Nil(t.Test, err, fmt.Sprint(err))
  56. }
  57. func (t *DatetimeTests) Data() {
  58. var err error
  59. _, _, err = t.g.Query(`insert into /test/datetime (v_varchar, v_date, v_timestamp) values ('1', '2019-10-20', '2019-10-20 23:59:59' )`)
  60. _, _, err = t.g.Query(`insert into /test/datetime (v_varchar, v_date, v_timestamp) values ('2', '2019-10-21', '2019-10-21 23:59:59' )`)
  61. _, _, err = t.g.Query(`insert into /test/datetime (v_varchar, v_date, v_timestamp) values ('3', '2019-10-22', '2019-10-22 23:59:59' )`)
  62. if err != nil {
  63. logger.Errorf("%v", err)
  64. }
  65. require.Nil(t.Test, err, fmt.Sprint(err))
  66. }
  67. func (t *DatetimeTests) Valid() {
  68. rtn, _, err := t.g.Query(`select * from /test/datetime`)
  69. if err != nil {
  70. logger.Errorf("%v", err)
  71. }
  72. if assert.Nil(t.Test, err) {
  73. assert.Equal(t.Test, len(rtn), 3, "they should be equal")
  74. }
  75. }
  76. func (t *DatetimeTests) Search() {
  77. var err error
  78. var rtn []map[string]interface{}
  79. rtn, _, err = t.g.Query(`select * from /test/datetime where v_date = '2019-10-20'`)
  80. if err != nil {
  81. logger.Errorf("%v", err)
  82. }
  83. if assert.Nil(t.Test, err) {
  84. assert.Equal(t.Test, 1, len(rtn), fmt.Sprintf("not find v_date = %v", "2019-10-20"))
  85. }
  86. rtn, _, err = t.g.Query(`select * from /test/datetime where v_timestamp = '2019-10-20 23:59:59'`)
  87. if err != nil {
  88. logger.Errorf("%v", err)
  89. }
  90. if assert.Nil(t.Test, err) {
  91. assert.Equal(t.Test, 1, len(rtn), fmt.Sprintf("not find v_timestamp = %v", "2019-10-20 23:59:59"))
  92. }
  93. }