jet/postgres/insert_statement_test.go

148 lines
3.1 KiB
Go
Raw Normal View History

2019-08-11 09:52:02 +02:00
package postgres
import (
"github.com/stretchr/testify/assert"
2019-08-11 09:52:02 +02:00
"testing"
"time"
)
2019-08-12 12:27:33 +02:00
func TestInvalidInsert(t *testing.T) {
assertStatementSqlErr(t, table1.INSERT(table1Col1), "jet: VALUES or QUERY has to be specified for INSERT statement")
2019-08-12 12:27:33 +02:00
assertStatementSqlErr(t, table1.INSERT(nil).VALUES(1), "jet: nil column in columns list")
}
2019-08-11 09:52:02 +02:00
func TestInsertNilValue(t *testing.T) {
2019-08-12 12:11:16 +02:00
assertStatementSql(t, table1.INSERT(table1Col1).VALUES(nil), `
2019-08-11 09:52:02 +02:00
INSERT INTO db.table1 (col1) VALUES
($1);
`, nil)
}
func TestInsertSingleValue(t *testing.T) {
2019-08-12 12:11:16 +02:00
assertStatementSql(t, table1.INSERT(table1Col1).VALUES(1), `
2019-08-11 09:52:02 +02:00
INSERT INTO db.table1 (col1) VALUES
($1);
`, int(1))
}
func TestInsertWithColumnList(t *testing.T) {
columnList := ColumnList{table3ColInt, table3StrCol}
2019-08-11 09:52:02 +02:00
2019-08-12 12:11:16 +02:00
assertStatementSql(t, table3.INSERT(columnList).VALUES(1, 3), `
2019-08-11 09:52:02 +02:00
INSERT INTO db.table3 (col_int, col2) VALUES
($1, $2);
`, 1, 3)
}
func TestInsertDate(t *testing.T) {
date := time.Date(1999, 1, 2, 3, 4, 5, 0, time.UTC)
2019-08-12 12:11:16 +02:00
assertStatementSql(t, table1.INSERT(table1ColTime).VALUES(date), `
2019-08-11 09:52:02 +02:00
INSERT INTO db.table1 (col_time) VALUES
($1);
`, date)
}
func TestInsertMultipleValues(t *testing.T) {
2019-08-12 12:11:16 +02:00
assertStatementSql(t, table1.INSERT(table1Col1, table1ColFloat, table1Col3).VALUES(1, 2, 3), `
2019-08-11 09:52:02 +02:00
INSERT INTO db.table1 (col1, col_float, col3) VALUES
($1, $2, $3);
`, 1, 2, 3)
}
func TestInsertMultipleRows(t *testing.T) {
stmt := table1.INSERT(table1Col1, table1ColFloat).
VALUES(1, 2).
VALUES(11, 22).
VALUES(111, 222)
2019-08-12 12:11:16 +02:00
assertStatementSql(t, stmt, `
2019-08-11 09:52:02 +02:00
INSERT INTO db.table1 (col1, col_float) VALUES
($1, $2),
($3, $4),
($5, $6);
`, 1, 2, 11, 22, 111, 222)
}
func TestInsertValuesFromModel(t *testing.T) {
type Table1Model struct {
Col1 *int
ColFloat float64
}
one := 1
toInsert := Table1Model{
Col1: &one,
ColFloat: 1.11,
}
stmt := table1.INSERT(table1Col1, table1ColFloat).
MODEL(toInsert).
MODEL(&toInsert)
expectedSQL := `
INSERT INTO db.table1 (col1, col_float) VALUES
($1, $2),
($3, $4);
`
2019-08-12 12:11:16 +02:00
assertStatementSql(t, stmt, expectedSQL, int(1), float64(1.11), int(1), float64(1.11))
2019-08-11 09:52:02 +02:00
}
func TestInsertValuesFromModelColumnMismatch(t *testing.T) {
defer func() {
r := recover()
assert.Equal(t, r, "missing struct field for column : col1")
}()
type Table1Model struct {
Col1Prim int
Col2 string
}
newData := Table1Model{
Col1Prim: 1,
Col2: "one",
}
table1.
INSERT(table1Col1, table1ColFloat).
MODEL(newData)
}
func TestInsertFromNonStructModel(t *testing.T) {
defer func() {
r := recover()
assert.Equal(t, r, "jet: data has to be a struct")
2019-08-11 09:52:02 +02:00
}()
table2.INSERT(table2ColInt).MODEL([]int{})
}
func TestInsertQuery(t *testing.T) {
stmt := table1.INSERT(table1Col1).
QUERY(table1.SELECT(table1Col1))
var expectedSQL = `
INSERT INTO db.table1 (col1) (
SELECT table1.col1 AS "table1.col1"
FROM db.table1
);
`
2019-08-12 12:11:16 +02:00
assertStatementSql(t, stmt, expectedSQL)
2019-08-11 09:52:02 +02:00
}
func TestInsertDefaultValue(t *testing.T) {
stmt := table1.INSERT(table1Col1, table1ColFloat).
VALUES(DEFAULT, "two")
var expectedSQL = `
INSERT INTO db.table1 (col1, col_float) VALUES
(DEFAULT, $1);
`
2019-08-12 12:11:16 +02:00
assertStatementSql(t, stmt, expectedSQL, "two")
2019-08-11 09:52:02 +02:00
}