mirror of https://github.com/aldy505/bob.git
40 lines
1.4 KiB
Go
40 lines
1.4 KiB
Go
package bob_test
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/aldy505/bob"
|
|
)
|
|
|
|
func TestReplacePlaceholder(t *testing.T) {
|
|
t.Run("should be able to replace placeholder to dollar", func(t *testing.T) {
|
|
sql := "INSERT INTO table_name (`col1`, `col2`, `col3`) VALUES (?, ?, ?), (?, ?, ?), (?, ?, ?);"
|
|
result := bob.ReplacePlaceholder(sql, bob.Dollar)
|
|
should := "INSERT INTO table_name (`col1`, `col2`, `col3`) VALUES ($1, $2, $3), ($4, $5, $6), ($7, $8, $9);"
|
|
|
|
if result != should {
|
|
t.Fatal("result string doesn't match:", result)
|
|
}
|
|
})
|
|
|
|
t.Run("should be able to replace placeholder to colon", func(t *testing.T) {
|
|
sql := "INSERT INTO table_name (`col1`, `col2`, `col3`) VALUES (?, ?, ?), (?, ?, ?), (?, ?, ?);"
|
|
result := bob.ReplacePlaceholder(sql, bob.Colon)
|
|
should := "INSERT INTO table_name (`col1`, `col2`, `col3`) VALUES (:1, :2, :3), (:4, :5, :6), (:7, :8, :9);"
|
|
|
|
if result != should {
|
|
t.Fatal("result string doesn't match:", result)
|
|
}
|
|
})
|
|
|
|
t.Run("should be able to replace placeholder to @p", func(t *testing.T) {
|
|
sql := "INSERT INTO table_name (`col1`, `col2`, `col3`) VALUES (?, ?, ?), (?, ?, ?), (?, ?, ?);"
|
|
result := bob.ReplacePlaceholder(sql, bob.AtP)
|
|
should := "INSERT INTO table_name (`col1`, `col2`, `col3`) VALUES (@p1, @p2, @p3), (@p4, @p5, @p6), (@p7, @p8, @p9);"
|
|
|
|
if result != should {
|
|
t.Fatal("result string doesn't match:", result)
|
|
}
|
|
})
|
|
}
|