blob: 8e79cf03c0168e26073a45b2ae70afd6e60eb9f9 [file] [log] [blame] [edit]
package squirrel
import (
"testing"
"github.com/stretchr/testify/assert"
)
func TestDeleteBuilderToSql(t *testing.T) {
b := Delete("").
Prefix("WITH prefix AS ?", 0).
From("a").
Where("b = ?", 1).
OrderBy("c").
Limit(2).
Offset(3).
Suffix("RETURNING ?", 4)
sql, args, err := b.ToSql()
assert.NoError(t, err)
expectedSql :=
"WITH prefix AS ? " +
"DELETE FROM a WHERE b = ? ORDER BY c LIMIT 2 OFFSET 3 " +
"RETURNING ?"
assert.Equal(t, expectedSql, sql)
expectedArgs := []interface{}{0, 1, 4}
assert.Equal(t, expectedArgs, args)
}
func TestDeleteBuilderToSqlErr(t *testing.T) {
_, _, err := Delete("").ToSql()
assert.Error(t, err)
}
func TestDeleteBuilderPlaceholders(t *testing.T) {
b := Delete("test").Where("x = ? AND y = ?", 1, 2)
sql, _, _ := b.PlaceholderFormat(Question).ToSql()
assert.Equal(t, "DELETE FROM test WHERE x = ? AND y = ?", sql)
sql, _, _ = b.PlaceholderFormat(Dollar).ToSql()
assert.Equal(t, "DELETE FROM test WHERE x = $1 AND y = $2", sql)
}
func TestDeleteBuilderRunners(t *testing.T) {
db := &DBStub{}
b := Delete("test").Where("x = ?", 1).RunWith(db)
expectedSql := "DELETE FROM test WHERE x = ?"
b.Exec()
assert.Equal(t, expectedSql, db.LastExecSql)
}
func TestDeleteBuilderNoRunner(t *testing.T) {
b := Delete("test")
_, err := b.Exec()
assert.Equal(t, RunnerNotSet, err)
}
func TestDeleteWithQuery(t *testing.T) {
db := &DBStub{}
b := Delete("test").Where("id=55").Suffix("RETURNING path").RunWith(db)
expectedSql := "DELETE FROM test WHERE id=55 RETURNING path"
b.Query()
assert.Equal(t, expectedSql, db.LastQuerySql)
}