package basic import ( "fmt" "testing" "time" . "git.wecise.com/wecise/odbserver/odb" "git.wecise.com/wecise/odbserver/odb/test" "gitee.com/wecisecode/util/logger" "github.com/stretchr/testify/assert" "github.com/stretchr/testify/require" ) type DatetimeTests struct { Test *testing.T g *Gutil } func DateTimeTest(t *testing.T) { g := test.TestG() t.Run("InitG", func(t *testing.T) { test := &DatetimeTests{Test: t, g: g} test.InitG() }) t.Run("Class", func(t *testing.T) { test := &DatetimeTests{Test: t, g: g} test.Class() }) t.Run("Data", func(t *testing.T) { test := &DatetimeTests{Test: t, g: g} test.Data() }) time.Sleep(time.Duration(1) * time.Second) t.Run("Valid", func(t *testing.T) { test := &DatetimeTests{Test: t, g: g} test.Valid() }) t.Run("Search", func(t *testing.T) { test := &DatetimeTests{Test: t, g: g} test.Search() }) } func (t *DatetimeTests) InitG() { require.NotNil(t.Test, t.g) } func (t *DatetimeTests) Class() { _, _, err := t.g.Query(` create class if not exists /test/datetime ( v_varchar varchar, v_timestamp timestamp, v_date date, indexes(v_varchar, v_timestamp, v_date), keys(v_varchar) );`) if err != nil { logger.Errorf("%v", err) } require.Nil(t.Test, err, fmt.Sprint(err)) } func (t *DatetimeTests) Data() { var err error _, _, 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' )`) _, _, 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' )`) _, _, 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' )`) if err != nil { logger.Errorf("%v", err) } require.Nil(t.Test, err, fmt.Sprint(err)) } func (t *DatetimeTests) Valid() { rtn, _, err := t.g.Query(`select * from /test/datetime`) if err != nil { logger.Errorf("%v", err) } if assert.Nil(t.Test, err) { assert.Equal(t.Test, len(rtn), 3, "they should be equal") } } func (t *DatetimeTests) Search() { var err error var rtn []map[string]interface{} rtn, _, err = t.g.Query(`select * from /test/datetime where v_date = '2019-10-20'`) if err != nil { logger.Errorf("%v", err) } if assert.Nil(t.Test, err) { assert.Equal(t.Test, 1, len(rtn), fmt.Sprintf("not find v_date = %v", "2019-10-20")) } rtn, _, err = t.g.Query(`select * from /test/datetime where v_timestamp = '2019-10-20 23:59:59'`) if err != nil { logger.Errorf("%v", err) } if assert.Nil(t.Test, err) { assert.Equal(t.Test, 1, len(rtn), fmt.Sprintf("not find v_timestamp = %v", "2019-10-20 23:59:59")) } }