jet/sqlbuilder/func_expression_test.go

45 lines
1.1 KiB
Go
Raw Normal View History

2019-05-06 12:42:15 +02:00
package sqlbuilder
import (
"gotest.tools/assert"
"testing"
)
func TestCase1(t *testing.T) {
query := CASE().
WHEN(table3Col1.EqL(1)).THEN(table3Col1.Add(IntLiteral(1))).
WHEN(table3Col1.EqL(2)).THEN(table3Col1.Add(IntLiteral(2)))
queryData := &queryData{}
2019-05-07 19:06:21 +02:00
err := query.serialize(queryData)
2019-05-06 12:42:15 +02:00
assert.NilError(t, err)
assert.Equal(t, queryData.buff.String(), `(CASE WHEN table3.col1 = $1 THEN table3.col1 + $2 WHEN table3.col1 = $3 THEN table3.col1 + $4 END)`)
}
func TestCase2(t *testing.T) {
query := CASE(table3Col1).
WHEN(IntLiteral(1)).THEN(table3Col1.Add(IntLiteral(1))).
WHEN(IntLiteral(2)).THEN(table3Col1.Add(IntLiteral(2))).
ELSE(IntLiteral(0))
queryData := &queryData{}
2019-05-07 19:06:21 +02:00
err := query.serialize(queryData)
2019-05-06 12:42:15 +02:00
assert.NilError(t, err)
assert.Equal(t, queryData.buff.String(), `(CASE table3.col1 WHEN $1 THEN table3.col1 + $2 WHEN $3 THEN table3.col1 + $4 ELSE $5 END)`)
}
2019-05-06 14:01:50 +02:00
func TestInterval(t *testing.T) {
query := INTERVAL(`6 years 5 months 4 days 3 hours 2 minutes 1 second`)
queryData := &queryData{}
2019-05-07 19:06:21 +02:00
err := query.serialize(queryData)
2019-05-06 14:01:50 +02:00
assert.NilError(t, err)
assert.Equal(t, queryData.buff.String(), `INTERVAL $1`)
}