| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125 |
- 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"))
- }
- }
|