2019-05-07 13:44:30 +02:00
|
|
|
package sqlbuilder
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"gotest.tools/assert"
|
|
|
|
|
"testing"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
func TestLockSingleTable(t *testing.T) {
|
|
|
|
|
lock := table1.LOCK().IN(LOCK_ROW_SHARE)
|
|
|
|
|
|
|
|
|
|
queryStr, _, err := lock.Sql()
|
|
|
|
|
|
|
|
|
|
assert.NilError(t, err)
|
2019-05-12 18:15:23 +02:00
|
|
|
assert.Equal(t, queryStr, `
|
|
|
|
|
LOCK TABLE db.table1 IN ROW SHARE MODE;
|
|
|
|
|
`)
|
2019-05-07 13:44:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestLockMultipleTable(t *testing.T) {
|
|
|
|
|
lock := LOCK(table2, table1).IN(LOCK_ACCESS_EXCLUSIVE).NOWAIT()
|
|
|
|
|
|
|
|
|
|
queryStr, _, err := lock.Sql()
|
|
|
|
|
|
|
|
|
|
assert.NilError(t, err)
|
2019-05-12 18:15:23 +02:00
|
|
|
assert.Equal(t, queryStr, `
|
|
|
|
|
LOCK TABLE db.table2, db.table1 IN ACCESS EXCLUSIVE MODE NOWAIT;
|
|
|
|
|
`)
|
2019-05-07 13:44:30 +02:00
|
|
|
}
|